Skip to main content

an open-source Python package enabling Self-Driving Labs (SDLs) interoperability

Project description

Documentation Status PyPI version Downloads License YouTube YouTube Published Community

IvoryOS logo

IvoryOS: open-source orchestrator for self-driving labs

IvoryOS turns existing Python automation code into interactive controls, drag-and-drop workflows, and optimization-ready experiments.

Build for fast-changing R&D environments, and make Python-based lab automation accessible and scalable.

code_launch_design.png

Join our community!

IvoryOS is an open-source project under active development. We welcome feedback, feature ideas, and contributions from anyone working on or interested in self-driving laboratories.

Join our Discord or Slack to ask questions, share use cases, and help shape IvoryOS.


Table of Contents

Installation

From PyPI:

pip install ivoryos

System Requirements

Platforms: Compatible with Linux, macOS, and Windows (developed/tested on Windows).
Python: Python ≥3.10

Dependency groups
  • Core: Flask, Flask-Login, Flask-Session, Flask-SocketIO, Flask-SQLAlchemy, Flask-WTF, WTForms, SQLAlchemy-Utils, bcrypt, python-dotenv, pandas.
  • Optimizers: optimizer-ax, optimizer-baybe, optimizer-nimo, or optimizers for all supported optimizer adapters.
  • Database: db for PostgreSQL support.
  • LLM design agent: llm for the optional in-app text-to-workflow feature.
  • Development: dev for running the test suite.
Optional feature installs
pip install "ivoryos[optimizers]"       # all optimizer adapters
pip install "ivoryos[optimizer-ax]"     # Ax only
pip install "ivoryos[optimizer-baybe]"  # BayBE only
pip install "ivoryos[optimizer-nimo]"   # NIMO only
pip install "ivoryos[db]"               # PostgreSQL support
pip install "ivoryos[llm]"              # optional text-to-workflow design agent

From a local source checkout:

pip install -e ".[dev]"
pytest
32-bit Windows installation notes

Prefer 64-bit Python when possible. If you must deploy IvoryOS on 32-bit Windows, pip may not find pre-built 32-bit wheels for modern packages such as greenlet, pandas, or newer Flask-Session releases.

# 1. Use a Flask-Session release before the msgspec dependency.
pip install "Flask-Session<0.7"

# 2. Install a pandas wheel compatible with the local 32-bit Python environment.
pip install pandas --user --only-binary=:all:

# 3. Install greenlet from conda-forge if PyPI has no compatible wheel.
conda install -c conda-forge greenlet -y

# 4. Install IvoryOS.
pip install ivoryos

Quick start

In your script, where you initialize or import your robot:

my_robot = Robot()

import ivoryos

ivoryos.run(__name__)

Then run the script and visit http://localhost:8000 in your browser. Use admin for both username and password, and start building workflows!


Features

Direct control:

direct function calling Instruments tab

Workflows

  • Design Editor: drag/add function to canvas in Workflow tab, use #parameter_name for dynamic parameters, click Prepare Run button to go to the execution configuration page
  • Execution Config: configure iteration methods and parameters in Execution tab.
  • Design Library: manage workflow scripts in Library tab.
  • Workflow Data: Execution records are in Data tab.
Logging

Add single or multiple loggers:

ivoryos.run(__name__, logger="logger name")
ivoryos.run(__name__, logger=["logger 1", "logger 2"])
Human-in-the-loop

Use pause in flow control to pause the workflow and send a notification with custom message handler(s). When run into pause, it will pause, send a message, and wait for human's response. Example of a Slack bot:

def slack_bot(msg: str = "Hi"):
    """
    a function that can be used as a notification handler function("msg")
    :param msg: message to send
    """
    from slack_sdk import WebClient

    slack_token = "your slack token"
    client = WebClient(token=slack_token)

    my_user_id = "your user id"  # replace with your actual Slack user ID

    client.chat_postMessage(channel=my_user_id, text=msg)

import ivoryos
ivoryos.run(__name__, notification_handler=slack_bot)

Use Input in flow control to get human input during workflow execution. Example:

click to see the data folder structure
  • ivoryos_data/:
    • config_csv/: Batch configuration csv
    • pseudo_deck/: Offline deck .pkl
    • results/: Execution results
    • scripts/: Compiled workflows Python scripts
    • default.log: Application logs
    • ivoryos.db: Local database

Demo

Online demo at demo.ivoryos.ai. Local version in abstract_sdl.py


Roadmap

Check out our Work Items for upcoming features and improvements.

  • Support dataclass input
  • Introspection version control
  • Check config file compatibility

Contributing

We welcome all contributions — from core improvements to new drivers, plugins, and real-world use cases. See CONTRIBUTING.md for details.


Citing

Click to see citations

If you find this project useful, please consider citing the following manuscript:

Zhang, W., Hao, L., Lai, V. et al. IvoryOS: an interoperable web interface for orchestrating Python-based self-driving laboratories. Nat Commun 16, 5182 (2025).

@article{zhang_et_al_2025,
  author       = {Wenyu Zhang and Lucy Hao and Veronica Lai and Ryan Corkery and Jacob Jessiman and Jiayu Zhang and Junliang Liu and Yusuke Sato and Maria Politi and Matthew E. Reish and Rebekah Greenwood and Noah Depner and Jiyoon Min and Rama El-khawaldeh and Paloma Prieto and Ekaterina Trushina and Jason E. Hein},
  title        = {{IvoryOS}: an interoperable web interface for orchestrating {Python-based} self-driving laboratories},
  journal      = {Nature Communications},
  year         = {2025},
  volume       = {16},
  number       = {1},
  pages        = {5182},
  doi          = {10.1038/s41467-025-60514-w},
  url          = {https://doi.org/10.1038/s41467-025-60514-w}
}

For an additional perspective related to the development of the tool, please see:

Zhang, W., Hein, J. Behind IvoryOS: Empowering Scientists to Harness Self-Driving Labs for Accelerated Discovery. Springer Nature Research Communities (2025).

@misc{zhang_hein_2025,
  author       = {Wenyu Zhang and Jason Hein},
  title        = {Behind {IvoryOS}: Empowering Scientists to Harness Self-Driving Labs for Accelerated Discovery},
  howpublished = {Springer Nature Research Communities},
  year         = {2025},
  month        = {Jun},
  day          = {18},
  url          = {https://communities.springernature.com/posts/behind-ivoryos-empowering-scientists-to-harness-self-driving-labs-for-accelerated-discovery}
}

Acknowledgements

Authors acknowledge Telescope Innovations Corp., UBC Hein Lab, and Acceleration Consortium members for their valuable suggestions and contributions.

Project details


Release history Release notifications | RSS feed

This version

1.6.4

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ivoryos-1.6.4.tar.gz (461.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ivoryos-1.6.4-py3-none-any.whl (506.7 kB view details)

Uploaded Python 3

File details

Details for the file ivoryos-1.6.4.tar.gz.

File metadata

  • Download URL: ivoryos-1.6.4.tar.gz
  • Upload date:
  • Size: 461.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for ivoryos-1.6.4.tar.gz
Algorithm Hash digest
SHA256 3582f18b8d9e7aff590cb514dd03b0cc89163b1a2e56520458cdd6b948d52129
MD5 423152f8bb25599c62a6efea0f229271
BLAKE2b-256 bbb4afa52da7d9a58941e3ceda1195285217cddf66e9a82eb7957ee2d7741f2d

See more details on using hashes here.

File details

Details for the file ivoryos-1.6.4-py3-none-any.whl.

File metadata

  • Download URL: ivoryos-1.6.4-py3-none-any.whl
  • Upload date:
  • Size: 506.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for ivoryos-1.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b1f982b5e1b1205086a70915133fe4f31b5154d55f4b5147b16a9c8467a5c457
MD5 72a007b29f0b66934190f292f75c54f1
BLAKE2b-256 13000b641291142579f41e7039a88bd650d2dcc6d473753e91902c23a68a5a0c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page