Datavoorbereiding voor NannyML

Monitoring Machine Learning in Python

Hakim Elakhrass

Co-founder and CEO of NannyML

Data laden

dataset_name = "green_taxi_dataset.csv"
data = pd.read_csv(dataset_name)
data.head()

De afbeelding is een screenshot van de eerste vijf rijen van de dataset.

Monitoring Machine Learning in Python

Data verwerken

# Create data partition
data['partition'] = pd.cut(
    data['lpep_pickup_datetime'],
    bins= [pd.to_datetime('2016-12-01'),
           pd.to_datetime('2016-12-08'),
           pd.to_datetime('2016-12-16'),
           pd.to_datetime('2017-01-01')],
    right=False,
    labels= ['train', 'test', 'prod']
)
Monitoring Machine Learning in Python

Data splitsen

# Target column name
target = 'tip_amount'
# Features column name
features = ["PULocationID", "DOLocationID", "trip_distance", "VendorID", "pickup_time"]
# Train set
X_train = data.loc[data['partition'] == 'train', features]
y_train = data.loc[data['partition'] == 'train', target]

# Test set (later reference set)
X_test = data.loc[data['partition'] == 'test', features]
y_test = data.loc[data['partition'] == 'test', target]

# Productieset (later analyseset)
X_prod = data.loc[data['partition'] == 'prod', features]
y_prod = data.loc[data['partition'] == 'prod', target]
Monitoring Machine Learning in Python

Het model bouwen

  • Train LGBMRegressor met de lightgbm-bibliotheek
  • Evalueer het model op een testset
  • Zet het model in productie
# Training the model
model = LGBMRegressor(random_state=42)
model.fit(X_train, y_train)

# Making predictions
y_pred_train = model.predict(X_train)
y_pred_test = model.predict(X_test)

# Evaluating the model on train and test set
mae_train = MAE(y_train, y_pred_train)
mae_test = MAE(y_test, y_pred_test)

# Deploying the model to production
y_pred_prod = model.predict(X_prod)
Monitoring Machine Learning in Python

Referentie- en analysesets maken

Referentieperiode

  • Gebruikt een testset

  • Vereist ground truth

  • Stelt de baselineprestatie vast

Analyseperiode

  • Meest recente productiedata

  • Ground truth is optioneel

  • NannyML analyseert datadrift en prestaties

# Creating reference set
reference = X_test.copy() # Test set features
reference['y_pred'] = y_pred_test # Predictions
reference['tip_amount'] = y_test # Labels
reference = reference.join(
    data['lpep_pickup_datetime']) # Timestamp
# Creating analysis set
analysis = X_prod.copy() # Production features
analysis['y_pred'] = y_pred_prod # Predictions
analysis = analysis.join(
    data['lpep_pickup_datetime']) # Timestamp
Monitoring Machine Learning in Python

Voorbeeld referentieset

  • Timestamp - tijdstip van de waarneming (optioneel)
  • Features - invoerkenmerken voor het model
  • Modeluitvoer
    • Predictions - voorspelscore van het model
    • Voorspellabels - geclippte waarschijnlijkheden
  • Target - bevat ground truth

De afbeelding toont de eerste vijf rijen van de referentieset.

Monitoring Machine Learning in Python

Laten we oefenen!

Monitoring Machine Learning in Python

Preparing Video For Download...