Increasing successful detections using data resampling

Fraud Detection in Python

Charlotte Werger

Data Scientist

Undersampling

Fraud Detection in Python

Oversampling

Fraud Detection in Python

Oversampling in Python

from imblearn.over_sampling import RandomOverSampler

method = RandomOverSampler() X_resampled, y_resampled = method.fit_resample(X, y)
compare_plots(X_resampled, y_resampled, X, y)

Fraud Detection in Python

Synthetic Minority Oversampling Technique (SMOTE)

1 https://www.kaggle.com/rafjaa/resampling-strategies-for-imbalanced-datasets
Fraud Detection in Python

Which resampling method to use?

  • Random Under Sampling (RUS): throw away data, computationally efficient
  • Random Over Sampling (ROS): straightforward and simple, but training your model on many duplicates
  • Synthetic Minority Oversampling Technique (SMOTE): more sophisticated and realistic dataset, but you are training on "fake" data
Fraud Detection in Python

When to use resampling methods

from sklearn.model_selection import train_test_split
from sklearn.linear_model import LogisticRegression

# Define resampling method and split into train and test method = SMOTE() X_train, X_test, y_train, y_test = train_test_split(X, y, train_size=0.8, random_state=0)
# Apply resampling to the training data only X_resampled, y_resampled = method.fit_resample(X_train, y_train)
# Continue fitting the model and obtain predictions model = LogisticRegression() model.fit(X_resampled, y_resampled)
# Get your performance metrics predicted = model.predict(X_test) print (classification_report(y_test, predicted))
Fraud Detection in Python

Let's practice!

Fraud Detection in Python

Preparing Video For Download...