softfloat 1.0.0

Pure software floating-point implementation, with `const` and `no_std` support
Documentation
1
2
3
4
5
6
7
8
9
10
11
12
13
use super::F64;

/// Sign of Y, magnitude of X (f64)
///
/// Constructs a number with the magnitude (absolute value) of its
/// first argument, `x`, and the sign of its second argument, `y`.
pub(crate) const fn copysign(x: F64, y: F64) -> F64 {
    let mut ux = x.to_bits();
    let uy = y.to_bits();
    ux &= (!0) >> 1;
    ux |= uy & (1 << 63);
    F64::from_bits(ux)
}