This is a summary of the models and metrics I learned in the Nanodegree Machine Learning Engineer from Udacity, in which I told my experience here. I added some models and libraries that I used at other times. As it is a quick chear sheet, the goal will always be to update this post.
Remember, this is not a post with details of each models or metrics, just to have a quick reminder, with brief summary of the model, advantages, disadvantages and examples of use cases. I put all the imports in the end, since we usually use more than one in one analysis.
Conclusion – Machine Learning Cheat Sheet. Machine Learning is going to have huge effects on the economy and living in general. Entire work tasks and industries can be automated, and the job market will be changed forever. Machine learning is the next big thing that will have more growth in the industry and improve the economy. Python For Data Science Cheat Sheet Python Basics Variables and Data T string es at Select t Jupyter spyder Lists ecu ANACONDA 20 Nu mpy np G. Ther Microsoft Azure Machine Learning: Algorithm Cheat Sheet CLUSTERING START TWO-CLASS CLASSIFICATION training. By Andre Ye, Cofounder at Critiq, Editor & Top Writer at Medium. Source: Pixabay. There are several areas of data mining and machine learning that will be covered in this cheat-sheet: Predictive Modelling. Regression and classification algorithms for supervised learning (prediction), metrics for evaluating model performance.
- Supervised Learning
- Unsupervised Learning
Supervised Learning
Supervised Learning are Machine Learning models that based on historical data, with outputs that we already know as correct, the algorithm is trained to be able to predict new results.
There are two types of problems for this type of learning:
- Regression: we try to predict quantitative (numerical)
- Classification: we try to predict qualitative (discrete)
Naive Bayes
What is it?
It is a sort probabilíticos based on Bayes Theorem, created by Thomas Bayes. However, being naive it may have false positives.Bayes Theorem: probability of an event occurring conditioning the other.Example: A If the probability of happening B is happening XX%.
Naive: understand that all events are independent, which can generate false positives.
There are 3 types of classifiers Naives Bayes:
- Bernoulli Naive Bayes: will assume that the binary features are typically represented by 0 and 1 negative and positive.
- Multinomial Naive Bayes: used with the features are discretes, as words or classifications from 1 to 5.
Gaussian Naive Bayes: used when the features are continuous and there is the assumption of the normal distribution.
- Where can it be used?
- Spam filter
- Sentimental Analysis
- Profile analysis: a lending profile analysis, checks whether a user is a good payer, pays assiduously, among other variables, to complete the loan if it is profitable for that user
- Data Mining: database with various texts to identify literary author or style, based on the historical, such as text structure, language, words used
- There is a system that supports average decisions about cardiac disease, Heart Disease Prediction System. It was developed using as a main model the Naive Bayes. The model can answer complex queries to diagnose heart disease and thus help health professionals make intelligent clinical decisions than traditional systems of decision support can not * The model Gaussian Naives Bayes was used to predict inhibition of protein activity by small molecules absorption, distribution, metabolism and excretion (ADME), prioritizing hit high throughput screening campaigns and enrichment of high yield coupling of the results
- Advantages
- Easy implementation
- Can work with categorical data and continuous
- It is performative and can be used in real time
- No need for a set of training data so large compared to other models
- Not to irrelevant features is sensitive
- Returns the degree of certainty of the answer
- Disadvantages
- Because it does not identify the interaction of the data, its dependence may occur false positives
- When dealing with phrases there is a problem it separate each word and there is loss of meaning as Chicago Bulls, with a basketball team and interpresta algorithm Chicago as a city and as Bulls as animal
Decision Trees
What is it?
Decision tree is a tree-shaped diagram used to determine a course of action. Each node of the tree represents a possible decision, occurrence or reaction.
A Decision Tree can be used in two ways:
- Classifier: used to predict values when the dependent variable (Y) is categorical.
Regression: used to predict values when the dependent variable (Y) is continuous.
- Where can it be used?
- Fraud Detection on credit cards, as can be seen in this example
- Recommendation Systems: like products, movies, websites, etc. A real case was Recommender Systems (RS), an algorithm created to increase sales and customer satisfaction. attempts to predict how a user will rank items based on their previous ratings and ratings from other users with similar profiles and thus recommend the item for purchase.
- Advantages
- Easy to understand, interpret and visualize
- Need little effort to prepare data (no need to normalize data, etc.)
- Can be used with categorical and numerical data
- No need to worry about outliers or if data is not linearly
- Easily read with feature interactions and not parametric
- Disadvantages
- Does not support online learning, needs to rebuild the tree when it gets new data
- It can be easily overfitting, however it can be resolved with Ensemble Methods
- The model may become unstable due to the small variation in the data
- Stability: small variations in the data can generate many different trees
- May be biased if some class is dominant
Support Vector Machines
What is it?
It can be used for classification and regression problems. It uses a technique called kernel to transform its data, and then, based on those transformations, it finds an optimal boundary between possible outputs.
- Where can it be used?
- Facial recognition
- Calligraphy Recognition
- Protein Structure Forecast
- Breast Cancer Diagnostics: experimental results show that linear kernel based on the bagging method may be the best choices for a small-scale dataset where the selection of features must be performed at the pre-processing stage of data .For a large-scale dataset, the RBF kernel based on the boosting method had better enhancement performance than the other classifiers, see this example
- Advantages
- High accuracy
- Can work with non-linear data
- Works well with data not yet structured and semi-structured, such as text, images and trees
- With an appropriate kernel function, you can solve complex problems
- Works well with high dimensional data
- Low risk of overfitting, using the correct kernels
- Disadvantages
- Does not provide probability estimates directly
- Does not perform well with large training data sets
- Difficult to choose a good kernel function
- Difficult to understand and interpret the final model, variable weights and individual impact.
Linear Regressions
What is it?
Linear Regression is used to predict the continuous output indices (X). It has a linear relationship with the values of X to predict the value of Y.
- Simple Linear Regression: When there is only one input variable (X)
Multiple Linear Regression: When there are only two or more input variables (X)
- Can it be used?
- Forecast the annual time depending on the time of experience in a company
- Predict Sales x Amount invested for marketing
- Predict Daily Weight Gain vs. Input Weight
- Provide Acquisition of credit cards / Card limit, multiplus benefits
- Forecast Production vs. Quantity of Exports and Capacity
- Forecast Economic growth
- Advantages
- Easy to understand and explain
- Identification of the sensate the model edit textualized values (R²)
- Can work with a small dataset
- Disadvantages
- Requires an output variable to do the normal distribution
- Hardly R² is high for real cases
- Concepts
- SSE (Sum of Square Errors): Sum of Errors, Squares, Minimum, Used for Score of other models as fit metric
- Degree of freedom: Degrees of freedom, number of values in the final calculation of a statistic that are free to vary
- R²: a coefficient of determination that varies between 0 and 1 and shows the explanatory model of the observed values. The higher the R², the more explanatory the model is, the better it adjusts to the sample.
K-Nearest Neighbors
What is it?
Estimate the probability associated with the occurrence of a given event due to some features. The results of the analysis are contained within a range of 0 to 1.
- Where can it be used?
- Risk forecast the tax area
- Used to rank if the company is in the solvent or insolvent group of companies
- Determine what characteristics lead companies to adopt the balanced scorecard
- Advantages
- Provide result in terms of probability
- High degree of reliability
- It is not necessary to assume multicollinearity
- Models can be easily updated with new data
- Disadvantages
- Sensitive to outliers
- Does not perfom well with high dimensionality
Logistic Regression
What is it?
Algorithm that estimates the probability associated to the occurrence of a certain event due to some features. Its output variable needs to be continuous and discrete inputs.
- Where can it be used?
- Image Segmentation and Categorization
- Geographic Image Processing
- Handwriting recognition
- Spam detection
- Advantages
- Logistic models can be updated easily with new data
- It is not necessary to worry about multicollinearity of data * Besides being a classifier also returns probability, percentage of the event can occur or not
- Disadvantages
- Does not work well with outliers
- Does not work well with a large number of categorical variables
Ensemble Methods
What is it?
Ensemble methods are ways to combine multiple models, creating a stronger and more accurate model.
Some of the methods are:
- Random Florest: used to build a model based on multiple Decision Trees during the training phase.
- AdaBoost: improves the model by means of the errors, changing the weights.
- Bagging: trains into several subsets, ie separates training data and divides them randomly, each having a weak learner, then joins the results of the weak learner to create a model based on the outputs most viewed by the models
- Gradient Boosting: attempts to minimize the Mean Square Error (MSE), so long as the sum of the residuals is close to 0 (or minimum) and the predicted values are close enough to the actual values.
XGBoost (Extreme Gradient Boosting): is an advanced implementation of Gradient Boosting, yet faster and with high predictive power. It has a variety of regularizations that reduce overfitting and improve overall performance.
- Where can it be used?
- Random Florest used in Kinect to track body movements and recreate them in-game.
AdaBoosting was used to detect the analysis of baseball player games, see the documentation.
- Advantages
- Better at avoiding overfitting
- Usually has models with stronger predictive power and accuracy than single models
- Disadvantages
- Scaling: Generally by training multiple models, can perform poorly with large datasets
- Difficult to deploy on real-time platform
Evaluating Models
Acronyms used in the concepts below:
- TP: True Positive, values that were correctly predicted by the algorithm as positive
- FP: False Positive, values that were incorrectly predicted to be positive
- TN: True Negatives, values that were correctly predicted to be negative
FN: False Negatives, values that were incorrectly predicted to be negative
- Accuracy: measures how often the classifier makes the correct prediction. It is the ratio between the number of correct predictions and the total number of predictions (the number of records tested). Mathematically expressed by:
begin{align}dot{Acurácia} & = frac{TP+TN}{TP+TN+FP+FN} end{align}
- Confusion Matrix: is an array of real values and values predicted by its algorithm, showing how many TP, TN, FP, and FN its model got. As we can see in Figure 1:
- Precision: is the ratio of true positives to all positives, regardless of whether they are classified correctly or not. Mathematically represented by:
begin{align}dot{Precision} & = frac{TP}{TP+FP} end{align}
- Recall: also called True Positive Rate (TPR) or Sensitivity, is the ratio of True Positives to all positives correctly classified and false negatives. Mathematically represented by:
begin{align}dot{Recall} & = frac{TP}{TP+FN} end{align}
- ROC: traces TPR vs. FPR at different classification thresholds. Decreasing the classification threshold classifies more items as positive, thus increasing both false positives and true positives. In other words, a model predicts the probability of a class being 1 or 0, using these probabilities it is possible to plot a distribution graph as in figure bellow, with the red curve representing 0 and the green curve for 1, with 0.5 being the limit between two classes
All positive values above the limit (greater than 0.5) will be True Positives (TP), and all negative values above the limit will be False Positives (FP), since they were incorrectly classified as positive values. Below the limit, all negative values will be True Negatives (TN) and positive False Negatives (FN), since they were incorrectly classified as negative. This concept is best demonstrated in Figure 3.
- AUC: measures the entire two-dimensional area under any ROC curve. AUC provides an aggregate measure of performance in all possible classification limits. One way to interpret AUC is as the probability of the model classifying a random positive example more than a random negative example. A model whose predictions are 100% wrong has an AUC of 0.0; while one whose predictions are 100% correct has an AUC of 1.0. According to Figure 4.
Classification Report: it is a report table with the main evaluation metrics for each class, being:: recall, precision and f1_score.
f1_score: is the harmonic mean that considers both: precision and recall, its formula being expressed by:
begin{align}dot{f1 score} & = 2 cdot frac{precision cdot recall}{precision + recall} end{align}
- fbeta_score: calculated using the mean (harmonic) of the precision and recall values, having a beta parameter that determines the weight of the precision in the score, being
beta <1
with greater weight for precision and ` beta> 1` favoring recall (beta = 0 consider only precision, beta = inf only recall). Mathematically expressed by:
begin{align}dot{F_beta score} = (1 + beta^2) cdot frac{precision cdot recall}{(beta^2 cdot precision) + recall}end{align}
Unupervised Learning
Unsupervised Learning are Machine Learning models that have little or none historical data to be based on and to predict results, they do not need a dataset to tell which are the correct output variables to model a predictive algorithm. These models can create data structures based on relationships between variables or detect some trends with clustering.
KMeans
What is it?
An algorithm that groups data that has characteristics similar to each other in a cluster. The K-means method has this name because K represents a number, since it is necessary to tell the algorithm how many clusters it wants to split the data. K-means is most commonly used in general use, with clusters of equal sizes, plane geometry, without large amounts of clusters. The algorithm always tries to find circular, spherical clusters.
Azure Machine Learning Cheat Sheet
It uses the distance measure to tell how similar each observation is, and can be:
- Euclidean distance: Euclidean distance between two points in a straight line
- Distance from Manhattan: sum of the distances between the lines that form 90º between two points, that is, sum of the line y to the point of intersection and line x. These measures are sensitive to the difference of scales between different variables:
Cosine distance: measure of the angle between two vectors. If the angle is 0 there is total similarity and if is π there is no relation between the objects.
- Where can it be used?
- Academic performance, based on student grades to separate students A, B or C
- Diagnostic system
- Movie catalog rating
- Classification of species of animals or plants
- Segmentation of customers according to consumption profiles
- Advantages
- Easy implementation and interpretation
- Good when you already have an idea of the required number of clusters
- Good scalability with many variables if k is not so high
- Disadvantages
- Early seeds have a great impact on the final results due to the local minumm when they are started in not so suitable places. Difficulty that can be bypassed by running the algorithm many times
- Difficult to predict the number of clusters (K-Value), you can use * elbow method * to get around this
- Sensitive to outliers
- Do not mess with missing values
- Does not work well with clusters that are not circular or spherical
- Sklearn Commands
- n_clusters: number of desired clusters, default 8
- max_iter: how many maximum interactions between assigning the points and moving the centroid, standard 300
- n_init: how many times the algorithm changes the centroids for different clusters, standard 10
- How to find the number of clusters (k)
- Elbow Method: method used to find the number of clusters most suitable for each data set, it plots the upstream values of k versus the total error calculated using this k. Here is a code to find this value:
Hierarchical
What is it?
The result of this algorithm is a grouping structure that gives us a visual indication of the relationship between clusters. It unified the data into clusters according to minimum distances, which are calculated according to each method:
Single Link: assumes that all points are a cluster and then groups them into clusters according to the distance of the points. Then, when there is an isolated point, it looks for the two ** closest points ** in the two clusters which is the distance between the clusters, and then joins the points forming another cluster. And then we choose how many clusters we want. This method does not exist in sklearn, instead we use Complete Link
Complete Link: assumes that all points are a cluster and then group them into clusters according to the distance of the points forming another cluster. And then, when there is an isolated point, it looks for the two most distant points in the two clusters which is the distance between the clusters, and then joins the points. And then we choose how many clusters we want.To join other clusters, it calculates the largest distance between the points, which we will name distance X, then measure the smallest distance X between clusters to join them.The problem of this method is that only one point is analyzed to verify the smallest distance, without taking into account the other data, which may be more dense, and may be another cluster.
Average Link: checks the distance between all points between clusters and the average of all distances is the distance measure between the two clusters.
Ward’s Link: method that attempts to minimize variance by merging the two clusters. It calculates a center point between two clusters, then checks the distance between each point and the center point, raises them squarely and sums all distances. Then it calculates a center point in each cluster, and subtracts each distance between points and center point of each cluster, raised to the square. ** This is the default sklean method. **
- Where can it be used?
- Using the Average Link method, it was possible to group produced proteins, used to create clusters of fungi types, see documentation
- Using the Complete Link method to draw a human microbiome diagram, see the documentation
- Advantages
- Works well with two-growing data set and two-rings
- Easy visualization of each clusters (dendograms)
- Especially powerful when the data set contains real hierarchical relationship (EX: evolutionary biology)
- Resulting hierarchical representations are very informative
- Disadvantages
- You need to choose which method is most appropriate
- Sensitive to noise and outilers
- It needs greater computational capacity when it has large datasets and many dimensionalities
Density Based Spatial Clustering of Application with Noise
What is it?
The algorithm groups the data that is dense together, points close together, and not all points are part of a cluster, the model names the other points as noise.It checks the distance ε (epsilon) around the points and if there are no other near enough points, it is considered noise. We have to set the parameters of minimum number of points per cluster and distance ε.Core point: is the point that has the minimum number of points required and identifies a cluster. The same cluster can have multiple core pointsBorder point: points that do not have the minimum number of required points around, yet are part of a cluster around a Core Point
- Where can it be used?
- Analyze network traffic, a network administrator can separate groups of traffic types as users of bulk downloads and others. See the documentation
- Detection of anomalies in temperature data, in which the points named as noises are anomalies, outliers. See the documentation
- Advantages
- Good with data set with noise or outliers
- Flexible to work with different forms and constraints of clusters
- It is not necessary to specify the number of clusters
- Works well with two-growing data set and two-rings
- Disadvantages
- Border points that can be accessed from two clusters are assigned to the cluster that first encounters it
- It faces difficulty in finding clusters of different densities, we can use HDBSCAN in these cases
Gaussian Mixture Models
What is it?
It is a lightweight clustering algorithm in which all data is part of all clusters, yet with different levels of belonging. It does a data distribution, and if it is Gaussian they have a higher clustering level, that is, it mixes the Gaussian distributions to separate the clusters.
It works by the Expectation Maximization algorithm in the following steps:
- Define K, number Gaussian distributions. Mean setar and variances
- Step E, smooth grouping of the data. calculates the degree of ownership of each point for each cluster
- Step M, maximization step, use the data from the previous step and create new mean and variance parameters for each cluster. in a weighted way taking into account the level of ownership of each point
Validate the log-likelihood (log-likelihood) to check if it converges. The higher the number, the more certain we have that the mix model we generate is responsible for creating the data or fitting into the dataset we have
- Where can it be used?
- Reading sensor data to find people routines. Ex: As a shift sensor, the algorithm can identify when they are in the office, dining or out. Or, it can differentiate the way of driving that the person used. See the documentation
- Identify speech, signatures, biometrics.
- Computer vision, can detect image backgrounds, for example taking people out of a video and leaving just the scenery. See the documentation
- Advantages
- Needs less training than other models, such as logistic regression
- High scalability
- Not sensitive to * features * with little importance
- Returns the degree of certainty of the answer
- Light clustering, which makes samples part of multiple clusters
- Disadvantages
- Sensitive to initialization values
- The convergence rate is slow
- It is not good to learn with interactions of features, for example, if you like ice cream of flakes and chocolate, but hate the two flavors together
- Sensitive to initialization values
Evaluating Models
External Indices: used when the original data is labeled. One of its indexes is the Adjusted Rand score, being -1 to 1, the higher the better.
Internal Indices: used to request the adjustment between the data and the structure. One of its indexes is the Silhouette score, being -1 to 1, the higher the better, it is not a good index for DBSCAN, nor is it for clusters defined as two-rings. Good for compact, dense, circular groupings. For DBSCAN it is good to use the DBCV index.
Relative Indices: indicates which cluster structure is best in some sense
Validation indices are defined as:
- Compression: measure of proximity of the elements in each group
- Separability: measure of how far the clusters are from each other
Feature Scaling
What is it?
Method for transforming features with similar ranges so that they can be computable, usually between 0 and 1.In Sklearn there is a method that does this, MinMaxScaler, which transforms the data in this scale, but it must remember that your array must have numbers float (decimals)
Examples of templates that are affected by Feature Scaling:
- K-Means
- SVM with RBF
Examples of models that are not ** affected by Feature Scaling:
- Lienar Regression
Decision Trees
- Advantages
- Have a reliable number compared to what you expect on the way out
- Disadvantages
- Sensitive to outilers
Principal Component Analysis
What is it?
- Used to reduce the dimensionality of the features by maximizing the variances, losing the least amount of information to the designer data
- PCA is a systematized model of transforming the features of inputs into main components.
- These Main Components are available for use in place of the original features
- You can rank the Main Components
- The Main Components must be perpendicular to each other (90º), which means that they are independent of each other
- The maximum number of Main Components that can be obtained is equal to the number of inputs of the data set, however it is advisable not to use all, but those with the highest raking
Measurable variables: can measure directly, such as m², number of rooms, school ranking
Latent variables: we can not measure directly, but it is represented by other indicators (the measurable ones), generating a theoretical sense. Ex: size is the latent variable and its measurable variables are m² and number of rooms.
- When to use?
- When we want to see whether latent variables that can be shown in the data patterns
- Decrease dimensionality to:
- View when we have large dimensionaldiades
- Decrease noise
- Pre-processing the data
- Where can it be used?
- Facial recognition along with SVM
Random Projection
- What is it?
A dimensionality reduction method, mathematically more efficient and perfomatic than PCA for working with a large dimensional data set. Based on the Johnson-Linderstrauss Lemma, the algorithm multiplies the data set by a random matrix, preserving the distances between the points to a large degree, causing the number of dimensions to decrease
Independent Component Analysis
What is it?
ICA assumes that features are mixtures of independent sources, and the algorithm tries to isolate them from each other.A well-known example is the “Party Problem” which shows three people in the same hall in different locations, each recording the sound of the venue. Each venue is playing something different such as piano, cello guitar, and a TV.
All recordings pick up the sounds, but of different intensity for each. Clearing the three recordings to get the sound of each object alone is what the ICA does, and this process is called Blind source separationThe algorithm assumes that the components are statistically independent and with a non-Gaussian distribution
- Where can it be used?
- Medical Scanners: Brain mapping, sensors detect electrical or magnetic signals. ICA can be used to find the independent components within the brain.
- Magnetic resonance imaging to isolate where each signal from the brain comes from
Importing libraries
Bibliography
Castle, Nikki. 2017. Supervised vs. Unsupervised Machine Learning
Çelik, Mete, et al. 2001.Anomaly detection in temperature data using DBSCAN algorithm
Chen, Edwin. Choosing a Machine Learning Classifier
Erman, Jefreey, et al. 2006. Traffic Classification Using Clustering Algorithms
Gershman, Amir, et al. A Decision Tree Based Recommender System
Grover, Prince. 2017. Gradient Boosting from scratch
Huang, Min-Wei, et al. 2017. SVM and SVM Ensembles in Breast CancerPrediction
Klon, Anthony E., et al 2006. Improved Naive Bayesian Modeling of Numerical Data for Absorption, Distribution, Metabolism and Excretion (ADME) Property Prediction
Markoski,Branko. 2015. Application of AdaBoost Algorithm inBasketball Player Detection
Pattekari,Shadab Adam & Parveen, Asma. 2012. PREDICTION SYSTEM FOR HEART DISEASE USING NAIVE BAYES
Portella, Letícia. 2018. Machine Learning Models - My Cheat List
Sachanm Lalit, 2015. Logistic Regression vs Decision Trees vs SVM: Part II
Saunders, Diane, et al. 2012. Using hierarchical clustering of secreted protein families to classify and rank candidate effectors of rust fungi
Simplilean. 2018. Naive Bayes Classifier
Simplilean. 2018. KNN Algorithm
Singh, Aishwarya. 2018. A Comprehensive Guide to Ensemble Learning (with Python codes)
Sonagara, Darshan and Badheka, Soham. 2014. Comparison of Basic Clustering Algorithms
Spencer, Melanie, et al. 2010. Association between composition of the human gastrointestinal microbiome and development of fatty liver with choline deficiency
Statinfer, 2017. SVM : Advantages Disadvantages and Applications
Stauffer, Chris and Grmson W, E, L. Adaptive background mixture models for real-time tracking
Sun, Feng-Tso, et al. Nonparametric Discovery of Human Routines from Sensor Data
By Andre Ye, Cofounder at Critiq, Editor & Top Writer at Medium.
Source: Pixabay.
There are several areas of data mining and machine learning that will be covered in this cheat-sheet:
- Predictive Modelling. Regression and classification algorithms for supervised learning (prediction), metrics for evaluating model performance.
- Methods to group data without a label into clusters: K-Means, selecting cluster numbers based objective metrics.
- Dimensionality Reduction. Methods to reduce the dimensionality of data and attributes of those methods: PCA and LDA.
- Feature Importance. Methods to find the most important feature in a dataset: permutation importance, SHAP values, Partial Dependence Plots.
- Data Transformation. Methods to transform the data for greater predictive power, for easier analysis, or to uncover hidden relationships and patterns: standardization, normalization, box-cox transformations.
All images were created by the author unless explicitly stated otherwise.
Predictive Modelling
Train-test-split is an important part of testing how well a model performs by training it on designated training data and testing it on designated testing data. This way, the model’s ability to generalize to new data can be measured. In sklearn, both lists, pandas DataFrames, or NumPy arrays are accepted in X and y parameters.
Training a standard supervised learning model takes the form of an import, the creation of an instance, and the fitting of the model.
sklearnclassifier models are listed below, with the branch highlighted in blue and the model name in orange.
sklearnregressor models are listed below, with the branch highlighted in blue and the model name in orange.
Evaluating model performance is done with train-test data in this form:
sklearnmetrics for classification and regression are listed below, with the most commonly used metric marked in green. Many of the grey metrics are more appropriate than the green-marked ones in certain contexts. Each has its own advantages and disadvantages, balancing priority comparisons, interpretability, and other factors.
Clustering
Before clustering, the data needs to be standardized (information for this can be found in the Data Transformation section). Clustering is the process of creating clusters based on point distances.
Source. Image free to share.
Training and creating a K-Means clustering model creates a model that can cluster and retrieve information about the clustered data.
Accessing the labels of each of the data points in the data can be done with:
Similarly, the label of each data point can be stored in a column of the data with:
Accessing the cluster label of new data can be done with the following command. The new_data can be in the form of an array, a list, or a DataFrame.
Accessing the cluster centers of each cluster is returned in the form of a two-dimensional array with:
To find the optimal number of clusters, use the silhouette score, which is a metric of how well a certain number of clusters fits the data. For each number of clusters within a predefined range, a K-Means clustering algorithm is trained, and its silhouette score is saved to a list (scores). data is the x that the model is trained on.
After the scores are saved to the list scores, they can be graphed out or computationally searched for to find the highest one.
Dimensionality Reduction
Dimensionality reduction is the process of expressing high-dimensional data in a reduced number of dimensions such that each one contains the most amount of information. Dimensionality reduction may be used for visualization of high-dimensional data or to speed up machine learning models by removing low-information or correlated features.
Principal Component Analysis, or PCA, is a popular method of reducing the dimensionality of data by drawing several orthogonal (perpendicular) vectors in the feature space to represent the reduced number of dimensions. The variable number represents the number of dimensions the reduced data will have. In the case of visualization, for example, it would be two dimensions.
Visual demonstration of how PCA works. Source.
Fitting the PCA Model: The .fit_transform function automatically fits the model to the data and transforms it into a reduced number of dimensions.
Explained Variance Ratio: Calling model.explained_variance_ratio_ will yield a list where each item corresponds to that dimension’s “explained variance ratio,” which essentially means the percent of the information in the original data represented by that dimension. The sum of the explained variance ratios is the total percent of information retained in the reduced dimensionality data.
PCA Feature Weights: In PCA, each newly creates feature is a linear combination of the former data’s features. Theselinear weights can be accessed with model.components_, and are a good indicator for feature importance (a higher linear weight indicates more information represented in that feature).
Linear Discriminant Analysis (LDA, not to be commonly confused with Latent Dirichlet Allocation) is another method of dimensionality reduction. The primary difference between LDA and PCA is that LDA is a supervised algorithm, meaning it takes into account both x and y. Principal Component Analysis only considers x and is hence an unsupervised algorithm.
PCA attempts to maintain the structure (variance) of the data purely based on distances between points, whereas LDA prioritizes clean separation of classes.
Feature Importance
Feature Importance is the process of finding the most important feature to a target. Through PCA, the feature that contains the most information can be found, but feature importance concerns a feature’s impact on the target. A change in an ‘important’ feature will have a large effect on the y-variable, whereas a change in an ‘unimportant’ feature will have little to no effect on the y-variable.
Permutation Importance is a method to evaluate how important a feature is. Several models are trained, each missing one column. The corresponding decrease in model accuracy as a result of the lack of data represents how important the column is to a model’s predictive power. The eli5 library is used for Permutation Importance.
In the data that this Permutation Importance model was trained on, the column lat has the largest impact on the target variable (in this case, the house price). Permutation Importance is the best feature to use when deciding which to remove (correlated or redundant features that actually confuse the model, marked by negative permutation importance values) in models for best predictive performance.
SHAP is another method of evaluating feature importance, borrowing from game theory principles in Blackjack to estimate how much value a player can contribute. Unlike permutation importance, SHapley Addative ExPlanations use a more formulaic and calculation-based method towards evaluating feature importance. SHAP requires a tree-based model (Decision Tree, Random Forest) and accommodates both regression and classification.
PD(P) Plots, or partial dependence plots, are a staple in data mining and analysis, showing how certain values of one feature influence a change in the target variable. Imports required include pdpbox for the dependence plots and matplotlib to display the plots.
Isolated PDPs: the following code displays the partial dependence plot, where feat_name is the feature within X that will be isolated and compared to the target variable. The second line of code saves the data, whereas the third constructs the canvas to display the plot.
Machine Learning Metrics Cheat Sheet Answers
The partial dependence plot shows the effect of certain values and changes in the number of square feet of living space on the price of a house. Shaded areas represent confidence intervals.
Contour PDPs: Partial dependence plots can also take the form of contour plots, which compare not one isolated variable but the relationship between two isolated variables. The two features that are to be compared are stored in a variable compared_features.
The relationship between the two features shows the corresponding price when only considering these two features. Partial dependence plots are chock-full of data analysis and findings, but be conscious of large confidence intervals.
Data Transformation
Standardizing or scaling is the process of ‘reshaping’ the data such that it contains the same information but has a mean of 0 and a variance of 1. By scaling the data, the mathematical nature of algorithms can usually handle data better.
The transformed_data is standardized and can be used for many distance-based algorithms such as Support Vector Machine and K-Nearest Neighbors. The results of algorithms that use standardized data need to be ‘de-standardized’ so they can be properly interpreted. .inverse_transform() can be used to perform the opposite of standard transforms.
Normalizing data puts it on a 0 to 1 scale, something that, similar to standardized data, makes the data mathematically easier to use for the model.
While normalizing doesn’t transform the shape of the data as standardizing does, it restricts the boundaries of the data. Whether to normalize or standardize data depends on the algorithm and the context.
Box-cox transformations involve raising the data to various powers to transform it. Box-cox transformations can normalize data, make it more linear, or decrease the complexity. These transformations don’t only involve raising the data to powers but also fractional powers (square rooting) and logarithms.
For instance, consider data points situated along the function g(x). By applying the logarithm box-cox transformation, the data can be easily modelled with linear regression.
Created with Desmos.
sklearn automatically determines the best series of box-cox transformations to apply to the data to make it better resemble a normal distribution.
Because of the nature of box-cox transformation square-rooting, box-cox transformed data must be strictly positive (normalizing the data beforehand can take care of this). For data with negative data points as well as positive ones, set method = ‘yeo-johnson’ for a similar approach to making the data more closely resemble a bell curve.
Original. Reposted with permission.
Related: