summaryrefslogtreecommitdiffstats
path: root/vendor/libm-0.1.4/src/math/frexpf.rs
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/libm-0.1.4/src/math/frexpf.rs')
-rw-r--r--vendor/libm-0.1.4/src/math/frexpf.rs21
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)
+}