Add a generic version of fmin and fmax
These can be used for `fmin`, `fminf`, `fmax`, and `fmaxf`. No changes to the implementation are made, so [1] is not fixed. [1]: https://github.com/rust-lang/libm/issues/439
This commit is contained in:
parent
453bebf7c1
commit
f94df5d524
8 changed files with 47 additions and 40 deletions
|
|
@ -379,26 +379,30 @@
|
|||
"fmax": {
|
||||
"sources": [
|
||||
"src/libm_helper.rs",
|
||||
"src/math/fmax.rs"
|
||||
"src/math/fmax.rs",
|
||||
"src/math/generic/fmax.rs"
|
||||
],
|
||||
"type": "f64"
|
||||
},
|
||||
"fmaxf": {
|
||||
"sources": [
|
||||
"src/math/fmaxf.rs"
|
||||
"src/math/fmaxf.rs",
|
||||
"src/math/generic/fmax.rs"
|
||||
],
|
||||
"type": "f32"
|
||||
},
|
||||
"fmin": {
|
||||
"sources": [
|
||||
"src/libm_helper.rs",
|
||||
"src/math/fmin.rs"
|
||||
"src/math/fmin.rs",
|
||||
"src/math/generic/fmin.rs"
|
||||
],
|
||||
"type": "f64"
|
||||
},
|
||||
"fminf": {
|
||||
"sources": [
|
||||
"src/math/fminf.rs"
|
||||
"src/math/fminf.rs",
|
||||
"src/math/generic/fmin.rs"
|
||||
],
|
||||
"type": "f32"
|
||||
},
|
||||
|
|
|
|||
|
|
@ -1,12 +1,5 @@
|
|||
/// Return the greater of two arguments or, if either argument is NaN, the other argument.
|
||||
#[cfg_attr(all(test, assert_no_panic), no_panic::no_panic)]
|
||||
pub fn fmax(x: f64, y: f64) -> f64 {
|
||||
// IEEE754 says: maxNum(x, y) is the canonicalized number y if x < y, x if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if x.is_nan() || x < y { y } else { x }) * 1.0
|
||||
super::generic::fmax(x, y)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,12 +1,5 @@
|
|||
/// Return the greater of two arguments or, if either argument is NaN, the other argument.
|
||||
#[cfg_attr(all(test, assert_no_panic), no_panic::no_panic)]
|
||||
pub fn fmaxf(x: f32, y: f32) -> f32 {
|
||||
// IEEE754 says: maxNum(x, y) is the canonicalized number y if x < y, x if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if x.is_nan() || x < y { y } else { x }) * 1.0
|
||||
super::generic::fmax(x, y)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,12 +1,5 @@
|
|||
/// Return the lesser of two arguments or, if either argument is NaN, the other argument.
|
||||
#[cfg_attr(all(test, assert_no_panic), no_panic::no_panic)]
|
||||
pub fn fmin(x: f64, y: f64) -> f64 {
|
||||
// IEEE754 says: minNum(x, y) is the canonicalized number x if x < y, y if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if y.is_nan() || x < y { x } else { y }) * 1.0
|
||||
super::generic::fmin(x, y)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,12 +1,5 @@
|
|||
/// Return the lesser of two arguments or, if either argument is NaN, the other argument.
|
||||
#[cfg_attr(all(test, assert_no_panic), no_panic::no_panic)]
|
||||
pub fn fminf(x: f32, y: f32) -> f32 {
|
||||
// IEEE754 says: minNum(x, y) is the canonicalized number x if x < y, y if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if y.is_nan() || x < y { x } else { y }) * 1.0
|
||||
super::generic::fmin(x, y)
|
||||
}
|
||||
|
|
|
|||
14
library/compiler-builtins/libm/src/math/generic/fmax.rs
Normal file
14
library/compiler-builtins/libm/src/math/generic/fmax.rs
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
use super::super::Float;
|
||||
|
||||
#[cfg_attr(all(test, assert_no_panic), no_panic::no_panic)]
|
||||
pub fn fmax<F: Float>(x: F, y: F) -> F {
|
||||
// IEEE754 says: maxNum(x, y) is the canonicalized number y if x < y, x if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if x.is_nan() || x < y { y } else { x }) * F::ONE
|
||||
}
|
||||
13
library/compiler-builtins/libm/src/math/generic/fmin.rs
Normal file
13
library/compiler-builtins/libm/src/math/generic/fmin.rs
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
use super::super::Float;
|
||||
|
||||
pub fn fmin<F: Float>(x: F, y: F) -> F {
|
||||
// IEEE754 says: minNum(x, y) is the canonicalized number x if x < y, y if y < x, the
|
||||
// canonicalized number if one operand is a number and the other a quiet NaN. Otherwise it
|
||||
// is either x or y, canonicalized (this means results might differ among implementations).
|
||||
// When either x or y is a signalingNaN, then the result is according to 6.2.
|
||||
//
|
||||
// Since we do not support sNaN in Rust yet, we do not need to handle them.
|
||||
// FIXME(nagisa): due to https://bugs.llvm.org/show_bug.cgi?id=33303 we canonicalize by
|
||||
// multiplying by 1.0. Should switch to the `canonicalize` when it works.
|
||||
(if y.is_nan() || x < y { x } else { y }) * F::ONE
|
||||
}
|
||||
|
|
@ -3,6 +3,8 @@ mod copysign;
|
|||
mod fabs;
|
||||
mod fdim;
|
||||
mod floor;
|
||||
mod fmax;
|
||||
mod fmin;
|
||||
mod rint;
|
||||
mod round;
|
||||
mod scalbn;
|
||||
|
|
@ -14,6 +16,8 @@ pub use copysign::copysign;
|
|||
pub use fabs::fabs;
|
||||
pub use fdim::fdim;
|
||||
pub use floor::floor;
|
||||
pub use fmax::fmax;
|
||||
pub use fmin::fmin;
|
||||
pub use rint::rint;
|
||||
pub use round::round;
|
||||
pub use scalbn::scalbn;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue