Merancang Alur Kerja Machine Learning di Python
Dr. Chris Anagnostopoulos
Honorary Associate Professor
Tingkat kebenaran:
Label tanpa noise atau kuat:
Label bernoise atau lemah:
Rekayasa fitur:
Rata-rata port unik yang dikunjungi tiap host terinfeksi:
np.mean(X[y]['unique_ports'])
15.11
Rata-rata port unik per host tanpa melihat label:
np.mean(X['unique_ports'])
11.23
Ubah sebuah fitur menjadi heuristik pelabelan:
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)
Akurasi hanya dengan ground truth:
0.91
Ground truth dan weak label tanpa bobot:
accuracy_score(y_test, clf.fit(X_train_aug, y_train_aug).predict(X_test))
0.93
Tambahkan bobot:
accuracy_score(y_test, clf.fit(X_train_aug, y_train_aug, sample_weight=weights).predict(X_test))
0.95
Merancang Alur Kerja Machine Learning di Python