6
我需要将存储的半浮点数(16位)转换为标准的32位浮点数。我目前使用下面的代码,但它依赖于libc。我只想使用std
,它应该在稳定的Rust上工作。如何使用稳定的标准库将f16解码为f32?
#[inline]
fn decode_f16(half: u16) -> f32 {
let exp: u16 = half >> 10 & 0x1f;
let mant: u16 = half & 0x3ff;
let val: f32 = if exp == 0 {
ffi::c_ldexpf(mant as f32, -24)
} else if exp != 31 {
ffi::c_ldexpf(mant as f32 + 1024f32, exp as isize - 25)
} else if mant == 0 {
::std::f32::INFINITY
} else {
::std::f32::NAN
};
if half & 0x8000 != 0 {
-val
} else {
val
}
}
为什么你不使用https://doc.rust-lang.org/std/primitive.f32.html#method.ldexp并等待它稳定? –
箱子应该现在稳定工作。另外,ldexp方法不太可能稳定。 – Pyfisch