#numeric

no-std num-traits

Numeric traits for generic mathematics

31 releases

0.2.19 May 3, 2024
0.2.18 Feb 8, 2024
0.2.17 Oct 7, 2023
0.2.16 Jul 20, 2023
0.1.34 Jul 24, 2016

#38 in Math

Download history 2593849/week @ 2024-09-17 2805583/week @ 2024-09-24 3168779/week @ 2024-10-01 3477877/week @ 2024-10-08 3441418/week @ 2024-10-15 2856542/week @ 2024-10-22 2851851/week @ 2024-10-29 2796059/week @ 2024-11-05 2817016/week @ 2024-11-12 2793363/week @ 2024-11-19 2479653/week @ 2024-11-26 2896634/week @ 2024-12-03 3093425/week @ 2024-12-10 2675023/week @ 2024-12-17 1545860/week @ 2024-12-24 1467820/week @ 2024-12-31

9,314,427 downloads per month
Used in 52,264 crates (4,435 directly)

MIT/Apache

240KB
4K SLoC

num-traits

crate documentation minimum rustc 1.60 build status

Numeric traits for generic mathematics in Rust.

Usage

Add this to your Cargo.toml:

[dependencies]
num-traits = "0.2"

Features

This crate can be used without the standard library (#![no_std]) by disabling the default std feature. Use this in Cargo.toml:

[dependencies.num-traits]
version = "0.2"
default-features = false
# features = ["libm"]    # <--- Uncomment if you wish to use `Float` and `Real` without `std`

The Float and Real traits are only available when either std or libm is enabled.

The FloatCore trait is always available. MulAdd and MulAddAssign for f32 and f64 also require std or libm, as do implementations of signed and floating- point exponents in Pow.

Releases

Release notes are available in RELEASES.md.

Compatibility

The num-traits crate is tested for rustc 1.60 and greater.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~100KB