Skip to main content

Reproducible plotting and analysis pipeline for research projects

Project description

FigOps

PyPI Python License CI

From messy analysis folders to traceable, publication-ready figures.

FigOps is a small research-ops toolkit for figure work: it reads a project config, checks the declared data contract, runs analysis and plotting scripts, applies journal/presentation styling, and records enough provenance to make the figure auditable later.

It is intentionally boring in the best way: one config, one command, clear inputs, repeatable outputs.

python -m pip install figops
figops --help
figops-mcp --smoke

If those commands work, the CLI is installed and the MCP surface is alive.


Why FigOps exists

Research figures often start as a few scripts and a folder of exported data. That works until the figure changes, a collaborator asks where a value came from, or a manuscript revision needs the same plot in a different journal style.

FigOps keeps that workflow lightweight while making the important parts explicit:

  • Data is the API — inputs are declared, checked, and traceable.
  • Figures are rebuildable — analysis, plotting, diagrams, and assembly live behind the same project contract.
  • Style is reusable — journal and presentation targets are selected through config instead of one-off plotting edits.
  • Agents can inspect safely — the MCP server exposes read, render, and smoke surfaces for tool-assisted figure workflows.

Current release

Item Status
Package figops==0.17.9 is live on PyPI
Python 3.12+
License Apache-2.0 for public package distribution
Commands figops, figops-mcp
Compatibility aliases graphhub, graphhub-mcp
GitHub Release v0.17.9

Install

For normal use:

python -m pip install figops

For a pinned, reproducible install:

python -m pip install figops==0.17.9

If you need the exact GitHub Release asset:

gh release download v0.17.9 --repo Moonweave-Research/figops --pattern "*.whl" --dir dist-release
python -m pip install dist-release/figops-0.17.9-py3-none-any.whl
figops-mcp --smoke

Quick start

Create a new figure project:

figops --init --project my_figure_project
cd my_figure_project

That creates a scaffold with:

my_figure_project/
├── project_config.yaml
├── raw/
│   └── example_input.csv
└── hub_scripts/
    ├── analyze.R
    ├── plot.py
    └── project_context.py

Run the project:

figops --project . --step all

For a first sanity check, list the available CLI options:

figops --help

What FigOps does

A FigOps run coordinates the work around a research figure:

  1. read project_config.yaml,
  2. resolve declared input files,
  3. validate data contracts and research-ops rules,
  4. run analysis scripts when needed,
  5. render figures, diagrams, or assembled panels,
  6. apply the selected style profile,
  7. write provenance and runtime metadata for auditability.

A minimal config looks like this:

project:
  name: "Example Study"

visual_style:
  target_format: nature
  font_scale: 1.0
  profile: baseline

pipeline:
  analysis:
    - script: "hub_scripts/analyze.R"
      lang: R
      cache: true

figures:
  - id: Fig1
    script: "hub_scripts/plot.py"
    output: "results/figures/Fig1.png"
    cache: true

R is only required when your configured analysis scripts use R. Python plotting and package/MCP smoke checks run from the Python package install.

Everyday commands

# Choose a configured project interactively
figops

# List configured projects
figops --list-projects

# Run the full pipeline for one project
figops --project "ProjectName" --step all

# Re-render figures only
figops --project "ProjectName" --step plot

# Re-render diagrams only
figops --project "ProjectName" --step diagrams

# Force a clean rerun and bypass cache
figops --project "ProjectName" --step all --force

From a source checkout, use the repo-local runtime wrapper:

python hub_uv.py run python orchestrator.py --list-projects
python hub_uv.py run python -m pytest tests/test_runtime_paths.py -q

hub_uv.py keeps the Python runtime outside the repository so the working tree does not get polluted with local virtualenv state.

MCP for agents

FigOps includes a Model Context Protocol server entry point:

figops-mcp --smoke

A healthy smoke response looks like:

{"status": "ok", "health_status": "ok", "tool_surface": "figops_mcp"}

Use this before wiring FigOps into Claude, Codex, or another MCP-capable client. For compatibility with earlier local setups, graphhub-mcp remains available as an alias.

Troubleshooting

Symptom What to try
project_config.yaml not found Run figops --init --project "<project>" or move into a configured project.
Project directory not found Run figops --list-projects and copy the exact configured name.
Strict lockfile errors --strict-lock is for reproducibility checks. For quick local rendering, rerun without strict mode.
Google Drive files feel stuck Let Drive finish syncing, then rerun. The prefetch layer can help with declared inputs, but it cannot repair a broken Drive login/session.
R script fails immediately Confirm Rscript is available if your project config uses lang: R.

For maintainers

Release candidates are checked with the packaging and test gates below:

uv build
python scripts/package_metadata_smoke.py
python scripts/public_package_surface.py
python scripts/consumer_install_smoke.py
uv run --with twine python -m twine check dist/*
python hub_uv.py run python -m pytest -q
python hub_uv.py run ruff check .

After release assets are uploaded, verify both the GitHub artifact and the public install path:

python scripts/github_release_asset_smoke.py
python -m pip install figops==0.17.9
figops-mcp --smoke

Publishing uses the manual Trusted Publishing workflow in .github/workflows/publish.yml: TestPyPI first, install smoke, then PyPI. See docs/packaging/trusted-publishing.md for the exact runbook.

Repository map

Path Purpose
orchestrator.py CLI entry point and top-level pipeline coordinator
hub_core/ Config loading, validation, cache, provenance, process execution, MCP logic
hub_core/mcp/ MCP server, schemas, transport, resources, prompts, and tool handlers
plotting/ Reusable plotting helpers and figure assembly utilities
themes/ Journal and presentation style presets
examples/ Small synthetic projects and package-facing examples
scripts/ Release, packaging, and distribution checks
tests/ Regression and contract tests
docs/packaging/ PyPI readiness, clearance checklist, and Trusted Publishing runbook

Next release checklist

The public package is live. For the next release, keep the same conservative path:

  1. bump the version,
  2. rebuild wheel/sdist from a clean tree,
  3. confirm package artifacts exclude private docs/tests/research markers,
  4. publish to TestPyPI through .github/workflows/publish.yml,
  5. install-check from TestPyPI,
  6. promote the same version to PyPI,
  7. install-check from public PyPI.

License

FigOps is distributed under the Apache-2.0 license. See LICENSE and NOTICE.

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

figops-0.17.9.tar.gz (270.4 kB view details)

Uploaded Source

Built Distribution

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

figops-0.17.9-py3-none-any.whl (304.6 kB view details)

Uploaded Python 3

File details

Details for the file figops-0.17.9.tar.gz.

File metadata

  • Download URL: figops-0.17.9.tar.gz
  • Upload date:
  • Size: 270.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for figops-0.17.9.tar.gz
Algorithm Hash digest
SHA256 aa5f54e9296896bca2a0cc4ce611d9d5ddad9b7e8469833ecbddb0646188269e
MD5 8cc6bc4084d3eeb46022e4025a0aa51e
BLAKE2b-256 e9c671507502b2acaa35da2c45ab6f61fee573d8ecf69cb7b400fa6c00b15349

See more details on using hashes here.

Provenance

The following attestation bundles were made for figops-0.17.9.tar.gz:

Publisher: publish.yml on Moonweave-Research/figops

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file figops-0.17.9-py3-none-any.whl.

File metadata

  • Download URL: figops-0.17.9-py3-none-any.whl
  • Upload date:
  • Size: 304.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for figops-0.17.9-py3-none-any.whl
Algorithm Hash digest
SHA256 a7c4f7804b2836a2e0adec65e865c8ff1a888f15c501e1926bc3c5a241ba7e45
MD5 8526f2b9ace97e13acd93b1f454cad95
BLAKE2b-256 dd00f5d0e063fa753e1f7ffc9f9886764e5d30de0357e67d4e42cbc524e3d3cf

See more details on using hashes here.

Provenance

The following attestation bundles were made for figops-0.17.9-py3-none-any.whl:

Publisher: publish.yml on Moonweave-Research/figops

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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