/opsml

Next generation of machine learning artifact management and observability

Primary LanguagePythonOtherNOASSERTION


opsml logo

OSS Version 3.0.0 Coming Soon!

Universal Machine Learning Artifact Registration Platform

Unit Tests Examples Storage Integration Tests Style Ruff uv Py-Versions Checked with mypy Pydantic v2 gitleaks AWS S3 Google Cloud Storage Azure License: MIT

What is it?

OpsML is a comprehensive toolkit designed to streamline and standardize machine learning operations. It offers:

  • Universal Registration System: A centralized platform for managing all ML artifacts.
  • Standardized Governance: Implement consistent practices across data science and engineering teams.
  • Artifact Lifecycle Management: Robust tracking, versioning, and storage solutions for all ML components.
  • Reproducible Workflows: Establish repeatable patterns for ML project management.
  • Cross-functional Compatibility: Bridge the gap between data science experimentation and production engineering.
  • Version Control for ML: Apply software engineering best practices to machine learning artifacts.
  • Metadata-Driven Approach: Enhance discoverability and traceability of models, datasets, and experiments.

This toolkit empowers teams to maintain rigorous control over their ML projects, from initial data preprocessing to model deployment and monitoring, all within a unified, scalable framework.

Why OpsML?

OpsML addresses a critical gap in the ML ecosystem: the lack of a universal standard for artifact registration and governance. Our experience with various open-source and proprietary tools revealed a persistent need to integrate disparate systems for effective artifact management and deployment. This led to the development of OpsML, a unified framework designed to streamline ML operations.

Key Features:

  • Modular Architecture: Seamlessly integrates into existing ML pipelines and workflows.
  • Card-based Artifact System: Implements a SQL-based registry for tracking, versioning, and storing ML artifacts (data, models, runs, projects). Think of it as trading cards for machine learning.
  • Strong Type Enforcement: Ensures data integrity with built-in type checking for data and model artifacts.
  • Extensive Library Support: Compatible with a wide range of ML and data processing libraries.
  • Automated ML Ops:
    • Auto-conversion to ONNX format
    • Intelligent metadata generation
    • Streamlined production packaging
    • Out of the box model monitoring*
  • Unified Governance Model: Provides a consistent framework for managing the entire ML lifecycle, from experimentation to production.
  • Scalable Design: Accommodates growing complexity of ML projects and increasing team sizes.

OpsML aims to be the common language for ML artifact management, reducing cognitive overhead and enabling teams to focus on model development and deployment rather than operational complexities.

* OpsML is integrated with Scouter out of the box. However, a Scouter server instance is required to use this feature.

Incorporate into Existing Workflows

Add quality control to your ML projects with little effort! With OpsML, data and models are added to interfaces and cards, which are then registered via card registries.

Incorporate into Existing Workflows

Given its simple and modular design, OpsML can be easily incorporated into existing workflows.


opsml logo

Installation:

Poetry

poetry add opsml

Pip

pip install opsml

Setup your local environment:

By default, OpsML will log artifacts and experiments locally. To change this behavior and log to a remote server, you'll need to set the following environment variables:

export OPSML_TRACKING_URI=${YOUR_TRACKING_URI}

You can find more information on how to set up the tracking and storage uris here.

Quickstart

If running the example below locally, with a local server, make sure to install the server extra:

poetry add "opsml[server]"
from sklearn.linear_model import LinearRegression
from opsml import CardInfo, CardRegistries, DataCard, ModelCard, PandasData, SklearnModel
from opsml.helpers.data import create_fake_data

# Setup
info = CardInfo(name="linear-regression", repository="opsml", contact="user@email.com")
registries = CardRegistries()

# Create and register DataCard
X, y = create_fake_data(n_samples=1000, task_type="regression")
X["target"] = y

data_interface = PandasData(
    data=X,
    data_splits=[
        DataSplit(label="train", column_name="col_1", column_value=0.5, inequality=">="),
        DataSplit(label="test", column_name="col_1", column_value=0.5, inequality="<"),
    ],
    dependent_vars=["target"]
)

datacard = DataCard(interface=data_interface, info=info)
registries.data.register_card(card=datacard)

# Train model
data = datacard.split_data()
reg = LinearRegression().fit(data["train"].X, data["train"].y)

# Create and register ModelCard
model_interface = SklearnModel(
    model=reg,
    sample_data=data["train"].X,
    task_type="regression"
)

modelcard = ModelCard(
    interface=model_interface,
    info=info,
    to_onnx=True,
    datacard_uid=datacard.uid
)
registries.model.register_card(card=modelcard)

Table of Contents

Usage

Now that OpsML is installed, you're ready to start using it!

It's time to point you to the official Documentation Website for more information on how to use OpsML

Advanced Installation Scenarios

see Installation for more information on how to install OpsML in different environments.

Supported Libraries

OpsML is designed to work with a variety of ML and data libraries. The following libraries are currently supported:

Data Libraries

Name Opsml Implementation
Pandas PandasData
Polars PolarsData
Torch TorchData
Arrow ArrowData
Numpy NumpyData
Sql SqlData
Text TextDataset
Image ImageDataset

Model Libraries

Name Opsml Implementation Example
Sklearn SklearnModel link
LightGBM LightGBMModel link
XGBoost XGBoostModel link
CatBoost CatBoostModel link
Torch TorchModel link
Torch Lightning LightningModel link
TensorFlow TensorFlowModel link
HuggingFace HuggingFaceModel link
Vowpal Wabbit VowpalWabbitModel link

Contributing

If you'd like to contribute, be sure to check out our contributing guide! If you'd like to work on any outstanding items, check out the roadmap section in the docs and get started 😃

Thanks goes to these phenomenal projects and people for creating a great foundation to build from!