Skip to content

Commit

Permalink
Merge #438: Use -0.0 as the neutral additive float
Browse files Browse the repository at this point in the history
-0.0 +  0.0 is  0.0
-0.0 + -0.0 is -0.0

Thus, the float additive-zero is -0.0, not its positive cousin.
This aligns with a recent change to the impl of Sum for floats,
in rust-lang/rust@4908188
  • Loading branch information
workingjubilee authored Oct 22, 2024
2 parents 7e162d1 + c080ba5 commit 5523a31
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 2 deletions.
2 changes: 1 addition & 1 deletion crates/core_simd/src/simd/num/float.rs
Original file line number Diff line number Diff line change
Expand Up @@ -419,7 +419,7 @@ macro_rules! impl_trait {
self.as_array().iter().sum()
} else {
// Safety: `self` is a float vector
unsafe { core::intrinsics::simd::simd_reduce_add_ordered(self, 0.) }
unsafe { core::intrinsics::simd::simd_reduce_add_ordered(self, -0.) }
}
}

Expand Down
6 changes: 6 additions & 0 deletions crates/core_simd/tests/ops_macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -527,6 +527,9 @@ macro_rules! impl_float_tests {
}

fn is_normal<const LANES: usize>() {
// Arm v7 Neon violates float opsem re: subnormals, see
// https://github.com/rust-lang/portable-simd/issues/439
#[cfg(not(target_arch = "arm"))]
test_helpers::test_unary_mask_elementwise(
&Vector::<LANES>::is_normal,
&Scalar::is_normal,
Expand All @@ -535,6 +538,9 @@ macro_rules! impl_float_tests {
}

fn is_subnormal<const LANES: usize>() {
// Arm v7 Neon violates float opsem re: subnormals, see
// https://github.com/rust-lang/portable-simd/issues/439
#[cfg(not(target_arch = "arm"))]
test_helpers::test_unary_mask_elementwise(
&Vector::<LANES>::is_subnormal,
&Scalar::is_subnormal,
Expand Down
2 changes: 1 addition & 1 deletion rust-toolchain.toml
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
[toolchain]
channel = "nightly-2024-06-13"
channel = "nightly-2024-09-11"
components = ["rustfmt", "clippy", "miri", "rust-src"]

0 comments on commit 5523a31

Please sign in to comment.