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-oriented 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 State

Item Status
Source checkout 0.17.11 release metadata (pyproject.toml)
Published package figops==0.17.9 is the latest locally documented PyPI release
TestPyPI dry run figops==0.17.11 was published and install-smoke verified
Python 3.12+
License Apache-2.0 for public package distribution
Commands figops, figops-mcp
Compatibility aliases graphhub, graphhub-mcp
GitHub Release v0.17.10 is the latest locally documented release asset

The source checkout and TestPyPI dry run may be ahead of the public PyPI package and GitHub Release asset. Treat pyproject.toml as the current source version, the GitHub Release asset as the latest locally documented attached artifact, and the pinned PyPI snippets below as the locally documented public-index install path until a release maintainer publishes and verifies a newer PyPI version.

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.10 --repo Moonweave-Research/figops --pattern "*.whl" --dir dist-release
python -m pip install dist-release/figops-0.17.10-py3-none-any.whl
figops-mcp --smoke

Quick start

For an installed package, verify the published CLI surface first:

figops --help
figops-mcp --smoke
figops-mcp doctor

For a source checkout, use hub_uv.py instead of bare uv run so the managed environment stays outside the repository:

python hub_uv.py sync
python hub_uv.py run python figops_mcp_server.py doctor
python hub_uv.py run python -m pytest tests/test_doctor.py -q

If uv is not installed, the source-checkout path cannot bootstrap itself. Use an already prepared Python 3.12+ environment with the FigOps runtime/dev dependencies, or install uv outside the repository and rerun the wrapper commands. R is only required for projects that declare lang: R.

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 sync
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.
Source-checkout tests fail with No module named pytest Run python hub_uv.py sync --group dev, then rerun tests through python hub_uv.py run python -m pytest ....
Doctor reports missing pandas, matplotlib, or yaml Run python hub_uv.py sync from the checkout, or use a Python 3.12+ environment with FigOps runtime dependencies installed.
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

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.11.tar.gz (304.5 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.11-py3-none-any.whl (361.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: figops-0.17.11.tar.gz
  • Upload date:
  • Size: 304.5 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.11.tar.gz
Algorithm Hash digest
SHA256 1472c44a3fa2fc6d41b14b5a5bfca16dfea4b139be71210b8448827c276eeb85
MD5 3fb76c461094383f8f707ff372d464c2
BLAKE2b-256 f1b9a504c6dfb478d9cd545966753b335b5a9716ba187e8d70b7c6f85db9696a

See more details on using hashes here.

Provenance

The following attestation bundles were made for figops-0.17.11.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.11-py3-none-any.whl.

File metadata

  • Download URL: figops-0.17.11-py3-none-any.whl
  • Upload date:
  • Size: 361.8 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.11-py3-none-any.whl
Algorithm Hash digest
SHA256 3c3af00dbaf7204c0eb033216fb17c2cfff0fa9ab067be9523d7a06b368ae260
MD5 226eb68c0003438a46061fa3793b9d94
BLAKE2b-256 b14e1e32a2834dab1acef9ed826cf37ec56745cfbbc5235cbababecc4a70f5bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for figops-0.17.11-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