Skip to main content

Visualize high-entropy values (keys, signatures, UUIDs, addresses) as SVG diagrams a human can compare at a glance.

Project description

entviz

CI Deploy Docs Release PyPI Python versions

Entviz is a tool for visualizing high-entropy values (like cryptographic keys, UUIDs, or blockchain addresses) into a grid of colored shapes and text, making it easy for humans to compare them. This is its reference implementation in python. There are also implementations in javascript/react and rust.

![An entviz rendering of this repository's root commit hash](assets/root-commit-entviz.svg){ width="320" }
This repository itself, rendered as an entviz of its own root commit hash.

Install

pip install entviz      # or: uv add entviz

Render any value to an SVG on stdout:

entviz "550e8400-e29b-41d4-a716-446655440000" --ar 1:1 > id.svg

The library has one runtime dependency (lxml) and emits SVG only — no rasterizer required.

Comparing two entvizes

Note: This is interim guidance. A dedicated comparison UI (a React component that aligns two entvizes and highlights differences) is planned; until then, follow the manual procedure below.

entviz is built for comparison, not memorization. To check whether two values are the same:

  • Render both the same way. Same point size, same font, same background, shown side by side at the same scale. Differences in scale, zoom, font, or surrounding color can hide or fake a difference.
  • Reject on any visible difference. The check is asymmetric: any visible difference in text, color bar, surround pattern, blank positions, ellipse, or quartile marks means the values are different. A match is never proof of identity — it only means no difference was found at the resolution you looked.
  • Compare every channel, not just one. A habituated reader who checks only one landmark (e.g. the color bar) is the easiest to fool. Scan the text, the color bar (each band carries a letter w/g/r/b/k), the surround rings, the blank-cell positions, and the overlays.

The fingerprint of marker

For inputs longer than 512 bits, the text channel can't show every character, so the entviz is labeled fingerprint of <type>(<length>): in bold dark red. On these entvizes:

  • The first 8 and last 8 text cells are real characters from the start and end of your value (use these to recognize and spot-check it).
  • The 4 middle cells (neutral background, framed) are a hash readout in hex — they are not characters from your value. Two different long inputs can therefore share many visible cells and still be different; trust the full picture, and remember that the whole input is bound into every color/shape channel through the fingerprint.

Developer Quickstart

Prerequisites

  • uv (manages the Python interpreter, virtualenv, and dependencies). uv will fetch a suitable Python (>=3.10) for you.

Installation

  1. Clone the repository:

    git clone https://github.com/dhh1128/entviz.git
    cd entviz
    
  2. Create the environment from the lockfile:

    uv sync
    

Running Tests

uv run pytest

To prove the supported Python floor locally (CI runs the full 3.10/3.11/3.12 matrix):

uv run --python 3.10 pytest

Running the CLI

entviz is installed as a console entry point:

uv run entviz "your-entropy-string" --ar 1:1 --fs 12

Regenerating the gallery

uv run python scripts/gallery.py

Regenerating the social preview card

The GitHub "social preview" image (the Open Graph card that unfurls when the repo URL is shared on Slack, X, LinkedIn, etc.) is a reproducible asset. The card embeds an entviz of this repo's own root commit SHA — the tool applied to itself — which is the same entviz shown at the top of the docs.

uv run python scripts/social_card.py

This (re)writes three files into docs/assets/, alongside the other docs images:

  • root-commit-entviz.svg — the entviz of the root commit hash (also embedded at the top of docs/index.md);
  • social-card.svg — the composed 1280×640 card (vector source of truth);
  • social-card.png — the PNG you upload (under 1 MB).

The PNG is rendered with cairosvg (a dev dependency) using the DejaVu font fallback baked into the font stack, so it reproduces without bundling fonts.

Uploading it (one-time, manual): GitHub → repo SettingsGeneralSocial previewEdit → upload docs/assets/social-card.png.

Reusing the template across repos: the palette, layout, and typography are shared family constants; only the KNOBS block at the top of scripts/social_card.py (repo name, owner, tagline, language, and the MARK) changes per repo. See the module docstring for details.

Cutting a release

python3 scripts/release.py --patch -m "what changed"

The script is self-guarding: it switches to main, fast-forwards to origin/main, refuses a dirty tree or unpushed local commits, runs the full test suite, regenerates the gallery, then bumps the version, commits, and pushes a vX.Y.Z tag. It is pure-stdlib, so it works from any directory (it operates on the repo root regardless of cwd) — python3 /path/to/entviz/scripts/release.py … is equivalent. (uv must be on PATH, since the script shells out to uv run for the tests and gallery.)

The pushed tag triggers .github/workflows/release.yml, which re-runs the tests on the tagged commit, publishes the sdist + wheel to PyPI via Trusted Publishing (OIDC — no API token), and creates a GitHub Release with the same artifacts attached.

See scripts/release.py for bump options (--minor, --major, --set X.Y.Z, --no-bump) and the versioning convention.

Project Structure

  • src/entviz/: Core library.
    • entropy.py: Entropy parsing and normalization.
    • layout.py: Grid layout calculations.
    • colors.py: Color selection and conversion.
    • shapes.py: Edge shape definitions.
    • pipeline.py: End-to-end render pipeline.
    • app.py: CLI entry point (entviz).
    • __init__.py: SPEC_VERSION (algorithm/spec) and __version__ (library) — the single source of truth for both.
  • scripts/: Maintenance tooling (gallery.py, release.py).
  • tests/: Unit tests.
  • docs/: Specification, gallery, and assets.

Documentation

For the full specification of the Entviz algorithm and design goals, see docs/spec.md.

Methodology & AI Collaboration

This repository follows a specific methodology for high-quality software development, especially when collaborating with AI:

  • AI Behavioral Rules: See AGENTS.md for mandatory rules on comprehension, TDD, and intent tracking.
  • Intent Layer: We track design decisions and goals in this.i.
  • TDD: Strict Test-Driven Development is required for all changes.

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

entviz-0.11.0.tar.gz (65.8 kB view details)

Uploaded Source

Built Distribution

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

entviz-0.11.0-py3-none-any.whl (68.7 kB view details)

Uploaded Python 3

File details

Details for the file entviz-0.11.0.tar.gz.

File metadata

  • Download URL: entviz-0.11.0.tar.gz
  • Upload date:
  • Size: 65.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for entviz-0.11.0.tar.gz
Algorithm Hash digest
SHA256 0761a52915ff157222d64cc02dfbafdb708c7abd41a9c5db9d7dd0c86c9b5628
MD5 2a77c74ffc8390bf149f5ff5d9bb1075
BLAKE2b-256 cef9dcce8dde0de8ef4588b559160a4838899a8be73686d8b591fa5e6f1e2060

See more details on using hashes here.

Provenance

The following attestation bundles were made for entviz-0.11.0.tar.gz:

Publisher: release.yml on dhh1128/entviz

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

File details

Details for the file entviz-0.11.0-py3-none-any.whl.

File metadata

  • Download URL: entviz-0.11.0-py3-none-any.whl
  • Upload date:
  • Size: 68.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for entviz-0.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c6aed3254b58d90b94d90a5e6b40a97d54db16e9d5d67b94e7e3b6ac000152e3
MD5 065e26b465ffa2e8bfc7accdb3fccccf
BLAKE2b-256 2163e57ca6596a953f21cea49a40ef4eaaeacc83bff1f643a9358bff72ce8399

See more details on using hashes here.

Provenance

The following attestation bundles were made for entviz-0.11.0-py3-none-any.whl:

Publisher: release.yml on dhh1128/entviz

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