-
-
Notifications
You must be signed in to change notification settings - Fork 927
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Add first version of a Comet integration * Remove debug prints * Add test for Comet Configuration transformation to env variables * Fix last lint warning * Update Readme for Comet logging documentation * Update Comet integration to be optional, update code and tests * Add documentation for Comet configuration * Add missing check
- Loading branch information
1 parent
dee7723
commit 6d3caad
Showing
11 changed files
with
315 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
[settings] | ||
profile=black | ||
known_third_party=wandb | ||
known_third_party=wandb,comet_ml |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,12 @@ | ||
""" | ||
Basic utils for Axolotl | ||
""" | ||
import importlib | ||
import importlib.util | ||
|
||
|
||
def is_mlflow_available(): | ||
return importlib.util.find_spec("mlflow") is not None | ||
|
||
|
||
def is_comet_available(): | ||
return importlib.util.find_spec("comet_ml") is not None |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
"""Comet module for trainer callbacks""" | ||
|
||
import logging | ||
from typing import TYPE_CHECKING | ||
|
||
import comet_ml | ||
from transformers import TrainerCallback, TrainerControl, TrainerState | ||
|
||
from axolotl.utils.distributed import is_main_process | ||
|
||
if TYPE_CHECKING: | ||
from axolotl.core.trainer_builder import AxolotlTrainingArguments | ||
|
||
LOG = logging.getLogger("axolotl.callbacks") | ||
|
||
|
||
class SaveAxolotlConfigtoCometCallback(TrainerCallback): | ||
"""Callback to save axolotl config to comet""" | ||
|
||
def __init__(self, axolotl_config_path): | ||
self.axolotl_config_path = axolotl_config_path | ||
|
||
def on_train_begin( | ||
self, | ||
args: "AxolotlTrainingArguments", # pylint: disable=unused-argument | ||
state: TrainerState, # pylint: disable=unused-argument | ||
control: TrainerControl, | ||
**kwargs, # pylint: disable=unused-argument | ||
): | ||
if is_main_process(): | ||
try: | ||
comet_experiment = comet_ml.start(source="axolotl") | ||
comet_experiment.log_other("Created from", "axolotl") | ||
comet_experiment.log_asset( | ||
self.axolotl_config_path, | ||
file_name="axolotl-config", | ||
) | ||
LOG.info( | ||
"The Axolotl config has been saved to the Comet Experiment under assets." | ||
) | ||
except (FileNotFoundError, ConnectionError) as err: | ||
LOG.warning(f"Error while saving Axolotl config to Comet: {err}") | ||
return control |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
"""Module for wandb utilities""" | ||
|
||
import logging | ||
import os | ||
|
||
from axolotl.utils.dict import DictDefault | ||
|
||
LOG = logging.getLogger("axolotl.utils.comet_") | ||
|
||
COMET_ENV_MAPPING_OVERRIDE = { | ||
"comet_mode": "COMET_START_MODE", | ||
"comet_online": "COMET_START_ONLINE", | ||
} | ||
COMET_EXPERIMENT_CONFIG_ENV_MAPPING_OVERRIDE = { | ||
"auto_histogram_activation_logging": "COMET_AUTO_LOG_HISTOGRAM_ACTIVATIONS", | ||
"auto_histogram_epoch_rate": "COMET_AUTO_LOG_HISTOGRAM_EPOCH_RATE", | ||
"auto_histogram_gradient_logging": "COMET_AUTO_LOG_HISTOGRAM_GRADIENTS", | ||
"auto_histogram_tensorboard_logging": "COMET_AUTO_LOG_HISTOGRAM_TENSORBOARD", | ||
"auto_histogram_weight_logging": "COMET_AUTO_LOG_HISTOGRAM_WEIGHTS", | ||
"auto_log_co2": "COMET_AUTO_LOG_CO2", | ||
"auto_metric_logging": "COMET_AUTO_LOG_METRICS", | ||
"auto_metric_step_rate": "COMET_AUTO_LOG_METRIC_STEP_RATE", | ||
"auto_output_logging": "COMET_AUTO_LOG_OUTPUT_LOGGER", | ||
"auto_param_logging": "COMET_AUTO_LOG_PARAMETERS", | ||
"comet_disabled": "COMET_AUTO_LOG_DISABLE", | ||
"display_summary_level": "COMET_DISPLAY_SUMMARY_LEVEL", | ||
"distributed_node_identifier": "COMET_DISTRIBUTED_NODE_IDENTIFIER", | ||
"log_code": "COMET_AUTO_LOG_CODE", | ||
"log_env_cpu": "COMET_AUTO_LOG_ENV_CPU", | ||
"log_env_details": "COMET_AUTO_LOG_ENV_DETAILS", | ||
"log_env_disk": "COMET_AUTO_LOG_ENV_DISK", | ||
"log_env_gpu": "COMET_AUTO_LOG_ENV_GPU", | ||
"log_env_host": "COMET_AUTO_LOG_ENV_HOST", | ||
"log_env_network": "COMET_AUTO_LOG_ENV_NETWORK", | ||
"log_git_metadata": "COMET_AUTO_LOG_GIT_METADATA", | ||
"log_git_patch": "COMET_AUTO_LOG_GIT_PATCH", | ||
"log_graph": "COMET_AUTO_LOG_GRAPH", | ||
"name": "COMET_START_EXPERIMENT_NAME", | ||
"offline_directory": "COMET_OFFLINE_DIRECTORY", | ||
"parse_args": "COMET_AUTO_LOG_CLI_ARGUMENTS", | ||
"tags": "COMET_START_EXPERIMENT_TAGS", | ||
} | ||
|
||
|
||
def python_value_to_environ_value(python_value): | ||
if isinstance(python_value, bool): | ||
if python_value is True: | ||
return "true" | ||
|
||
return "false" | ||
|
||
if isinstance(python_value, int): | ||
return str(python_value) | ||
|
||
if isinstance(python_value, list): # Comet only have one list of string parameter | ||
return ",".join(map(str, python_value)) | ||
|
||
return python_value | ||
|
||
|
||
def setup_comet_env_vars(cfg: DictDefault): | ||
# TODO, we need to convert Axolotl configuration to environment variables | ||
# as Transformers integration are call first and would create an | ||
# Experiment first | ||
|
||
for key in cfg.keys(): | ||
if key.startswith("comet_") and key != "comet_experiment_config": | ||
value = cfg.get(key, "") | ||
|
||
if value is not None and value != "": | ||
env_variable_name = COMET_ENV_MAPPING_OVERRIDE.get(key, key.upper()) | ||
final_value = python_value_to_environ_value(value) | ||
os.environ[env_variable_name] = final_value | ||
|
||
if cfg.comet_experiment_config: | ||
for key, value in cfg.comet_experiment_config.items(): | ||
if value is not None and value != "": | ||
config_env_variable_name = ( | ||
COMET_EXPERIMENT_CONFIG_ENV_MAPPING_OVERRIDE.get(key) | ||
) | ||
|
||
if config_env_variable_name is None: | ||
LOG.warning( | ||
f"Unknown Comet Experiment Config name {key}, ignoring it" | ||
) | ||
continue | ||
|
||
final_value = python_value_to_environ_value(value) | ||
os.environ[config_env_variable_name] = final_value | ||
|
||
# Enable comet if project name is present | ||
if cfg.comet_project_name and len(cfg.comet_project_name) > 0: | ||
cfg.use_comet = True |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.