Skip to content

Commit

Permalink
Add EvaluationTracker to docs and fix its docstring (#464)
Browse files Browse the repository at this point in the history
* Fix definition of public in docstring

* Fix push_to_tensorboard param name in docstring

* Fix docstring style

* Add EvaluationTracker to docs

* Fix docstring style

* Move docstring to class header

* Add attributes to docstring

* Fix style

* Fix style

* Fix style

* Fix style

* Fix style

* Fix style

* Fix internal links in docstring
  • Loading branch information
albertvillanova authored Dec 19, 2024
1 parent c45e3c8 commit 988fa94
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 25 deletions.
5 changes: 4 additions & 1 deletion docs/source/package_reference/logging.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
# Loggers
# Logging

## EvaluationTracker
[[autodoc]] logging.evaluation_tracker.EvaluationTracker

## GeneralConfigLogger
[[autodoc]] logging.info_loggers.GeneralConfigLogger
Expand Down
51 changes: 27 additions & 24 deletions src/lighteval/logging/evaluation_tracker.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,16 +82,35 @@ def default(self, o):


class EvaluationTracker:
"""
Keeps track of the overall evaluation process and relevant informations.
"""Keeps track of the overall evaluation process and relevant information.
The [`EvaluationTracker`] contains specific loggers for experiments details
([`DetailsLogger`]), metrics ([`MetricsLogger`]), task versions
([`VersionsLogger`]) as well as for the general configurations of both the
specific task ([`TaskConfigLogger`]) and overall evaluation run
([`GeneralConfigLogger`]). It compiles the data from these loggers and
The [`~logging.evaluation_tracker.EvaluationTracker`] contains specific loggers for experiments details
([`~logging.evaluation_tracker.DetailsLogger`]), metrics ([`~logging.evaluation_tracker.MetricsLogger`]), task versions
([`~logging.evaluation_tracker.VersionsLogger`]) as well as for the general configurations of both the
specific task ([`~logging.evaluation_tracker.TaskConfigLogger`]) and overall evaluation run
([`~logging.evaluation_tracker.GeneralConfigLogger`]). It compiles the data from these loggers and
writes it to files, which can be published to the Hugging Face hub if
requested.
Args:
output_dir (`str`): Local folder path where you want results to be saved.
save_details (`bool`, defaults to True): If True, details are saved to the `output_dir`.
push_to_hub (`bool`, defaults to False): If True, details are pushed to the hub.
Results are pushed to `{hub_results_org}/details__{sanitized model_name}` for the model `model_name`, a public dataset,
if `public` is True else `{hub_results_org}/details__{sanitized model_name}_private`, a private dataset.
push_to_tensorboard (`bool`, defaults to False): If True, will create and push the results for a tensorboard folder on the hub.
hub_results_org (`str`, *optional*): The organisation to push the results to.
See more details about the datasets organisation in [`EvaluationTracker.save`].
tensorboard_metric_prefix (`str`, defaults to "eval"): Prefix for the metrics in the tensorboard logs.
public (`bool`, defaults to False): If True, results and details are pushed to public orgs.
nanotron_run_info ([`~nanotron.config.GeneralArgs`], *optional*): Reference to information about Nanotron models runs.
**Attributes**:
- **details_logger** ([`~logging.info_loggers.DetailsLogger`]) -- Logger for experiment details.
- **metrics_logger** ([`~logging.info_loggers.MetricsLogger`]) -- Logger for experiment metrics.
- **versions_logger** ([`~logging.info_loggers.VersionsLogger`]) -- Logger for task versions.
- **general_config_logger** ([`~logging.info_loggers.GeneralConfigLogger`]) -- Logger for general configuration.
- **task_config_logger** ([`~logging.info_loggers.TaskConfigLogger`]) -- Logger for task configuration.
"""

def __init__(
Expand All @@ -105,23 +124,7 @@ def __init__(
public: bool = False,
nanotron_run_info: "GeneralArgs" = None,
) -> None:
"""
Creates all the necessary loggers for evaluation tracking.
Args:
output_dir (str): Local folder path where you want results to be saved
save_details (bool): If True, details are saved to the output_dir
push_to_hub (bool): If True, details are pushed to the hub.
Results are pushed to `{hub_results_org}/details__{sanitized model_name}` for the model `model_name`, a public dataset,
if `public` is True else `{hub_results_org}/details__{sanitized model_name}_private`, a private dataset.
push_results_to_tensorboard (bool): If True, will create and push the results for a tensorboard folder on the hub
hub_results_org (str): The organisation to push the results to. See
more details about the datasets organisation in
[`EvaluationTracker.save`]
tensorboard_metric_prefix (str): Prefix for the metrics in the tensorboard logs
public (bool): If True, results and details are pushed in private orgs
nanotron_run_info (GeneralArgs): Reference to informations about Nanotron models runs
"""
"""Creates all the necessary loggers for evaluation tracking."""
self.details_logger = DetailsLogger()
self.metrics_logger = MetricsLogger()
self.versions_logger = VersionsLogger()
Expand Down

0 comments on commit 988fa94

Please sign in to comment.