Progettare workflow di Machine Learning in Python
Dr. Chris Anagnostopoulos
Honorary Associate Professor
Gradi di verità:
Etichette senza rumore o forti:
Etichette rumorose o deboli:
Feature engineering:
Media delle porte uniche visitate da ogni host infetto:
np.mean(X[y]['unique_ports'])
15.11
Media delle porte uniche visitate per host ignorando le etichette:
np.mean(X['unique_ports'])
11.23
Trasforma una feature in un'euristica di etichettatura:
X_train, X_test, y_train, y_test = train_test_split(X, y)
y_weak_train = X_train['unique_ports'] > 15


X_train_aug = pd.concat([X_train, X_train])
y_train_aug = pd.concat([pd.Series(y_train), pd.Series(y_weak_train)])

weights = [1.0]*len(y_train) + [0.1]*len(y_weak_train)
Accuratezza usando solo la verità a terra:
0.91
Verità a terra ed etichette deboli senza pesi:
accuracy_score(y_test, clf.fit(X_train_aug, y_train_aug).predict(X_test))
0.93
Aggiungi pesi:
accuracy_score(y_test, clf.fit(X_train_aug, y_train_aug, sample_weight=weights).predict(X_test))
0.95
Progettare workflow di Machine Learning in Python