Name Description Size
diyfp.rs explicit DiyFp(double d) { union { double d; uint64_t u64; } u = { d }; int biased_e = static_cast<int>((u.u64 & kDpExponentMask) >> kDpSignificandSize); uint64_t significand = (u.u64 & kDpSignificandMask); if (biased_e != 0) { f = significand + kDpHiddenBit; e = biased_e - kDpExponentBias; } else { f = significand; e = kDpMinExponent + 1; } } 7545
dtoa.rs inline void GrisuRound(char* buffer, int len, uint64_t delta, uint64_t rest, uint64_t ten_kappa, uint64_t wp_w) { while (rest < wp_w && delta - rest >= ten_kappa && (rest + ten_kappa < wp_w || /// closer wp_w - rest > rest + ten_kappa - wp_w)) { buffer[len - 1]--; rest += ten_kappa; } } 15663
lib.rs [![github]](https://github.com/dtolnay/dtoa)&ensp;[![crates-io]](https://crates.io/crates/dtoa)&ensp;[![docs-rs]](https://docs.rs/dtoa) [github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github [crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= <br> This crate provides fast functions for printing floating-point primitives to an [`io::Write`]. The implementation is a straightforward Rust port of [Milo Yip]'s C++ implementation [dtoa.h]. The original C++ code of each function is included in comments. See also [`itoa`] for printing integer primitives. [`io::Write`]: https://doc.rust-lang.org/std/io/trait.Write.html [Milo Yip]: https://github.com/miloyip [dtoa.h]: https://github.com/miloyip/rapidjson/blob/master/include/rapidjson/internal/dtoa.h [`itoa`]: https://github.com/dtolnay/itoa <br> ## Performance (lower is better) ![performance](https://raw.githubusercontent.com/dtolnay/dtoa/master/performance.png) <br> # Examples ```edition2018 use std::io; fn main() -> io::Result<()> { // Write to a vector or other io::Write. let mut buf = Vec::new(); dtoa::write(&mut buf, 2.71828f64)?; println!("{:?}", buf); // Write to a stack buffer. let mut bytes = [b'\0'; 20]; let n = dtoa::write(&mut bytes[..], 2.71828f64)?; println!("{:?}", &bytes[..n]); Ok(()) } ``` 8238