7 releases
| 0.1.6 | Apr 1, 2026 |
|---|---|
| 0.1.5 | Apr 1, 2026 |
| 0.1.4 | Mar 12, 2026 |
| 0.1.0 | Feb 28, 2026 |
#52 in Biology
2,062 downloads per month
Used in 2 crates
6MB
20K
SLoC
kuva
A scientific plotting library in Rust. 30 plot types, SVG output, optional PNG/PDF backends, and a CLI binary that renders plots directly from the shell — including in the terminal itself.

Quick start
Install the CLI
Step 1 — install Rust (skip if you already have cargo):
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
# then restart your shell, or run:
source ~/.cargo/env
Step 2 — install kuva:
# From crates.io — installs to ~/.cargo/bin/ (on your $PATH after rustup setup)
cargo install kuva --features cli
# From a local clone — SVG output only
cargo install --path . --features cli
# From a local clone — with PNG and PDF output
cargo install --path . --features cli,full
After installation, kuva is available anywhere in your shell — no need to reference ./target/release/kuva or set any paths manually.
Use as a library
Add to Cargo.toml:
[dependencies]
kuva = "0.1"
# Optional backends
kuva = { version = "0.1", features = ["png"] } # PNG output
kuva = { version = "0.1", features = ["pdf"] } # PDF output
kuva = { version = "0.1", features = ["full"] } # PNG + PDF
Then in Rust:
use kuva::prelude::*;
let plot = ScatterPlot::new()
.with_data(vec![(1.0_f64, 2.0), (3.0, 5.0), (5.0, 4.0)])
.with_color("steelblue")
.with_legend("samples");
let plots: Vec<Plot> = vec![plot.into()];
let layout = Layout::auto_from_plots(&plots)
.with_title("My Plot")
.with_x_label("X")
.with_y_label("Y");
let svg = render_to_svg(plots, layout);
std::fs::write("my_plot.svg", svg).unwrap();
Use the CLI
# Scatter plot to SVG
kuva scatter data.tsv --x x --y y -o plot.svg
# Volcano plot, label top 20 genes
kuva volcano gene_stats.tsv --name-col gene --x-col log2fc --y-col pvalue --top-n 20
# Ridgeline plot — stacked density curves, one per group
kuva ridgeline samples.tsv --group-by group --value expression --overlap 0.6
# Box plot rendered directly in the terminal
kuva box samples.tsv --group-col group --value-col expression --terminal
Input is auto-detected TSV or CSV. Columns are selectable by name or 0-based index. Pipe from stdin by omitting the file argument. Output defaults to SVG on stdout; use -o file.svg/png/pdf to write a file.
Documentation
Full documentation — plot type reference, API guide, CLI flag reference, themes, palettes, and benchmarks — is at psy-fer.github.io/kuva.
Contributors
Thank you to everyone who has contributed to kuva!
Development note
kuva was initially built by hand, with a working library and several plot types already in place before AI tooling was introduced. From that point, development was heavily assisted by Claude (Anthropic) — accelerating the addition of new plot types, the CLI binary, tests, and documentation. The architecture, domain knowledge, and direction remain the author's own; Claude was used as an accelerant, not an author.
This disclaimer was written by Claude as an honest assessment of its own role in the project.
License
MIT
Dependencies
~1–4MB
~67K SLoC