Integrations
Lightning AI
and
ZenML logo in purple, representing machine learning pipelines and MLOps framework.
Accelerate and simplify model training with Lightning AI Studio and ZenML
Lightning AI
All integrations

Lightning AI

Accelerate and simplify model training with Lightning AI Studio and ZenML
Add to ZenML
Category
Orchestrator
COMPARE
related resources
No items found.

Accelerate and simplify model training with Lightning AI Studio and ZenML

Integrating Lightning AI with ZenML enables data scientists and ML engineers to streamline the model development process. By using the Lightning AI integration, you can run your ZenML pipelines on Lightning AI’s infrastructure, leveraging its managed environments and scalable compute. This integration simplifies code, improves reproducibility, and allows seamless scaling of model training across different hardware.

Features with ZenML

  • Faster Execution: Automatic packaging and upload of code to your Lightning AI Studio.
  • Reproducible Training: Ensure consistent training results by encapsulating Lightning AI configurations within ZenML pipelines.
  • Quick Experimentation: Using ZenML’s configurable pipelines, you can run experiments with different parameters and on different machines quickly.
  • Seamless Tracking: Track and compare model metrics, hyperparameters, and artifacts using ZenML's experiment tracking features.

Main Features

  • Managed infrastructure, including GPUs, for running your pipelines.
  • Deployment of models supported.
  • Built-in support for distributed training.
  • Easy scaling of workloads on Lightning AI’s infrastructure.

How to use ZenML with
Lightning AI

You have to first set up your stack to include a Lightning AI orchestrator. Run the following commands after replacing the values with your own.

zenml orchestrator register lightning_orchestrator \
    --flavor=lightning \
    --user_id=<YOUR_LIGHTNING_USER_ID> \
    --api_key=<YOUR_LIGHTNING_API_KEY> \
    --username=<YOUR_LIGHTNING_USERNAME> \
    --teamspace=<YOUR_LIGHTNING_TEAMSPACE> \
    --organization=<YOUR_LIGHTNING_ORGANIZATION>

# Register and activate a stack with the new orchestrator
zenml stack register lightning_stack -o lightning_orchestrator ... --set

You can also define settings inside your pipeline code and pass it to the settings parameter of your pipeline. Find out all the values you can set from our code docs.

from zenml import pipeline, step
from zenml.integrations.lightning.flavors.lightning_orchestrator_flavor import (
    LightningOrchestratorSettings,
)

lightning_settings = LightningOrchestratorSettings(
    main_studio_name="my_studio",  # change this to your studio name if you already have one
    machine_type="cpu",
    async_mode=True,
    custom_commands=["pip install -r requirements.txt"],
)


@step
def load_data() -> dict:
    """Simulates loading of training data and labels."""

    training_data = [[1, 2], [3, 4], [5, 6]]
    labels = [0, 1, 0]

    return {"features": training_data, "labels": labels}


@step
def train_model(data: dict) -> None:
    """
    A mock 'training' process that also demonstrates using the input data.
    In a real-world scenario, this would be replaced with actual model fitting logic.
    """
    total_features = sum(map(sum, data["features"]))
    total_labels = sum(data["labels"])

    print(
        f"Trained model using {len(data['features'])} data points. "
        f"Feature sum is {total_features}, label sum is {total_labels}"
    )


@pipeline(settings={"orchestrator": lightning_settings})
def simple_ml_pipeline():
    """Define a pipeline that connects the steps."""
    dataset = load_data()
    train_model(dataset)


if __name__ == "__main__":
    run = simple_ml_pipeline()
    # You can now use the `run` object to see steps, outputs, etc.

The code example demonstrates running a simple pipeline with the Lightning AI orchestrator. You can see that we set a studio name explicitly; ZenML creates one for you if you leave it empty. We can also configure a host of other options in the settings. In the snippet above, we have added the settings directly in code but you can also use YAML files to keep the code and configuration separate, allowing you to run the same piece of code with multiple configs.

Additional Resources
Read the documentation
Read the full Lightning AI integration documentation
Read the code docs on Lightning AI
Learn more about Lightning AI

Accelerate and simplify model training with Lightning AI Studio and ZenML

Integrating Lightning AI with ZenML enables data scientists and ML engineers to streamline the model development process. By using the Lightning AI integration, you can run your ZenML pipelines on Lightning AI’s infrastructure, leveraging its managed environments and scalable compute. This integration simplifies code, improves reproducibility, and allows seamless scaling of model training across different hardware.
Lightning AI

Start Your Free Trial Now

No new paradigms - Bring your own tools and infrastructure
No data leaves your servers, we only track metadata
Free trial included - no strings attached, cancel anytime
Dashboard displaying machine learning models, including versions, authors, and tags. Relevant to model monitoring and ML pipelines.

Connect Your ML Pipelines to a World of Tools

Expand your ML pipelines with Apache Airflow and other 50+ ZenML Integrations
Feast
Skypilot VM
Google Cloud
Sagemaker Pipelines
Amazon S3
MLflow
Argilla
BentoML
Deepchecks
TensorBoard
PyTorch Lightning