#cubic-spline #spline-interpolation #spline #curve #cubic #graphics #inversion

no-std uniform-cubic-splines

Simple uniform cubic spline evaluation and inversion

10 releases

0.1.10 Sep 15, 2024
0.1.8 Oct 15, 2023
0.1.7 Mar 19, 2023
0.1.5 Nov 30, 2021
0.1.3 Nov 14, 2020

#203 in Math

Download history 36/week @ 2024-09-18 54/week @ 2024-09-25 20/week @ 2024-10-02 5/week @ 2024-10-09 8/week @ 2024-10-16 8/week @ 2024-10-23 14/week @ 2024-10-30 14/week @ 2024-11-06 2/week @ 2024-11-13 7/week @ 2024-11-20 11/week @ 2024-11-27 45/week @ 2024-12-04 62/week @ 2024-12-11 16/week @ 2024-12-18 8/week @ 2025-01-01

96 downloads per month
Used in 2 crates (via sl-map-apis)

MIT OR Apache-2.0 OR Zlib

26KB
316 lines

uniform-cubic-splines

Uniform cubic spline interpolation & inversion.

Documentation Crate

This crate supports the following types of splines:

Curve widget with 1D Catmull-Rom spline

Curve widget with a 1D Catmull-Rom spline with non-uniform knot spacing and knot multiplicity using this crate for interpolation (drawn using tiny-skia).

The crate uses generics to allow interpolation of any type for which certain traits are defined.

I.e. you can use this crate to interpolate splines in 1D, 2D, 3D, etc.

[dependencies]
uniform-cubic-splines = { version = "0.1" }

Example

Using a combination of spline() and spline_inverse() it is possible to compute a full spline-with-nonuniform-abscissæ:

use uniform_cubic_splines::{
    basis::CatmullRom, spline_inverse, spline,
};

// We want to evaluate the spline at knot value 0.3.
let x = 0.3;

// The first and last points are never interpolated.
let knot_spacing = [0.0, 0.0, 0.1, 0.3, 1.0, 1.0];
let knots        = [0.0, 0.0, 1.3, 4.2, 3.2, 3.2];

let v = spline_inverse::<CatmullRom, _>(x, &knot_spacing, None, None).unwrap();
let y = spline::<CatmullRom, _, _>(v, &knots);

assert!(y - 4.2 < 1e-6);

Features

  • monotonic_check -- The spline_inverse() code will check if the knot vector is monotonic (on by default).

Background

The code is a Rust port of the implementation found in the Open Shading Language C++ source.

If you come from a background of computer graphics/shading languages used in offline rendering this crate should feel like home.

Dependencies

~165KB