Comet
zenml.integrations.comet
special
Initialization for the Comet integration.
The CometML integrations currently enables you to use Comet tracking as a convenient way to visualize your experiment runs within the Comet ui.
CometIntegration (Integration)
Definition of Comet integration for ZenML.
Source code in zenml/integrations/comet/__init__.py
class CometIntegration(Integration):
"""Definition of Comet integration for ZenML."""
NAME = COMET
REQUIREMENTS = ["comet-ml>=3.0.0"]
@classmethod
def flavors(cls) -> List[Type[Flavor]]:
"""Declare the stack component flavors for the Comet integration.
Returns:
List of stack component flavors for this integration.
"""
from zenml.integrations.comet.flavors import (
CometExperimentTrackerFlavor,
)
return [CometExperimentTrackerFlavor]
flavors()
classmethod
Declare the stack component flavors for the Comet integration.
Returns:
Type | Description |
---|---|
List[Type[zenml.stack.flavor.Flavor]] |
List of stack component flavors for this integration. |
Source code in zenml/integrations/comet/__init__.py
@classmethod
def flavors(cls) -> List[Type[Flavor]]:
"""Declare the stack component flavors for the Comet integration.
Returns:
List of stack component flavors for this integration.
"""
from zenml.integrations.comet.flavors import (
CometExperimentTrackerFlavor,
)
return [CometExperimentTrackerFlavor]
experiment_trackers
special
Initialization for the comet experiment tracker.
comet_experiment_tracker
Implementation for the Comet experiment tracker.
CometExperimentTracker (BaseExperimentTracker)
Track experiment using Comet.
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
class CometExperimentTracker(BaseExperimentTracker):
"""Track experiment using Comet."""
@property
def config(self) -> CometExperimentTrackerConfig:
"""Returns the `CometExperimentTrackerConfig` config.
Returns:
The configuration.
"""
return cast(CometExperimentTrackerConfig, self._config)
@property
def settings_class(self) -> Type[CometExperimentTrackerSettings]:
"""Settings class for the Comet experiment tracker.
Returns:
The settings class.
"""
return CometExperimentTrackerSettings
def prepare_step_run(self, info: "StepRunInfo") -> None:
"""Configures a Comet experiment.
Args:
info: Info about the step that will be executed.
"""
os.environ[COMET_API_KEY] = self.config.api_key
settings = cast(
CometExperimentTrackerSettings, self.get_settings(info)
)
tags = settings.tags + [info.run_name, info.pipeline.name]
comet_exp_name = (
settings.run_name or f"{info.run_name}_{info.pipeline_step_name}"
)
self._initialize_comet(
run_name=comet_exp_name, tags=tags, settings=settings.settings
)
def get_step_run_metadata(
self, info: "StepRunInfo"
) -> Dict[str, "MetadataType"]:
"""Get component- and step-specific metadata after a step ran.
Args:
info: Info about the step that was executed.
Returns:
A dictionary of metadata.
"""
exp_url: Optional[str] = None
exp_name: Optional[str] = None
if self.experiment:
exp_url = self.experiment.url
exp_name = self.experiment.name
# If the URL cannot be retrieved, use the default experiment URL
default_exp_url = (
f"https://www.comet.com/{self.config.workspace}/"
f"{self.config.project_name}/experiments/"
)
exp_url = exp_url or default_exp_url
# If the experiment name cannot be retrieved, use the default name
default_exp_name = f"{info.run_name}_{info.pipeline_step_name}"
settings = cast(
CometExperimentTrackerSettings, self.get_settings(info)
)
exp_name = exp_name or settings.run_name or default_exp_name
return {
METADATA_EXPERIMENT_TRACKER_URL: Uri(exp_url),
"comet_experiment_name": exp_name,
}
def cleanup_step_run(self, info: "StepRunInfo", step_failed: bool) -> None:
"""Stops the Comet experiment.
Args:
info: Info about the step that was executed.
step_failed: Whether the step failed or not.
"""
if self.experiment:
self.experiment.end()
os.environ.pop(COMET_API_KEY, None)
def log_metrics(
self,
metrics: Dict[str, Any],
step: Optional[int] = None,
) -> None:
"""Logs metrics to the Comet experiment.
Args:
metrics: Dictionary of metrics to log.
step: Optional step number associated with the metrics.
"""
if self.experiment:
self.experiment.log_metrics(metrics, step=step)
def log_params(self, params: Dict[str, Any]) -> None:
"""Logs parameters to the Comet experiment.
Args:
params: Dictionary of parameters to log.
"""
if self.experiment:
self.experiment.log_parameters(params)
def _initialize_comet(
self,
run_name: str,
tags: List[str],
settings: Union[Dict[str, Any], None] = None,
) -> None:
"""Initializes a Comet experiment.
Args:
run_name: Name of the Comet experiment.
tags: Tags to attach to the Comet experiment.
settings: Additional settings for the Comet experiment.
"""
logger.info(
f"Initializing Comet with workspace {self.config.workspace}, project "
f"name: {self.config.project_name}, run_name: {run_name}."
)
self.experiment = Experiment(
workspace=self.config.workspace,
project_name=self.config.project_name,
**settings or {},
)
self.experiment.set_name(run_name)
self.experiment.add_tags(tags)
config: CometExperimentTrackerConfig
property
readonly
Returns the CometExperimentTrackerConfig
config.
Returns:
Type | Description |
---|---|
CometExperimentTrackerConfig |
The configuration. |
settings_class: Type[zenml.integrations.comet.flavors.comet_experiment_tracker_flavor.CometExperimentTrackerSettings]
property
readonly
Settings class for the Comet experiment tracker.
Returns:
Type | Description |
---|---|
Type[zenml.integrations.comet.flavors.comet_experiment_tracker_flavor.CometExperimentTrackerSettings] |
The settings class. |
cleanup_step_run(self, info, step_failed)
Stops the Comet experiment.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
info |
StepRunInfo |
Info about the step that was executed. |
required |
step_failed |
bool |
Whether the step failed or not. |
required |
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
def cleanup_step_run(self, info: "StepRunInfo", step_failed: bool) -> None:
"""Stops the Comet experiment.
Args:
info: Info about the step that was executed.
step_failed: Whether the step failed or not.
"""
if self.experiment:
self.experiment.end()
os.environ.pop(COMET_API_KEY, None)
get_step_run_metadata(self, info)
Get component- and step-specific metadata after a step ran.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
info |
StepRunInfo |
Info about the step that was executed. |
required |
Returns:
Type | Description |
---|---|
Dict[str, MetadataType] |
A dictionary of metadata. |
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
def get_step_run_metadata(
self, info: "StepRunInfo"
) -> Dict[str, "MetadataType"]:
"""Get component- and step-specific metadata after a step ran.
Args:
info: Info about the step that was executed.
Returns:
A dictionary of metadata.
"""
exp_url: Optional[str] = None
exp_name: Optional[str] = None
if self.experiment:
exp_url = self.experiment.url
exp_name = self.experiment.name
# If the URL cannot be retrieved, use the default experiment URL
default_exp_url = (
f"https://www.comet.com/{self.config.workspace}/"
f"{self.config.project_name}/experiments/"
)
exp_url = exp_url or default_exp_url
# If the experiment name cannot be retrieved, use the default name
default_exp_name = f"{info.run_name}_{info.pipeline_step_name}"
settings = cast(
CometExperimentTrackerSettings, self.get_settings(info)
)
exp_name = exp_name or settings.run_name or default_exp_name
return {
METADATA_EXPERIMENT_TRACKER_URL: Uri(exp_url),
"comet_experiment_name": exp_name,
}
log_metrics(self, metrics, step=None)
Logs metrics to the Comet experiment.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
metrics |
Dict[str, Any] |
Dictionary of metrics to log. |
required |
step |
Optional[int] |
Optional step number associated with the metrics. |
None |
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
def log_metrics(
self,
metrics: Dict[str, Any],
step: Optional[int] = None,
) -> None:
"""Logs metrics to the Comet experiment.
Args:
metrics: Dictionary of metrics to log.
step: Optional step number associated with the metrics.
"""
if self.experiment:
self.experiment.log_metrics(metrics, step=step)
log_params(self, params)
Logs parameters to the Comet experiment.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
params |
Dict[str, Any] |
Dictionary of parameters to log. |
required |
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
def log_params(self, params: Dict[str, Any]) -> None:
"""Logs parameters to the Comet experiment.
Args:
params: Dictionary of parameters to log.
"""
if self.experiment:
self.experiment.log_parameters(params)
prepare_step_run(self, info)
Configures a Comet experiment.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
info |
StepRunInfo |
Info about the step that will be executed. |
required |
Source code in zenml/integrations/comet/experiment_trackers/comet_experiment_tracker.py
def prepare_step_run(self, info: "StepRunInfo") -> None:
"""Configures a Comet experiment.
Args:
info: Info about the step that will be executed.
"""
os.environ[COMET_API_KEY] = self.config.api_key
settings = cast(
CometExperimentTrackerSettings, self.get_settings(info)
)
tags = settings.tags + [info.run_name, info.pipeline.name]
comet_exp_name = (
settings.run_name or f"{info.run_name}_{info.pipeline_step_name}"
)
self._initialize_comet(
run_name=comet_exp_name, tags=tags, settings=settings.settings
)
flavors
special
Comet integration flavors.
comet_experiment_tracker_flavor
Comet experiment tracker flavor.
CometExperimentTrackerConfig (BaseExperimentTrackerConfig, CometExperimentTrackerSettings)
pydantic-model
Config for the Comet experiment tracker.
Attributes:
Name | Type | Description |
---|---|---|
workspace |
Optional[str] |
Name of an existing Comet workspace. |
project_name |
Optional[str] |
Name of an existing Comet project to log to. |
api_key |
str |
API key that should be authorized to log to the configured Comet workspace and project. |
Source code in zenml/integrations/comet/flavors/comet_experiment_tracker_flavor.py
class CometExperimentTrackerConfig( # type: ignore[misc] # https://github.com/pydantic/pydantic/issues/4173
BaseExperimentTrackerConfig, CometExperimentTrackerSettings
):
"""Config for the Comet experiment tracker.
Attributes:
workspace: Name of an existing Comet workspace.
project_name: Name of an existing Comet project to log to.
api_key: API key that should be authorized to log to the configured Comet
workspace and project.
"""
api_key: str = SecretField()
workspace: Optional[str] = None
project_name: Optional[str] = None
CometExperimentTrackerFlavor (BaseExperimentTrackerFlavor)
Flavor for the Comet experiment tracker.
Source code in zenml/integrations/comet/flavors/comet_experiment_tracker_flavor.py
class CometExperimentTrackerFlavor(BaseExperimentTrackerFlavor):
"""Flavor for the Comet experiment tracker."""
@property
def name(self) -> str:
"""Name of the flavor.
Returns:
The name of the flavor.
"""
return COMET_EXPERIMENT_TRACKER_FLAVOR
@property
def docs_url(self) -> Optional[str]:
"""A url to point at docs explaining this flavor.
Returns:
A flavor docs url.
"""
return self.generate_default_docs_url()
@property
def sdk_docs_url(self) -> Optional[str]:
"""A url to point at SDK docs explaining this flavor.
Returns:
A flavor SDK docs url.
"""
return self.generate_default_sdk_docs_url()
@property
def logo_url(self) -> str:
"""A url to represent the flavor in the dashboard.
Returns:
The flavor logo.
"""
return "https://public-flavor-logos.s3.eu-central-1.amazonaws.com/experiment_tracker/comet.png"
@property
def config_class(self) -> Type[CometExperimentTrackerConfig]:
"""Returns `CometExperimentTrackerConfig` config class.
Returns:
The config class.
"""
return CometExperimentTrackerConfig
@property
def implementation_class(self) -> Type["CometExperimentTracker"]:
"""Implementation class for this flavor.
Returns:
The implementation class.
"""
from zenml.integrations.comet.experiment_trackers import (
CometExperimentTracker,
)
return CometExperimentTracker
config_class: Type[zenml.integrations.comet.flavors.comet_experiment_tracker_flavor.CometExperimentTrackerConfig]
property
readonly
Returns CometExperimentTrackerConfig
config class.
Returns:
Type | Description |
---|---|
Type[zenml.integrations.comet.flavors.comet_experiment_tracker_flavor.CometExperimentTrackerConfig] |
The config class. |
docs_url: Optional[str]
property
readonly
A url to point at docs explaining this flavor.
Returns:
Type | Description |
---|---|
Optional[str] |
A flavor docs url. |
implementation_class: Type[CometExperimentTracker]
property
readonly
Implementation class for this flavor.
Returns:
Type | Description |
---|---|
Type[CometExperimentTracker] |
The implementation class. |
logo_url: str
property
readonly
A url to represent the flavor in the dashboard.
Returns:
Type | Description |
---|---|
str |
The flavor logo. |
name: str
property
readonly
Name of the flavor.
Returns:
Type | Description |
---|---|
str |
The name of the flavor. |
sdk_docs_url: Optional[str]
property
readonly
A url to point at SDK docs explaining this flavor.
Returns:
Type | Description |
---|---|
Optional[str] |
A flavor SDK docs url. |
CometExperimentTrackerSettings (BaseSettings)
pydantic-model
Settings for the Comet experiment tracker.
Attributes:
Name | Type | Description |
---|---|---|
run_name |
Optional[str] |
The Comet experiment name. |
tags |
List[str] |
Tags for the Comet experiment. |
settings |
Dict[str, Any] |
Settings for the Comet experiment. |
Source code in zenml/integrations/comet/flavors/comet_experiment_tracker_flavor.py
class CometExperimentTrackerSettings(BaseSettings):
"""Settings for the Comet experiment tracker.
Attributes:
run_name: The Comet experiment name.
tags: Tags for the Comet experiment.
settings: Settings for the Comet experiment.
"""
run_name: Optional[str] = None
tags: List[str] = []
settings: Dict[str, Any] = {}