Cross-validatie

Modelvalidatie in Python

Kasey Jones

Data Scientist

Cross-validatie

Train-, validatie- en testsets maak je door je data in 3 subsets te splitsen. Bijvoorbeeld 60% training en 20% voor zowel validatie als test.

Modelvalidatie in Python

Cross-validatie

Bij cross-validatie splits je de data meerdere keren in train- en validatiesets, niet één keer 80:20. Bijvoorbeeld 5 verschillende 80:20-splits.

Modelvalidatie in Python

n_splits: aantal cross-validatiesplits

shuffle: booleaan om te shufflen vóór het splitsen

random_state: random seed

from sklearn.model_selection import KFold

X = np.array(range(40))
y = np.array([0] * 20 + [1] * 20)

kf = KFold(n_splits=5)

splits = kf.split(X)
Modelvalidatie in Python
kf = KFold(n_splits=5)
splits = kf.split(X)

for train_index, test_index in splits: print(len(train_index), len(test_index))
32 8 32 8 32 8 32 8 32 8
# Print één van de indexsets:
print(train_index, test_index)
[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 ...]
[32 33 34 35 36 37 38 39]
Modelvalidatie in Python
rfr = RandomForestRegressor(n_estimators=25, random_state=1111)

errors = [] for train_index, val_index in splits: X_train, y_train = X[train_index], y[train_index] X_val, y_val = X[val_index], y[val_index] rfr.fit(X_train, y_train) predictions = rfr.predict(X_val) errors.append(<some_accuracy_metric>)
print(np.mean(errors))
4.25
Modelvalidatie in Python

Practice time

Modelvalidatie in Python

Preparing Video For Download...