Help us improve
Share bugs, ideas, or general feedback.
From tufte-vdqi
Scores a data graphic against Tufte's nine criteria, computes lie factor, identifies chartjunk species, and returns prioritized fixes with specific remedies and exemplars.
npx claudepluginhub gnurio/tufte-vdqi-plugin --plugin tufte-vdqiHow this skill is triggered — by the user, by Claude, or both
Slash command
/tufte-vdqi:assess-graphical-excellenceThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
This is the assessment hub of the Tufte toolkit. Its job is to score an existing
Routes data-visualization requests to the right Tufte skill: assess a graphic, produce a new chart, or fix a cluttered one. Invoke when unsure which Tufte skill to use.
Creates and critiques data visualizations using Edward Tufte's principles: high data-ink ratio, direct labels, range frames, and small multiples. Covers Recharts, Plotly, matplotlib, Chart.js, ECharts, D3, SVG, and HTML.
Designs clear, accessible data visualizations with chart selection for comparisons/trends/distributions, styling principles, color palettes, responsiveness, and best practices.
Share bugs, ideas, or general feedback.
This is the assessment hub of the Tufte toolkit. Its job is to score an existing graphic, name what's wrong using Tufte's vocabulary (the duck, the dreaded grid, moiré vibration, dimensionality violation, etc.), and hand back the exact remedy plus the genre to switch to and an exemplar to emulate.
The output is concrete and source-grounded because the model reasons over a
single principles file (references/tufte-principles.md) that quotes VDQI by
page. Generic "improve data-ink ratio" advice is the failure mode this skill is
designed to avoid.
A description (or image, or file) of the graphic, and ideally its purpose and audience. If something essential is missing, infer reasonably and state the assumption rather than stalling.
Read references/tufte-principles.md first. The workflow uses every part of it.
Score the nine criteria (Part A). 0–10 each, with a chart-specific observation. Use VDQI's numeric anchors: e.g. data-ink ratio "0.1–0.2 is typical, edit toward 1.0" (p.136); data density 0.15 numbers/in² is "overwrought" (p.162). Unsupported scores are the main failure mode.
Compute the lie factor when proportionality looks suspicious (Part B,
B1). Formula: (visual change %) / (data change %). Acceptable 0.95–1.05.
Report the number and compare to VDQI's catalogue (Part E) — anchor the
verdict in a named case: "this is essentially the 1979 TIME barrel
(lie factor 59.4)" or "in the league of the LA Times shrinking-doctor
(lie factor 2.8)" rather than a free-floating number.
Identify chartjunk species present (Part D). Walk the four named offenses and name each one the chart exhibits, citing Tufte's named offender when the resemblance is close:
Rank candidate genres and challenge the default (Part C, Part G). List at least three Tufte genres that could fit the data, ranked by fit. Then apply the default-challenge rule:
If your top-ranked genre is also what an unprompted Claude would pick (line, bar, dot plot, scatter, pie), you MUST do one of: (a) explicitly justify it by citing what the alternatives lose, OR (b) reach for a second-line VDQI move (supertable, table-graphic, sparkline, dot-dash plot, quartile plot, small multiples) and explain why it is the stronger fit here.
Quiet defaulting to the obvious chart is the failure mode this rule exists to catch.
Common multi-answer data shapes (flag these in the output so render knows to emit alternatives):
Compute the weighted overall score. Weights: integrity 3×, proportionality 2×, data-ink 2×, typography 0.5×, the rest 1×.
Translate scores into ranked fixes. Each fix gets up to four tags:
If the graphic plots a multi-year currency series, check B7. Use
scripts/deflate.py (requires real CPI values; refuses to guess).
## Assessment: <graphic>
Context: <purpose / audience, or stated assumption>
### Scores
<one line per criterion: name — score/10 — chart-specific observation>
### Chartjunk species present
<list any of: moiré, dreaded grid, duck, decoration — each with the detected signature, and Tufte's named offender it most resembles>
### Distortion check
Lie factor: <value or "n/a"> — <interpretation>
Resembles: <named VDQI case from Part E, or "no close analogue">
### Genres considered (ranked)
1. <Part-C genre> — <why it fits this data>
2. <Part-C genre> — <why>
3. <Part-C genre> — <why>
Chosen: <genre>. Default-challenge: <if the chosen genre is what unprompted Claude would also pick, justify here by citing what the alternatives lose; otherwise note "second-line VDQI move — stronger fit than the default chart">.
Multi-render trigger: <one of the data shapes from step 4, e.g. "≤20 numbers ⇒ supertable + chart" — or "none, single canonical render">
### Overall: <weighted score>/10 — <one-sentence verdict>
### Fixes (highest impact first)
1. [B?, C?, resembles E?, emulate F?] — <concrete change>
2. ...
All nine criteria scored with chart-specific evidence; chartjunk species named where present; distortion quantified and anchored in a VDQI case; the genre question explicitly considered; recommendations ordered by impact, each tied to a remedy AND (when applicable) a genre switch / a famous case to avoid / a famous case to emulate. The reader should leave with a concrete picture of what to build next, not a list of vague improvements.
render-tufte-chart — rebuild the graphic so it satisfies these criteria,
using the per-genre scripts named in your fixes.orchestrate-tufte-vdqi — routes here for evaluation, then to render for the
fix.