top of page

Machine Learning with Scikit-learn: A Comprehensive Guide to Supervised Learning using Python



I. Introduction to Machine Learning


a. Definition of Machine Learning


Machine Learning (ML) can be considered as teaching computers to learn from data and make predictions or decisions without explicitly programming them to perform a specific task. Think of it like teaching a toddler to recognize different shapes: you show them examples, and they learn to identify new shapes by comparing them to previous examples.


b. Examples of Machine Learning Applications


Here are some real-world applications of machine learning:

  • Predicting email spam: By analyzing the content and sender's details, a model can predict whether an email is spam or not.

  • Clustering books into categories: Based on textual features and writing styles, books can be grouped into genres such as fiction, non-fiction, mystery, etc.


c. Unsupervised Learning


Unsupervised learning is a branch of ML where the model learns from unlabelled data. Imagine putting different kinds of fruits in a basket and letting someone who has never seen them before group them by similarities. They might group them by color, size, or shape without knowing the specific types of fruits.


d. Supervised Learning


In contrast, supervised learning uses labeled data, where both the input and the correct output are known. It's like learning with a teacher who corrects you whenever you're wrong.


Examples of Supervised Learning:

  • Classification: Labeling an email as spam or not (binary classification) or categorizing a document into multiple classes (multi-class classification).

  • Regression: Predicting a continuous value, like the price of a house based on features like location, size, etc.


II. Getting Started with Supervised Learning


a. Naming Conventions


In supervised learning, we commonly use the following terminology:

  • Features: The input variables, like the ingredients in a recipe.

  • Predictor Variables: The algorithm's output, such as the taste of the dish.

  • Target Variables: The correct output we aim to predict.


b. Requirements Before Performing Supervised Learning


Before diving into model building, it's essential to prepare the data:

  1. Handling missing values: You can't bake a cake with missing ingredients. Likewise, you need to fill or remove missing values in your dataset.

import pandas as pd

data = pd.read_csv('data.csv')
data.fillna(data.mean(), inplace=True)

  1. Converting to numeric data format: If your ingredients are in different units (grams, pounds), you need to standardize them. Similarly, convert categorical variables to numeric form.

data['category'] = data['category'].astype('category').cat.codes

  1. Exploratory Data Analysis (EDA) and Data Visualization: This step is like tasting your dish while cooking, adjusting ingredients accordingly.

import seaborn as sns

sns.pairplot(data, hue='target')

The code snippet above will generate a pair plot that gives you insights into the relationships between variables.


By covering the basics of machine learning and the essential data preprocessing steps, we've set the foundation for diving into more complex topics related to the Scikit-learn library.


III. Scikit-learn Syntax


a. General Workflow


The standard process of building and deploying a machine learning model using scikit-learn involves several steps, akin to constructing a building from a blueprint:

  1. Importing models and algorithms: Choose the right tools for your construction.

from sklearn.neighbors import KNeighborsClassifier

  1. Fitting models to data: Lay the foundation by fitting your model to the training data.

model = KNeighborsClassifier(n_neighbors=3)
model.fit(X_train, y_train)

  1. Prediction methods: Once the building is ready, use it as needed, like making predictions on unseen data.

predictions = model.predict(X_test)


b. Example with k-Nearest Neighbors (KNN)


K-Nearest Neighbors is a simple yet powerful algorithm. Imagine you're in a room filled with different colored balloons (representing different classes), and you want to classify a new balloon. KNN does this by looking at the k closest balloons to the new one and assigning the majority color.


Understanding how KNN Uses Distance


The concept of distance is vital in KNN. If the balloons are closer, they're more likely to be of the same color. Here's how you can calculate the Euclidean distance:

import numpy as np

def euclidean_distance(x1, x2):
    return np.sqrt(np.sum((x1 - x2)**2))


IV. Building a Classification Model


a. Steps in Building a Classifier


Building a classifier with scikit-learn is like following a recipe. Here are the essential steps:

  1. Training: Teach your model to understand the pattern.

model.fit(X_train, y_train)

  1. Predicting Labels of Unseen Data: Let your model predict the unseen data, like tasting a new dish.

predictions = model.predict(X_test)


b. Understanding k-Nearest Neighbors (KNN)


KNN classifies new data points by voting. Think of it as asking k nearest friends for a movie recommendation.


Various Scenarios with Different Values of k

  • If k is too small, it's like asking only one friend, and the model can be too sensitive to noise.

  • If k is too large, the decision might be too general, like asking the whole town for advice.


c. KNN Intuition


Visualizing KNN helps in understanding how it classifies data points. A scatter plot with different colors for different classes can show how KNN classifies based on proximity.


d. Using Scikit-learn to Fit a Classifier


Here's how you fit a KNN classifier using scikit-learn:

from sklearn.neighbors import KNeighborsClassifier

knn = KNeighborsClassifier(n_neighbors=5)
knn.fit(X_train, y_train)


e. Predicting on Unlabeled Data


Once trained, you can predict on new observations:

new_predictions = knn.predict(X_new)


V. Measuring Model Performance


a. Evaluating Classifier Performance


Assessing the performance of a model is like tasting a dish to determine if it needs more seasoning. In the context of machine learning, various metrics can be used, but we'll focus on accuracy.


Introduction to the Accuracy Metric


Accuracy tells us the fraction of correct predictions out of all predictions. It's like hitting the bullseye on a target.

from sklearn.metrics import accuracy_score

accuracy = accuracy_score(y_test, predictions)
print(f"Accuracy: {accuracy * 100}%")


b. Computing Accuracy


To compute accuracy, we need to split our data into training and test sets.


Splitting Data into Training and Test Sets


Imagine dividing your data into two parts: one for training and the other for validating the trained model. Here's how you can do it:

from sklearn.model_selection import train_test_split

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)


Fitting the Classifier and Calculating Accuracy


After splitting, fit your model and calculate the accuracy:

model.fit(X_train, y_train)
predictions = model.predict(X_test)
accuracy = accuracy_score(y_test, predictions)


c. Train/Test Split


To further illustrate, think of splitting data as teaching a dog new tricks using only some of the toys (training set) and testing the dog's performance with unseen toys (test set).


Code Example and Best Practices for Splitting Data

# Using stratified splitting to maintain the class distribution
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, stratify=y, random_state=42)


d. Understanding Model Complexity


Model complexity is like adjusting the seasoning in a dish. Too little and it's bland

(underfitting); too much and it's overwhelming (overfitting).


Interpretation of k in KNN

  • Small k: The model pays too much attention to the noise in the training data.

  • Large k: The model may become too general.


e. Model Complexity and Over/Underfitting


You can visualize overfitting and underfitting using a model complexity curve.


Utilizing a Model Complexity Curve


You can iterate through various k values to calculate accuracies and plot the results:

import matplotlib.pyplot as plt

neighbors = range(1, 9)
train_accuracy = []
test_accuracy = []

for k in neighbors:
    model = KNeighborsClassifier(n_neighbors=k)
    model.fit(X_train, y_train)
    train_accuracy.append(model.score(X_train, y_train))
    test_accuracy.append(model.score(X_test, y_test))

plt.plot(neighbors, train_accuracy, label='Training accuracy')
plt.plot(neighbors, test_accuracy, label='Test accuracy')
plt.xlabel('Number of neighbors')
plt.ylabel('Accuracy')
plt.legend()
plt.show()


f. Plotting Results


The plot above provides a visual comparison between training and test accuracies, helping you find the sweet spot where the model performs well without overfitting or underfitting.


g. Interpreting the Model Complexity Curve


Analyze the plot to find the optimal k. It's like finding the right amount of seasoning that makes the dish neither too bland nor too spicy.


Conclusion


Machine learning, particularly with the Python scikit-learn library, offers an exciting avenue to unlock insights from data. In this tutorial, we have ventured through the realm of supervised learning, using the k-Nearest Neighbors (KNN) algorithm as our guide.


We started with a foundational understanding of machine learning, illustrating concepts with real-world examples and analogies. We moved on to explore how to set up, preprocess data, and get started with supervised learning, focusing on classification problems.


Our journey continued with a hands-on exploration of building a KNN classifier, where we looked at how the algorithm works, the intuition behind it, and practical code examples to fit, predict, and visualize KNN in action.

Finally, we delved into measuring model performance, discussing how to compute and interpret accuracy, understand model complexity, and identify the balance between overfitting and underfitting.


Whether you were a novice at the start or brushing up on existing knowledge, this tutorial has offered a step-by-step guide to supervised learning with scikit-learn, enriching your skill set and opening doors to further exploration in the machine learning landscape.


We hope this tutorial has provided you with a solid foundation and the inspiration to continue your journey into the fascinating world of machine learning. Feel free to experiment, explore other algorithms, and build on what you've learned here. The road to mastery is filled with continual learning and growth. Happy coding!

bottom of page