Python Tytorial PDF
Python Tytorial PDF
Python Tytorial PDF
Introduction
My latest data science project involved predicting the sales of each product in a particular store. There
were several ways I could approach the problem. But no matter which model I used, my accuracy score
would not improve.
I figured out the problem after spending some time inspecting the data – outliers!
This is a commonly overlooked mistake we tend to make. The temptation is to start building models on
the data you’ve been given. But that’s essentially setting yourself up for failure.
There are no shortcuts to data exploration. Building models will only get you so far if you’ve skipped this
stage of your data science project. After a point of time, you’ll hit the accuracy ceiling – the model’s
performance just won’t budge.
Data exploration consists of many things, such as variable identification, treating missing values, feature
engineering, etc. Detecting and treating outliers is also a major cog in the data exploration stage. The
quality of your inputs decide the quality of your output!
PyOD is one such library to detect outliers in your data. It provides access to more than 20 different
algorithms to detect outliers and is compatible with both Python 2 and 3. An absolute gem!
In this article, I will take you on a journey to understand outliers and how you can detect them using
PyOD in Python.
This article assumes you have a basic knowledge of machine learning algorithms and the Python
language. You can refer to this article -“Essentials of Machine Learning“, to understand or refresh these
concepts.
Table of Contents
1. What is an Outlier?
What is an Outlier?
An outlier is any data point which differs greatly from the rest of the observations in a dataset. Let’s
see some real life examples to understand outlier detection:
• When one student averages over 90% while the rest of the class is at 70% – a clear outlier
• While analyzing a certain customer’s purchase patterns, it turns out there’s suddenly an entry
for a very high value. While most of his/her transactions fall below Rs. 10,000, this entry is for
Rs. 1,00,000. It could be an electronic item purchase – whatever the reason, it’s an outlier in the
overall data
• How about Usain Bolt? Those record breaking sprints are definitely outliers when you factor in
the majority of athletes
There are a plethora of reasons why outliers exist. Perhaps an analyst made an error in the data entry,
or the machine threw up an error in measurement, or the outlier could even be intentional! Some
people do not want to disclose their information and hence input false information in forms.
Outliers are of two types: Univariate and Multivariate. A univariate outlier is a data point that consists
of extreme values in one variable only, whereas a multivariate outlier is a combined unusual score on at
least two variables. Suppose you have three different variables – X, Y, Z. If you plot a graph of these in a
3-D space, they should form a sort of cloud. All the data points that lie outside this cloud will be the
multivariate outliers.
I would highly recommend you to read this amazing guide on data exploration which covers outliers in
detail.
Outliers can impact the results of our analysis and statistical modeling in a drastic way. Check out the
below image to visualize what happens to a model when outliers are present versus when they have
been dealt with:
But here’s the caveat – outliers aren’t always a bad thing. It’s very important to understand this. Simply
removing outliers from your data without considering how they’ll impact the results is a recipe for
disaster.
“Outliers are not necessarily a bad thing. These are just observations that are not following the same
pattern as the other ones. But it can be the case that an outlier is very interesting. For example, if in a
biological experiment, a rat is not dead whereas all others are, then it would be very interesting to
understand why. This could lead to new scientific discoveries. So, it is important to detect outliers.”
Our tendency is to use straightforward methods like box plots, histograms and scatter-plots to detect
outliers. But dedicated outlier detection algorithms are extremely valuable in fields which process
large amounts of data and require a means to perform pattern recognition in larger datasets.
Applications like fraud detection in finance and intrusion detection in network security require intensive
and accurate techniques to detect outliers. Can you imagine how embarrassing it would be if you
detected an outlier and it turned out to be genuine?
The PyOD library can step in to bridge this gap. Let’s see what it’s all about.
Numerous outlier detection packages exist in various programming languages. I particularly found these
languages helpful in R. But when I switched to Python, there was a glaring lack of an outlier detection
library. How was this even possible?!
Existing implementations like PyNomaly are not specifically designed for outlier detection (though it’s
still worth checking out!). To fill this gap, Yue Zhao, Zain Nasrullah, and Zheng Li designed and
implemented the PyOD library.
PyOD is a scalable Python toolkit for detecting outliers in multivariate data. It provides access to
around 20 outlier detection algorithms under a single well-documented API.
Features of PyOD
PyOD has several advantages and comes with quite a few useful features. Here’s my pick of the bunch:
• Open Source with detailed documentation and examples across various algorithms
• Supports advanced models, including Neural Networks, Deep Learning, and Outlier Ensembles
• Optimized performance with JIT (Just in Time) and parallelization using numba and joblib
Time to power up our Python notebooks! Let’s first install PyOD on our machines:
pip install --upgrade pyod # to make sure that the latest version is installed!
As simple as that!
Note that PyOD also contains some neural network based models which are implemented in Keras. PyOD
will NOT install Keras or TensorFlow automatically. You will need to install Keras and other libraries
manually if you want to use neural net based models.
Let’s see the outlier detection algorithms that power PyOD. It’s well and good implementing PyOD but I
feel it’s equally important to understand how it works underneath. This will give you more flexibility
when you’re using it on a dataset.
Note: We will be using a term Outlying score in this section. It means every model, in some way, scores a
data point than uses threshold value to determine whether the point is an outlier or not.
• For any data point, the distance to its kth nearest neighbor could be viewed as the outlying
score
o Largest: Uses the distance of the kth neighbor as the outlier score
o Median: Uses the median of the distance to k neighbors as the outlier score
Isolation Forest
• It uses the scikit-learn library internally. In this method, data partitioning is done using a set of
trees. Isolation Forest provides an anomaly score looking at how isolated the point is in the
structure. The anomaly score is then used to identify outliers from normal observations
• It is an efficient unsupervised method which assumes the feature independence and calculates
the outlier score by building histograms
• It is much faster than multivariate approaches, but at the cost of less precision
• LOCI is very effective for detecting outliers and groups of outliers. It provides a LOCI plot for
each point which summarizes a lot of the information about the data in the area around the
point, determining clusters, micro-clusters, their diameters, and their inter-cluster distances
• None of the existing outlier-detection methods can match this feature because they output only
a single number for each point
Feature Bagging
• A feature bagging detector fits a number of base detectors on various sub-samples of the
dataset. It uses averaging or other combination methods to improve the prediction accuracy
• By default, Local Outlier Factor (LOF) is used as the base estimator. However, any estimator
could be used as the base estimator, such as kNN and ABOD
• Feature bagging first constructs n sub-samples by randomly selecting a subset of features. This
brings out the diversity of base estimators. Finally, the prediction score is generated by
averaging or taking the maximum of all base detectors
• It classifies the data into small clusters and large clusters. The anomaly score is then calculated
based on the size of the cluster the point belongs to, as well as the distance to the nearest large
cluster
• A function generate_data can be used to generate random data with outliers. Inliers data is
generated by a multivariate Gaussian distribution and outliers are generated by a uniform
distribution.
• We can provide our own values of outliers fraction and the total number of samples that we
want in our dataset. We will use this utility function to create data in the implementation part.
Implementation of PyOD
Enough talk – let’s see some action. In this section, we’ll implement the PyOD library in Python. I’m
going to use two different approaches to demonstrate PyOD:
import numpy as np
from scipy import stats
%matplotlib inline
import matplotlib.font_manager
Now, we’ll import the models we want to use to detect the outliers in our dataset. We will be using
ABOD (Angle Based Outlier Detector) and KNN (K Nearest Neighbors):
Now, we will create a random dataset with outliers and plot it.
outlier_fraction = 0.1
n_inliers = len(x_inliers)
n_outliers = len(x_outliers)
F1 = X_train[:,[0]].reshape(-1,1)
F2 = X_train[:,[1]].reshape(-1,1)
# create a meshgrid
plt.scatter(F1,F2)
plt.xlabel('F1')
plt.ylabel('F2')
Create a dictionary and add all the models that you want to use to detect the outliers:
classifiers = {
Fit the data to each model we have added in the dictionary, Then, see how each model is detecting
outliers:
plt.figure(figsize=(10, 10))
clf.fit(X_train)
y_pred = clf.predict(X_train)
# no of errors in prediction
# decision function calculates the raw anomaly score for every point
Z = clf.decision_function(np.c_[xx.ravel(), yy.ravel()]) * -1
Z = Z.reshape(xx.shape)
subplot = plt.subplot(1, 2, i + 1)
# fill orange contour lines where range of anomaly score is from threshold to maximum anomaly score
subplot.axis('tight')
subplot.legend(
[a.collections[0], b, c],
prop=matplotlib.font_manager.FontProperties(size=10),
loc='lower right')
subplot.set_title(clf_name)
subplot.set_xlim((-10, 10))
subplot.set_ylim((-10, 10))
plt.show()
Looking good!
Now, let’s see how PyOD does on the famous Big Mart Sales Problem.
Go ahead and download the dataset from the above link. Let’s start with importing the required libraries
and loading the data:
import pandas as pd
import numpy as np
# Import models
df = pd.read_csv("train.csv")
Let’s plot Item MRP vs Item Outlet Sales to understand the data:
df.plot.scatter('Item_MRP','Item_Outlet_Sales')
The range of Item Outlet Sales is from 0 to 12000 and Item MRP is from 0 to 250. We will scale down
both these features to a range between 0 and 1. This is required to create a explainable visualization (it
will become way too stretched otherwise). As for this data, using the same approach will take much
more time to create the visualization.
Note: If you don’t want the visualization, you can use the same scale to predict whether a point is an
outlier or not.
df[['Item_MRP','Item_Outlet_Sales']] = scaler.fit_transform(df[['Item_MRP','Item_Outlet_Sales']])
df[['Item_MRP','Item_Outlet_Sales']].head()
<img class="aligncenter wp-image-49817 size-full"
src="https://s3-ap-south-1.amazonaws.com/av-blog-media/wp-content/uploads/2019/02/Screenshot-
from-2019-02-05-18-25-01.png" alt="" width="270" height="189" />
Store these values in the NumPy array for using in our models later:
X1 = df['Item_MRP'].values.reshape(-1,1)
X2 = df['Item_Outlet_Sales'].values.reshape(-1,1)
X = np.concatenate((X1,X2),axis=1)
Again, we will create a dictionary. But this time, we will add some more models to it and see how each
model predicts outliers.
You can set the value of the outlier fraction according to your problem and your understanding of the
data. In our example, I want to detect 5% observations that are not similar to the rest of the data. So,
I’m going to set the value of outlier fraction as 0.05.
random_state = np.random.RandomState(42)
outliers_fraction = 0.05
classifiers = {
'Feature
Bagging':FeatureBagging(LOF(n_neighbors=35),contamination=outliers_fraction,check_estimator=False,
random_state=random_state),
Now, we will fit the data to each model one by one and see how differently each model predicts the
outliers.
clf.fit(X)
scores_pred = clf.decision_function(X) * -1
y_pred = clf.predict(X)
n_outliers = np.count_nonzero(y_pred == 1)
plt.figure(figsize=(10, 10))
# copy of dataframe
dfx = df
dfx['outlier'] = y_pred.tolist()
# decision function calculates the raw anomaly score for every point
Z = clf.decision_function(np.c_[xx.ravel(), yy.ravel()]) * -1
Z = Z.reshape(xx.shape)
# fill blue map colormap from minimum anomaly score to threshold value
# fill orange contour lines where range of anomaly score is from threshold to maximum anomaly score
plt.axis('tight')
plt.legend(
[a.collections[0], b,c],
prop=matplotlib.font_manager.FontProperties(size=20),
loc=2)
plt.xlim((0, 1))
plt.ylim((0, 1))
plt.title(clf_name)
plt.show()
OUTPUT
End Notes
That was an incredible learning experience for me as well. I spent a lot of time researching PyOD and
implementing it in Python. I would encourage you to do the same. Practice using it on different datasets
– it’s such a useful library!
PyOD already supports around 20 classical outlier detection algorithms which can be used in both
academic and commercial projects. Its contributors are planning to enhance the toolbox by
implementing models that will work well with time series and geospatial data.
If you have any suggestions/feedback related to the article, please post them in the comments section
below. I look forward to hearing your experience using PyOD as well. Happy learning.