2021-07-19 19:13:24 -04:00
|
|
|
#![feature(portable_simd)]
|
|
|
|
|
2021-04-25 15:01:05 -07:00
|
|
|
macro_rules! float_rounding_test {
|
2021-08-07 21:15:24 +00:00
|
|
|
{ $scalar:tt, $int_scalar:tt } => {
|
2021-04-25 15:01:05 -07:00
|
|
|
mod $scalar {
|
2021-12-21 15:29:29 -08:00
|
|
|
use std_float::StdFloat;
|
|
|
|
|
2022-11-27 23:44:20 -05:00
|
|
|
type Vector<const LANES: usize> = core_simd::simd::Simd<$scalar, LANES>;
|
2021-04-25 15:01:05 -07:00
|
|
|
type Scalar = $scalar;
|
|
|
|
type IntScalar = $int_scalar;
|
|
|
|
|
|
|
|
test_helpers::test_lanes! {
|
|
|
|
fn ceil<const LANES: usize>() {
|
|
|
|
test_helpers::test_unary_elementwise(
|
|
|
|
&Vector::<LANES>::ceil,
|
|
|
|
&Scalar::ceil,
|
|
|
|
&|_| true,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn floor<const LANES: usize>() {
|
|
|
|
test_helpers::test_unary_elementwise(
|
|
|
|
&Vector::<LANES>::floor,
|
|
|
|
&Scalar::floor,
|
|
|
|
&|_| true,
|
|
|
|
)
|
|
|
|
}
|
2021-04-25 15:03:17 -07:00
|
|
|
|
|
|
|
fn round<const LANES: usize>() {
|
|
|
|
test_helpers::test_unary_elementwise(
|
|
|
|
&Vector::<LANES>::round,
|
|
|
|
&Scalar::round,
|
|
|
|
&|_| true,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn trunc<const LANES: usize>() {
|
|
|
|
test_helpers::test_unary_elementwise(
|
|
|
|
&Vector::<LANES>::trunc,
|
|
|
|
&Scalar::trunc,
|
|
|
|
&|_| true,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fract<const LANES: usize>() {
|
2023-07-22 09:16:42 -04:00
|
|
|
test_helpers::test_unary_elementwise_flush_subnormals(
|
2021-04-25 15:03:17 -07:00
|
|
|
&Vector::<LANES>::fract,
|
|
|
|
&Scalar::fract,
|
|
|
|
&|_| true,
|
|
|
|
)
|
|
|
|
}
|
2021-04-25 15:01:05 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
test_helpers::test_lanes! {
|
|
|
|
fn to_int_unchecked<const LANES: usize>() {
|
2023-05-20 17:17:56 -04:00
|
|
|
use core_simd::simd::SimdFloat;
|
2021-04-25 15:01:05 -07:00
|
|
|
// The maximum integer that can be represented by the equivalently sized float has
|
|
|
|
// all of the mantissa digits set to 1, pushed up to the MSB.
|
|
|
|
const ALL_MANTISSA_BITS: IntScalar = ((1 << <Scalar>::MANTISSA_DIGITS) - 1);
|
|
|
|
const MAX_REPRESENTABLE_VALUE: Scalar =
|
|
|
|
(ALL_MANTISSA_BITS << (core::mem::size_of::<Scalar>() * 8 - <Scalar>::MANTISSA_DIGITS as usize - 1)) as Scalar;
|
|
|
|
|
2022-03-20 19:17:33 -04:00
|
|
|
let mut runner = test_helpers::make_runner();
|
2021-04-25 15:01:05 -07:00
|
|
|
runner.run(
|
|
|
|
&test_helpers::array::UniformArrayStrategy::new(-MAX_REPRESENTABLE_VALUE..MAX_REPRESENTABLE_VALUE),
|
|
|
|
|x| {
|
2022-02-02 18:21:12 -08:00
|
|
|
let result_1 = unsafe { Vector::from_array(x).to_int_unchecked::<IntScalar>().to_array() };
|
2021-04-25 15:01:05 -07:00
|
|
|
let result_2 = {
|
2022-02-02 18:21:12 -08:00
|
|
|
let mut result: [IntScalar; LANES] = [0; LANES];
|
2021-04-25 15:01:05 -07:00
|
|
|
for (i, o) in x.iter().zip(result.iter_mut()) {
|
2022-02-02 18:21:12 -08:00
|
|
|
*o = unsafe { i.to_int_unchecked::<IntScalar>() };
|
2021-04-25 15:01:05 -07:00
|
|
|
}
|
|
|
|
result
|
|
|
|
};
|
|
|
|
test_helpers::prop_assert_biteq!(result_1, result_2);
|
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
).unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-07 21:15:24 +00:00
|
|
|
float_rounding_test! { f32, i32 }
|
|
|
|
float_rounding_test! { f64, i64 }
|