by VILA-Lab
An Automated AI Agent Tool for Plotting Your Data in Any Paper's Figure Style.
# Add to your Claude Code skills
git clone https://github.com/VILA-Lab/FigMirrorNo comments yet. Be the first to share your thoughts!
FigMirror uses a reference figure as the style target, then renders your data through an iterative Drawer / Reviewer loop until the output looks like it belongs in the same paper family.
Already inside Claude Code or Codex? Paste this and let the agent do the setup:
Install FigMirror for me: https://github.com/VILA-Lab/FigMirror
Use this when you want upload, preview, iteration history, and refinement in a browser.
If uv is missing: python3 -m pip install uv.
git clone https://github.com/VILA-Lab/FigMirror.git && cd FigMirror
bash scripts/install.sh
uv run python scripts/figcopy_serve.py --workspace .artifacts/figmirror-workspace --backend codex
Open http://127.0.0.1:8765/.
Use this when you want FigMirror inside your agent, no web UI.
curl -fsSL https://raw.githubusercontent.com/VILA-Lab/FigMirror/main/scripts/install.sh | bash
Then attach a paper-figure screenshot, paste your data, and ask:
Use FigMirror to mirror this figure's style with my data.
Need manual target selection, Claude backend, or troubleshooting? See Detailed Install.
Illustration of FigMirror. The left panel shows the core agentic loop; the right panel introduces Grounded Measurement.
FigMirror uses an agentic Drawer-Reviewer loop. The Drawer renders a candidate figure with Grounded Measurement. The Reviewer compares it with the reference image, then returns a visual review, a revision checklist, and a preserve list. The preserve list accumulates across iterations as an anchor against style drift. The Aesthetic Lib provides fallback principles, style rules, and figure properties when the agents disagree or the Drawer has low confidence.
For 3D figures, FigMirror adds geometry-aware prompting for camera, scale, surfaces, lighting, and repair checks, helping the loop preserve the 3D composition of the reference figure while producing editable matplotlib code.
Grounded Measurement builds on two properties of computer-use-trained foundation models: Measurement with Axis, which lets the model return x/y coordinates for visual targets; and Resonate with Code, which turns those coordinates into executable checks, such as cropping a line segment and reading its color from pixels.
For the detailed algorithm, architecture, product envelope, and spec map, read docs/method.md. For the web UI, see scripts/README_figcopy_serve.md.
FigMirror welcomes contributions!
Open an issue for bugs, broken installs, or figure cases FigMirror should learn from; open a PR for showcase examples, prompt improvements, UI polish, or small regression tests.
Start with docs/contributing.md. Good first PRs include adding a showcase example, improving a web UI interaction, tightening install docs, or adding a small regression test around runner behavior.