Introductie tot dataversiebeheer met DVC
Ravi Bhadauria
Machine Learning Engineer
Reproduceerbaar: zelfde output in andere omgevingen en later
Modulair: losse, onafhankelijke, testbare modules
Consistent: één bron voor alle parameters

Bestanden moeten een ondersteund formaat hebben
params.yamlWe werken met YAML
.yaml of .ymlParameters als dictionaries
:Comments beginnen met #
Datatypes:
Datastructuren:
Inspringing is belangrijk
# Key-value pairs
a: 1
b: 1.2
c: "String value"
# Arrays
a: [1, 2.2, 3, 4.8]
b:
- 5
- "String value"
# Nested dictionaries
a:
b: "Some value"
c: "Some other value"
# Parameters voor datapreprocessing preprocess: ... target_column: RainTomorrow categorical_features: - Location - WindGustDir - ...# Parameters voor modeltraining/-evaluatie train_and_evaluate: rfc_params: n_estimators: 2 ...
# In model.py
def evaluate_model(model, X_test, y_test):
"""Evaluate a model on a test set and return metrics."""
y_pred = model.predict(X_test)
precision = precision_score(y_test, y_pred)
...
return { "accuracy": accuracy, "precision": precision,
"recall": recall, "f1_score": f1 }
# In entrypoint-code (train_and_evaluate.py)
from model import evaluate_model
metrics = evaluate_model(model, X_test, y_test)

Introductie tot dataversiebeheer met DVC