diff options
Diffstat (limited to 'vendor/libm-0.1.4/src/math/frexpf.rs')
-rw-r--r-- | vendor/libm-0.1.4/src/math/frexpf.rs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/vendor/libm-0.1.4/src/math/frexpf.rs b/vendor/libm-0.1.4/src/math/frexpf.rs new file mode 100644 index 000000000..2919c0ab0 --- /dev/null +++ b/vendor/libm-0.1.4/src/math/frexpf.rs @@ -0,0 +1,21 @@ +pub fn frexpf(x: f32) -> (f32, i32) { + let mut y = x.to_bits(); + let ee: i32 = ((y >> 23) & 0xff) as i32; + + if ee == 0 { + if x != 0.0 { + let x1p64 = f32::from_bits(0x5f800000); + let (x, e) = frexpf(x * x1p64); + return (x, e - 64); + } else { + return (x, 0); + } + } else if ee == 0xff { + return (x, 0); + } + + let e = ee - 0x7e; + y &= 0x807fffff; + y |= 0x3f000000; + (f32::from_bits(y), e) +} |