Skip to main content

Convert raster images into clean, editable SVG.

Project description

svgsmith

Agent-native, self-verifying raster→SVG vectorizer.

svgsmith turns PNG/JPG images into editable SVG. It is built to be driven by an AI agent without a human in the loop: it picks the right tracing engine for the input, post-processes the result into clean editable layers, and verifies its own output by re-rasterizing the SVG and comparing it to the original — re-tuning until a quality threshold is met. Every run returns a structured JSON report so a calling agent can decide whether to accept, retry, or escalate.

It does not reinvent tracing. It wraps proven engines (VTracer for color, Potrace for line art) and adds the layer that is missing for agent use: routing, editable output, and a self-verification loop.

Status: MVP complete — engine routing, editable post-processing, the self-verify loop, the CLI/JSON report, and the vectorize skill are all in. See the EPIC for scope.

System dependencies

The line-art engine shells out to the Potrace binary (svgsmith does not bundle a Potrace Python binding). Install it from your package manager before use:

The self-verify loop rasterizes SVGs with CairoSVG, which needs the Cairo system library. Install both:

# Debian / Ubuntu
sudo apt-get install -y potrace libcairo2 libcairo2-dev
# macOS (Homebrew)
brew install potrace cairo

The color engine (VTracer) ships as a pinned PyPI wheel and needs no system package.

Installation

Requires Python 3.11+. Install the system dependencies above first, then svgsmith:

pip install svgsmith

From source

git clone https://github.com/realproject7/svgsmith
cd svgsmith
pip install .          # add ".[dev]" for the test/lint extras

Verify the install:

svgsmith --version
svgsmith convert path/to/image.png --out out.svg --report json

What makes it different

  • Auto-routing — classifies the input (logo/icon vs illustration vs pixel art) and selects the engine + preset automatically. No tracer-flag expertise required.
  • Editable output — instead of one monolithic <path>, output is grouped into <g> layers with simplified paths and a consolidated color palette.
  • Self-verifying — converts, re-rasterizes, diffs against the original (SSIM), and re-tunes parameters until it converges on a quality target.
  • Structured report — emits JSON (mode, engine, iterations, similarity score, warnings) so agents can branch programmatically.
  • Local & private — runs fully offline; images never leave the machine.

Gallery

Each pair is the original raster (left) and the svgsmith SVG output (right), rendered at the same size. Fixtures are self-generated (see tests/corpus/).

Original svgsmith SVG
Logo (--mode binary)
Icon (--mode binary)
Illustration (--mode color)
Pixel art (--mode pixel)

Usage

svgsmith convert input.png \
  --mode auto \         # auto | binary | color | pixel
  --quality 0.9 \       # target similarity (0–1), drives the verify loop
  --max-iters 4 \
  --editable \          # editable layered output (default on; --no-editable for raw)
  --out output.svg \
  --report json

Flags

Flag Default Meaning
--mode {auto,binary,color,pixel} auto auto classifies the image and routes it: binary→Potrace (logos/line art), color→VTracer (illustrations), pixel→VTracer pixel preset.
--quality FLOAT 0.9 Target fidelity in [0,1] (SSIM vs the original). Drives the verify loop.
--max-iters INT 4 Max verify/refine iterations before returning the best result so far.
--editable / --no-editable on Editable grouped/simplified SVG, or the raw traced output.
--smooth / --no-smooth on Curve-refit color contours into smooth, sparse Béziers (Schneider least-squares).
--detail {high,normal,clean,poster} normal Color detail dial. high = maximum detail; clean = edge-preserving cleanup (less noise/grain); poster = bold flat graphic with few colors.
--solid-background off Isolate the subject and repaint the background as one clean solid color — removes texture/grain/specks while keeping subject detail.
--uniform-outline off Force an even-width outline band (outlined illustrations only; would add a wrong border on line art).
--out PATH <input>.svg Output SVG path.
--report {off,json} off Print a JSON report to stdout (the only thing on stdout).

Composable for agents. svgsmith is meant to be driven by an AI agent that maps a user's intent to flags. "Detailed character on a clean flat background"--detail high --solid-background; "poster-style, minimal"--detail poster; "crisp logo"--mode binary; "keep the raw look"--no-smooth. The vectorize skill encodes this mapping.

Rasterize (SVG → PNG)

The inverse command renders an SVG back to a PNG (preview, thumbnail, round-trip):

svgsmith rasterize input.svg --out out.png        # intrinsic (viewBox) size
svgsmith rasterize input.svg --width 512           # fixed width
svgsmith rasterize input.svg --scale 2 --background white

Output

The SVG is responsive and scalable: it carries a viewBox and no fixed pixel dimensions (style="width:100%;height:100%", preserveAspectRatio="xMidYMid meet"), so it fits any container or browser window with its aspect ratio preserved — no overflow or scrollbars.

Exit codes

Code Meaning
0 Success — similarity >= --quality.
2 SVG was produced but stayed below the quality target (still written to --out).
1 Hard error (e.g. unreadable input, missing potrace binary).

JSON report

{
  "output": "output.svg",
  "mode_used": "color",
  "engine": "vtracer",
  "preset": "illustration",
  "iterations": 2,
  "similarity": 0.93,
  "passed_threshold": true,
  "svg": { "paths": 84, "groups": 6, "colors": 12, "bytes": 14820 },
  "warnings": []
}
Field Meaning
mode_used / engine / preset What the router actually chose.
iterations How many verify/refine passes ran.
similarity Best SSIM achieved vs the original.
passed_threshold similarity >= --quality.
svg Output stats: path count, <g> groups, distinct colors, byte size.
warnings Human-readable caveats (e.g. photographic gradients that vectorize poorly).

How the self-verify loop works

svgsmith doesn't trust a single trace. After producing an SVG it:

  1. re-rasterizes the SVG back to a bitmap (via cairosvg) at the original resolution,
  2. scores it against the source with SSIM — that score is similarity,
  3. if it's below --quality, re-tunes the trace/post-process parameters and retries, up to --max-iters, and
  4. returns the best-scoring result with the score in the report.

That closed loop is what lets an agent run svgsmith unsupervised: it gets a converged result and a confidence number, not a guess. For an end-to-end agent wrapper, see the vectorize skill.

License

MIT — see LICENSE.

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

svgsmith-0.1.0.tar.gz (47.0 kB view details)

Uploaded Source

Built Distribution

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

svgsmith-0.1.0-py3-none-any.whl (40.1 kB view details)

Uploaded Python 3

File details

Details for the file svgsmith-0.1.0.tar.gz.

File metadata

  • Download URL: svgsmith-0.1.0.tar.gz
  • Upload date:
  • Size: 47.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for svgsmith-0.1.0.tar.gz
Algorithm Hash digest
SHA256 25025c24ee24ecaef6faafeaba6f047694738ddce43283d633f45e7f748c98b0
MD5 f8095c1f353718abacef943b437ee71d
BLAKE2b-256 bdc8725b1bc7a805f64d805e6d978ffd938bace697c88fe4bc781e2f60608fcb

See more details on using hashes here.

File details

Details for the file svgsmith-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: svgsmith-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 40.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for svgsmith-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8140207173c1d7fe8e2c97eedcd6cb5d63fdc23e955a2b23aa3cc9ae496b072b
MD5 8bba854c8d7c1aceb4f16d2739baba95
BLAKE2b-256 da69d91b83a286fa99a9825720f94446f3f485ff0bd8ad0b0229980162640e7a

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