Manual log
Note
- Use manual log if,
Model framework is not supported for AutoLogging
External models where framework not supported for autolog or model built with third party native frameworks in external platforms (Azure, Sagemaker etc.)
- class ManualLog(experiment_name=None, set_as_current_exp=None, root_dir=None)
Bases:
object
Enables user to trace experiments from external machine learning engines manually.
- start_trace(experiment_id: str = None)
Start a tracing session when using manual log option. By default it uses the current experiment used in client initialization.
- Parameters:
experiment_id (str) – (Optional) ID of experiment. This will start logging session under specific experiment so runs will be under specific experiment.
A way you might use me is:
>>> client.manual_log.start_trace() >>> client.manual_log.start_trace(experiment_id="1")
- log_metric(key: str, value: float, step: int | None = None) None
Log a metric against active run.
- Parameters:
key (str) – Metric name.
value (float) – Metric value (float).
step (int) – Integer training step (iteration) at which was the metric calculated. Defaults to 0.
- Returns:
None
A way you might use me is:
>>> client.manual_log.log_metric("mae", .77)
- log_metrics(metrics: Dict[str, float], step: int | None = None) None
Log multiple metrics under active run.
- Parameters:
metrics (dict) – Dictionary of metric_name: String -> value: Float.
step (int) – Integer training step (iteration) at which was the metric calculated. Defaults to 0.
- Returns:
None
A way you might use me is:
>>> client.manual_log.log_metrics({"mse": 2000.00, "rmse": 50.00})
- log_param(key: str, value: Any) None
Log a param against active run.
- Parameters:
key (str) – Param name.
value – Param value.Value is converted to a string.
- Returns:
None
A way you might use me is:
>>> client.manual_log.log_param("c", 1)
- log_params(params: Dict[str, Any]) None
Log multiple params under active run.
- Parameters:
params (dict) – Dictionary of String -> value: (String, but will be string-ified if not)
- Returns:
None
A way you might use me is:
>>> client.manual_log.log_params({"n_estimators": 3, "random_state": 42})
- set_tag(key: str, value: Any) None
Log tag for active run.
- Parameters:
key (str) – Param name.
value – Param value.Value is converted to a string.
- Returns:
None
A way you might use me is:
>>> client.manual_log.set_tag("engineering", "ML Platform")
- set_tags(tags: Dict[str, Any]) None
Log multiple tags for active run.
- Parameters:
tags (dict) – Dictionary of tags names: String -> value: (String, but will be string-ified if not)
- Returns:
None
A way you might use me is:
>>> client.manual_log.set_tags({"engineering": "ML Platform", "release.candidate": "RC1"})
- end_trace()
End an active session.
A way you might use me is:
>>> client.manual_log.end_trace()