Skip to content

aldente0630/ieee-fraud-detection

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IEEE-CIS Fraud Detection with Unsupervised Learning

Goals

  • Compare the prediction performances and computation times of various unsupervised learning anomaly detection algorithms such as Isolation Forest, Random Cut Forest and COPOD.
  • (Optional) Use Altair for the purpose of drawing interactive plots during EDA.

Requirements

  • The dataset can be downloaded from this Kaggle competition.
  • In addition to the Anaconda libraries, you need to install altair, category_encoders, pyod and scikit-learn version 0.24 or higher.
  • You also need to set up an AWS account and install awscli and sagemaker-python-sdk.

Exploratory Data Analysis

To preprocess data for modeling, I quickly explored proportions of missing values, cardinalities of categorical features, distributions of numerical features, and a correlation coefficient matrix. For the efficiency of the calculation, I selected some features by random sampling and looked at the proportions of their missing values. I have found that most of the features have a fairly high percentage of missing values.

Proportions of Missing Values

A list and description of categorical features can be found on this Kaggle page. Some categorical features have more than a few hundred categories, or even more than 10K.

Cardinalities of Categorical Features

In order to examine the distribution of numerical features, I randomly selected some features. From the histograms, it can be seen that most of the features have a long tail.

Histograms of Numeric Features

Finally, I calculated the correlation coefficient matrix. While most of the features are not correlated, some have very high positive correlations.

Correlation Matrix

Data Splitting and Preprocessing

In the general case of unsupervised learning, it is not possible to evaluate the predictive performance. However, since there are labels in this example, I split 20% of the total into the validation dataset. I preprocessed using ordinal encoding, missing value imputation, and Helmert Encoding for categorical features, and applied missing value imputation to numeric features. Then I normalized all the features.

Data Visualization with t-SNE

To view the transformed validation dataset, I reduced the dimensions of the dataset using t-SNE. The manifold looks like a few clusters, and the fraudulent labels appear to exist outside the clusters. Therefore, it seems that pretty good accuracy can be achieved even with unsupervised learning.

Scatter Plot of Manifold with t-SNE

Model Training and Prediction

Fitting and Prediction with Isolation Forest, Random Cut Forest and COPOD

I used popular tree ensemble models, namely Isolation Forest and Random Cut Forest, and the latest algorithm Copula-based Outlier Detection(COPOD). For detailed explanations and usages of the algorithms, please refer to the following link.

Isolation Forest fitting used 12 cores as multi-threading, but COPOD was fitted with a single thread. I used an AWS EC2 instance, ml.m4.xlarge to train SageMaker's First Party Algorithm Estimator, Random Cut Forest.

Model Evaluation

Anomaly scores output by the models have log-normal distributions with long tails as expected.

Histograms of Models

COPOD is the highest for both AUROC and AUPRC, followed by Isolation Forest, followed by Random Cut Forest.

ROC Curves

PR Curves

The results are summarized in a table as follows.

Estimator AUROC AUPRC Training Time Spec.
COPOD 77.55% 15.53% 4min 54s MacBook Pro (16 CPUs, mem 32GB)
Isolation Forest 76.33% 13.74% 5min 49s MacBook Pro (16 CPUs, mem 32GB)
Random Cut Forest 74.22% 12.71% 3min 35s EC2 ml.m4.xlarge (2 CPUs, mem 16GB)

Conclusion

COPOD performance was the best in AUROC, the competition criterion, so I fitted the entire dataset with it and submitted the predictions. The final result is AUROC 77.26%, which is quite far from 94.59%, which is No. 1 in the private leaderboard, but the possibility as unsupervised learning could be found.

Releases

No releases published

Packages

No packages published