Experiment tracking is an optional feature of this repo. We have introduced experiment tracking to help in systematically recording hyperparameters, model configurations, and results from each experiment automatically and with the help of third party trackers like Aimstack.
Tracking can be enabled by passing a config in the Training Arguments with the name of the enabled trackers passed as a list.
from tuning import sft_trainer
training_args = TrainingArguments(
...,
trackers = ["aim", "file_logger"]
)
sft_trainer.train(train_args=training_args,...)
For each of the requested trackers the code expects you to pass a config to the sft_trainer.train
function which can be specified through tracker_conifgs
argument here details of which are present below.
File Logger is an inbuilt tracker which can be used to dump loss at every log interval to a file.
Currently File Logger
is enabled by default and will dump loss at every log interval of a training to a default file path specified here inside the output folder passed during training.
To override the location of file logger please pass an instance of the FileLoggingTrackerConfig to tracker_configs
argument.
from tuning import sft_trainer
from tuning.config.tracker_configs import FileLoggingTrackerConfig, TrackerConfigFactory
training_args = TrainingArguments(
...,
trackers = ["file_logger"]
)
logs_file = "new_train_logs.jsonl"
tracker_configs = TrackerConfigFactory(
file_logger_config=FileLoggingTrackerConfig(
training_logs_filename=logs_file
)
)
sft_trainer.train(train_args=training_args, tracker_configs=tracker_configs, ...)
Currently File Logging tacker supports only one argument and this file will be placed inside the train_args.output
folder.
To enable Aim users need to pass "aim"
as the requested tracker as part of the training argument.
When using Aimstack, users need to specify additional arguments which specify where the Aimstack database is present and what experiment name to use for tracking the training.
Aimstack supports either a local (filesystem path
) based db location or a remote (aim_server:port
) based database location.
See Aim documentation for more details.
After initialising a repo, users can specify the location of the repo either local or remote.
For a local aim database where aim_repo
should point to the path of where the initialized Aimstack repo is present,
from tuning import sft_trainer
from tuning.config.tracker_configs import AimConfig, TrackerConfigFactory
training_args = TrainingArguments(
...,
trackers = ["aim"],
)
tracker_configs = TrackerConfigFactory(
aim_config=AimConfig(
experiment="experiment-name",
aim_repo=<path_to_the_repo>
)
)
sft_trainer.train(train_args=training_args, tracker_configs=tracker_configs,....)
or, for a remote server where aimstack database is running at aim://aim_remote_server_ip:aim_remote_server_port
from tuning import sft_trainer
from tuning.config.tracker_configs import AimConfig, TrackerConfigFactory
training_args = TrainingArguments(
...,
trackers = ["aim"],
)
tracker_configs = TrackerConfigFactory(
aim_config=AimConfig(
experiment="experiment-name",
aim_remote_server_ip=<server_url>,
aim_remote_server_port=<server_port>
)
)
sft_trainer.train(train_args=training_args, tracker_configs=tracker_configs,....)
The code expects either the local
or remote
repo to be specified and will result in a ValueError
otherwise.
See AimConfig for more details.
If running the code via main function of sft_trainer.py the arguments to enable and customise trackers can be passed via commandline.
To enable tracking please pass
--tracker <aim/file_logger>
To further customise tracking you can specify additional arguments needed by the tracker like
--tracker aim --aim_repo <path-to-aimrepo> --experiment <experiment-name>