1 unstable release
0.1.0 | Feb 2, 2025 |
---|
#510 in Math
143 downloads per month
15KB
171 lines
generic-interval
A generic closed interval library.
An interval is a pair of numbers which represents all the numbers between them.
Intervals are considered closed so the bounds are included.
Intervals are written [a, b] to represent all the numbers between a and b inclusive, a ≤ b.
The library is designed to be used with any types that implement the
Copy
and PartialOrd
traits including the floating point types:
f64
and f32
and arithmetic types in
new types.
The library is declared no_std so it can be used in embedded applications.
Examples
use generic_interval::{Interval, hull, intersection};
// An example new-type based on f64
#[derive(Clone, Copy, Debug, PartialEq, PartialOrd)]
pub struct Metres(pub f64);
let a = Interval::try_from((Metres(1.0), Metres(4.0))).unwrap();
let b = Interval::try_from((Metres(6.0), Metres(9.0))).unwrap();
// Note: the hull does not include 4.0-6.0
let result = hull(a, b);
assert_eq!(Metres(1.0), result.lower());
assert_eq!(Metres(9.0), result.upper());
let result = intersection(a, b);
assert!(result.is_none());
let c = Interval::try_from((Metres(4.0), Metres(9.0))).unwrap();
let result = intersection(a, c).unwrap();
assert_eq!(Metres(4.0), result.lower());
assert_eq!(Metres(4.0), result.upper());
License
generic-interval
is provided under a MIT license, see LICENSE.
Dependencies
~0.4–1MB
~22K SLoC