LocalFileLogger#
- class LocalFileLogger(experiments_folder: str, config: Dict[str, Any] | None = None, gzip: bool = False)[source]#
Bases:
BaseFileLogger
Logger for logging files into local folder.
It writes its result into folder like
experiments_folder/2021-12-12T12-12-12
, where the second part is related to datetime of starting the experiment.After every
start_experiment
it creates a new subfolderjob_type/group
. If some of these two values are None then behaviour is little different and described instart_experiment
method.Create instance of LocalFileLogger.
- Parameters:
experiments_folder (str) – path to folder to create experiment in
config (Dict[str, Any] | None) – a dictionary-like object for saving inputs to your job, like hyperparameters for a model or settings for a data preprocessing job
gzip (bool) – indicator whether to use compression during saving tables or not
Methods
finish_experiment
(*args, **kwargs)Finish experiment.
log
(msg, **kwargs)Log any event.
log_backtest_metrics
(ts, metrics_df, ...)Write metrics to logger.
log_backtest_run
(metrics, forecast, test)Backtest metrics from one fold to logger.
set_params
(**params)Return new object instance with modified parameters.
start_experiment
([job_type, group])Start experiment within current experiment, it is used for separate different folds during backtest.
to_dict
()Collect all information about etna object in dict.
Attributes
This class stores its
__init__
parameters as attributes.- log(msg: str | Dict[str, Any], **kwargs)[source]#
Log any event.
This class does nothing with it, use other loggers to do it.
- log_backtest_metrics(ts: TSDataset, metrics_df: DataFrame, forecast_df: DataFrame, fold_info_df: DataFrame)[source]#
Write metrics to logger.
- Parameters:
Notes
If some exception during saving is raised, then it becomes a warning.
- log_backtest_run(metrics: DataFrame, forecast: DataFrame, test: DataFrame)[source]#
Backtest metrics from one fold to logger.
- Parameters:
Notes
If some exception during saving is raised, then it becomes a warning.
- set_params(**params: dict) Self [source]#
Return new object instance with modified parameters.
Method also allows to change parameters of nested objects within the current object. For example, it is possible to change parameters of a
model
in aPipeline
.Nested parameters are expected to be in a
<component_1>.<...>.<parameter>
form, where components are separated by a dot.- Parameters:
**params (dict) – Estimator parameters
- Returns:
New instance with changed parameters
- Return type:
Self
Examples
>>> from etna.pipeline import Pipeline >>> from etna.models import NaiveModel >>> from etna.transforms import AddConstTransform >>> model = model=NaiveModel(lag=1) >>> transforms = [AddConstTransform(in_column="target", value=1)] >>> pipeline = Pipeline(model, transforms=transforms, horizon=3) >>> pipeline.set_params(**{"model.lag": 3, "transforms.0.value": 2}) Pipeline(model = NaiveModel(lag = 3, ), transforms = [AddConstTransform(in_column = 'target', value = 2, inplace = True, out_column = None, )], horizon = 3, )
- start_experiment(job_type: str | None = None, group: str | None = None, *args, **kwargs)[source]#
Start experiment within current experiment, it is used for separate different folds during backtest.
As a result, within
self.experiment_folder
subfolderjob_type/group
is created.If
job_type
orgroup
isn’t set then only one-level subfolder is created.If none of
job_type
andgroup
is set then experiment logs files intoself.experiment_folder
.