#numbers #complex-numbers #complex #float #deserialize #integer #unsigned

number-general

A generic number type for Rust which supports basic math and (de)serialization

32 releases

0.11.1 Dec 20, 2023
0.11.0 Nov 6, 2023
0.10.0 Jul 3, 2023
0.9.1 Jan 24, 2023
0.3.0 Feb 1, 2021

#226 in Data structures

Download history 6/week @ 2024-01-08 8/week @ 2024-01-22 29/week @ 2024-01-29 3/week @ 2024-02-05 279/week @ 2024-02-12 20/week @ 2024-02-19 71/week @ 2024-02-26 27/week @ 2024-03-04 41/week @ 2024-03-11 126/week @ 2024-03-18 221/week @ 2024-03-25 215/week @ 2024-04-01 15/week @ 2024-04-08 15/week @ 2024-04-15 12/week @ 2024-04-22

266 downloads per month
Used in 15 crates (4 directly)

Apache-2.0

125KB
4K SLoC

number-general

A generic Rust number type with support for basic math operations, (de)serialization, and casting with safecast.

Example usage:

use number_general::{Int, Number};
use safecast::CastFrom;

let sequence: Vec<Number> = serde_json::from_str("[true, 2, 3.5, -4, [1.0, -0.5]]").unwrap();
let actual = sequence.into_iter().product();

assert_eq!(actual, Number::from(num::Complex::<f64>::new(-28., 14.)));
assert_eq!(Int::cast_from(actual), Int::from(-28));

lib.rs:

Provides a generic Number enum with Boolean, Complex, Float, [Int], and UInt variants, as well as a NumberCollator, ComplexCollator, and FloatCollator since these types do not implement [Ord].

Number supports casting with safecast.

For (de)serialization with serde, enable the "serde" feature.

For (de)coding with destream, enable the "stream" feature.

Example usage:

let sequence: Vec<Number> = vec![true.into(), 2.into(), 3.5.into(), [1.0, -0.5].into()];
let actual = sequence.into_iter().product();
let expected = Number::from(num::Complex::<f64>::new(7., -3.5));

assert_eq!(expected, actual);
assert_eq!(Int::cast_from(actual), Int::from(7));

Dependencies

~1.2–2.2MB
~45K SLoC