parti 0.1.0

Clustering and hierarchical structure primitives
Documentation

parti

Partition, reconcile, predict. Clustering, community detection, and hierarchical conformal prediction in Rust.

Problem

Given a set of points or a graph, you want to find groups: k-means for embeddings, Leiden for networks, hierarchical clustering for dendrograms. When predictions have hierarchical structure (e.g., forecasts at country/region/city levels), they should be coherent -- the parts should sum to the whole. Conformal prediction can provide calibrated intervals that respect this structure.

This library provides the algorithms. It is domain-agnostic; the stable contract is in CONTRACT.md.

Examples

Embeddings to communities. Build a kNN graph from 2D points and detect clusters via Leiden:

cargo run --example embedding_clustering --features knn-graph

Hierarchical conformal prediction. Given a tree of predictions, reconcile them so they are structurally coherent, then produce calibrated prediction intervals:

cargo run --example hierarchical_conformal

Used by flowmatch (behind --features parti-evals) to evaluate whether generated samples preserve the cluster structure of real data -- for example, whether generated earthquake locations form the same geographic clusters as the USGS catalog.

What it provides

  • Clustering: k-means, DBSCAN, hierarchical clustering.
  • Community detection: kNN graph construction (feature-gated), Leiden/Louvain/label propagation.
  • Hierarchy + conformal: hierarchical reconciliation, split conformal prediction with coherence guarantees.
  • Metrics: clustering evaluation helpers (used by flowmatch parti-eval examples).

Usage

[dependencies]
parti = "0.1.0"
use parti::{HierarchicalConformal, HierarchyTree, ReconciliationMethod};

// Build hierarchy, get summing matrix
let h_tree = HierarchyTree::from_raptor(&tree);
let s = h_tree.summing_matrix();

// Calibrate on held-out data
let mut cp = HierarchicalConformal::new(s, ReconciliationMethod::Ols);
cp.calibrate(&y_calib, &y_hat_calib, 0.1)?; // 90% coverage

// Coherent prediction intervals
let (lower, upper) = cp.predict_intervals(&y_hat_test)?;

References

  • Principato et al. (2024). "Conformal Prediction for Hierarchical Data."
  • Qiu & Li (2015). "IT-Dendrogram: A new representation for hierarchical clustering."
  • Sarthi et al. (2024). "RAPTOR: Recursive Abstractive Processing for Tree-Organized Retrieval."

License

MIT OR Apache-2.0