Skip to main content

🧬 Flexible framework for organizing data/experiments/workflows

Project description

🧬 Formed

CI Docs Python version License PyPI version

Formed is a flexible framework for managing data, experiments, and workflows in both research and production environments. It provides a simple yet powerful DAG-based workflow system with automatic caching, dependency tracking, and seamless integration with popular ML tools.

Key Features

  • 📊 DAG-based workflows: Define complex workflows as directed acyclic graphs with automatic dependency resolution
  • 💾 Smart caching: Content-based automatic caching that detects code changes via AST analysis
  • 🔧 Flexible configuration: Use Jsonnet/JSON for declarative workflow definitions with type safety
  • 🔌 Rich integrations: Built-in support for PyTorch, 🤗 Transformers, MLflow, and more
  • 🎯 Type-safe: Leverage Python type hints for automatic object construction and validation
  • 📦 Extensible: Easy to extend with custom steps, formats, and organizers

Quick Example

Define reusable computation steps with automatic caching:

# mysteps.py
from collections.abc import Iterator
from formed import workflow

@workflow.step
def load_dataset(size: int) -> Iterator[int]:
    for i in range(size):
        yield i

@workflow.step
def square(dataset: Iterator[int]) -> Iterator[int]:
    for i in dataset:
        yield i * i

Connect steps in a workflow configuration:

// workflow.jsonnet
{
  steps: {
    dataset: {
      type: 'load_dataset',
      size: 10
    },
    results: {
      type: 'square',
      dataset: { type: 'ref', ref: 'dataset' }
    }
  }
}

Configure and run:

# formed.yml
workflow:
  organizer:
    type: filesystem

required_modules:
  - mysteps
formed workflow run workflow.jsonnet --execution-id my-experiment

Results are automatically cached - rerunning only executes changed steps!

Installation

pip install formed

With integrations:

pip install formed[mlflow]         # MLflow integration
pip install formed[torch]          # PyTorch integration
pip install formed[transformers]   # 🤗 Transformers integration
pip install formed[all]            # All integrations

Documentation

📖 Full documentation available here

Why Formed?

Formed bridges the gap between experimental notebooks and production pipelines:

  • Reproducible: Content-based caching ensures consistent results
  • Iterative: Only re-execute what changed, speeding up development
  • Collaborative: Declarative configs make workflows easy to share and review
  • Production-ready: Same code works in research and deployment

Whether you're prototyping in Jupyter or deploying at scale, formed adapts to your workflow.

License

MIT License - see LICENSE file for details.

Project details


Download files

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

Source Distribution

formed-0.0.5.tar.gz (164.8 kB view details)

Uploaded Source

Built Distribution

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

formed-0.0.5-py3-none-any.whl (216.3 kB view details)

Uploaded Python 3

File details

Details for the file formed-0.0.5.tar.gz.

File metadata

  • Download URL: formed-0.0.5.tar.gz
  • Upload date:
  • Size: 164.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.25 {"installer":{"name":"uv","version":"0.9.25","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for formed-0.0.5.tar.gz
Algorithm Hash digest
SHA256 92fc93f6ab797815ea051220cc75bd9fa6638e4c2c395a1a6b3d30c7d88f524e
MD5 6de536829612417e36785a9244e58734
BLAKE2b-256 15226ea176714dba2773d45e2908092cbcdec722966b538d4ce5449d24381cda

See more details on using hashes here.

File details

Details for the file formed-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: formed-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 216.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.25 {"installer":{"name":"uv","version":"0.9.25","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for formed-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8b275201c2dfe6e1fd255ac6b0cf73aced2675971af6bf4281242321a21b9873
MD5 bb097e534a7aa44c93d1939fa689b456
BLAKE2b-256 9bfc8a1f01cf30600ab04be0cc9f4c50b740d391098ed2e6d41ca6a9a8a637cc

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