Meer succesvolle detecties met data-resampling

Fraudedetectie in Python

Charlotte Werger

Data Scientist

Undersampling

Fraudedetectie in Python

Oversampling

Fraudedetectie 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)

Fraudedetectie in Python

Synthetic Minority Oversampling Technique (SMOTE)

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

Welke resampling-methode gebruik je?

  • Random Under Sampling (RUS): data weggooien, rekenefficiënt
  • Random Over Sampling (ROS): simpel en rechttoe-rechtaan, maar je traint op veel duplicaten
  • Synthetic Minority Oversampling Technique (SMOTE): geavanceerder en realistischer dataset, maar je traint op “nep” data
Fraudedetectie in Python

Wanneer resampling gebruiken

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))
Fraudedetectie in Python

Laten we oefenen!

Fraudedetectie in Python

Preparing Video For Download...