1 | #[cfg_attr (all(test, assert_no_panic), no_panic::no_panic)] |
2 | pub fn frexp(x: f64) -> (f64, i32) { |
3 | let mut y: u64 = x.to_bits(); |
4 | let ee: i32 = ((y >> 52) & 0x7ff) as i32; |
5 | |
6 | if ee == 0 { |
7 | if x != 0.0 { |
8 | let x1p64: f64 = f64::from_bits(0x43f0000000000000); |
9 | let (x: f64, e: i32) = frexp(x * x1p64); |
10 | return (x, e - 64); |
11 | } |
12 | return (x, 0); |
13 | } else if ee == 0x7ff { |
14 | return (x, 0); |
15 | } |
16 | |
17 | let e: i32 = ee - 0x3fe; |
18 | y &= 0x800fffffffffffff; |
19 | y |= 0x3fe0000000000000; |
20 | return (f64::from_bits(y), e); |
21 | } |
22 | |