Synthetische oversampling

Fraudedetectie in R

Sebastiaan Höppner

PhD researcher in Data Science at KU Leuven

Oversampling met 'SMOTE'

  • SMOTE: Synthetic Minority Oversampling TEchnique (Chawla et al., 2002)
  • Over-sample de minderheidsklasse (= fraude) door synthetische gevallen te creëren
Fraudedetectie in R
dim(transfer_data)
1000    4
head(transfer_data)
  isFraud    amount   balance     ratio
1   false  528.6840 1529.4732 0.3456641
2   false  184.0193  836.3509 0.2200265
3   false 1885.8024 2984.0684 0.6319568
4   false  732.0286 1248.7217 0.5862224
prop.table(table(transfer_data$isFraud))
 false  true
  0.99  0.01
Fraudedetectie in R

smote_scatterplot_1

Fraudedetectie in R

smote_scatterplot_2

Fraudedetectie in R

SMOTE

Kies een fraudegeval X (Tim)

smote_zoomin

Fraudedetectie in R

SMOTE - stap 1

Stap 1

Vind de K dichtstbijzijnde frauduleuze buren van X (Tim)

bv. K = 4

smote_step1

Fraudedetectie in R

SMOTE - stap 2

Stap 2

Kies willekeurig één van Tims dichtste buren

bv. X4 (Bart)

smote_step2

Fraudedetectie in R

SMOTE - stap 3

Stap 3: maak een synthetisch voorbeeld

synthetic_case_1

Fraudedetectie in R

SMOTE - stap 3

Stap 3: maak een synthetisch voorbeeld

synthetic_case_2

Fraudedetectie in R

SMOTE - stap 3

Stap 3: maak een synthetisch voorbeeld

synthetic_case_3

Fraudedetectie in R

SMOTE - stap 3

smote_step3

Fraudedetectie in R

SMOTE - stap 4

Stap 4

Herhaal stappen 1-3 voor elk fraudegeval dup_size keer

bv. dup_size = 10

smote_step3

Fraudedetectie in R
library(smotefamily)
smote_output = SMOTE(X = transfer_data[, -1],
                       target = transfer_data$isFraud,
                       K = 4,
                       dup_size = 10)

oversampled_data = smote_output$data
table(oversampled_data$isFraud)
false  true
  990   110
prop.table(table(oversampled_data$isFraud))
false  true
  0.9   0.1
Fraudedetectie in R

smote_result

Fraudedetectie in R

Laten we oefenen!

Fraudedetectie in R

Preparing Video For Download...