Skip to content

EricLBuehler/float8

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

float8: 8-bit floating point types for Rust

This crate provides 2 types:

  • F8E4M3: Sign + 4-bit exponent + 3-bit mantissa. More precise but less dynamic range.
  • F8E5M2: Sign + 5-bit exponent + 2-bit mantissa. Less precise but more dynamic range (same exponent as f16).

Generally, this crate is modelled after the half crate, so it can be used alongside and with minimal code changes.

  • This crate provides no_std support
  • Requires Rust 1.70 or greater

Optional features

  • std - Enable features that depend on the Rust standard library.
  • serde - Add support for the serde crate with Serialize and Deserialize traits.
  • num-traits - Implement traits from num-traits such as ToPrimitive, FromPrimitive, AsPrimitive, Num, Float, FloatCore, and Bounded.
  • bytemuck - Implement traits from bytemuck including Zeroable and Pod
  • zerocopy - Implement traits from zerocopy including AsBytes and FromBytes
  • rand_distr - Implement traits from rand_distr including Distribution and others
  • rkyv - Enable zero-copy deserialization with rkyv.

Resources

About

8-bit floating point types for Rust

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages