From df5f7676101d0772898b6b837b0f97c5958bcf02 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcel=20M=C3=A4rtens?= Date: Sat, 18 May 2024 19:15:27 +0200 Subject: [PATCH] cleanup and more correct simd behavior --- common/query_server/src/proto.rs | 2 +- world/src/sim/erosion.rs | 5 ++--- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/common/query_server/src/proto.rs b/common/query_server/src/proto.rs index df79172db8..4d2ef126f3 100644 --- a/common/query_server/src/proto.rs +++ b/common/query_server/src/proto.rs @@ -1,4 +1,4 @@ -#![allow(non_local_definitions)] //TODO: added 2024-05-15 to update toolchain +#![allow(non_local_definitions)] // necessary because of the Protocol derive macro use protocol::Protocol; pub(crate) const VERSION: u16 = 0; diff --git a/world/src/sim/erosion.rs b/world/src/sim/erosion.rs index 3865f17fad..1bcbcb0503 100644 --- a/world/src/sim/erosion.rs +++ b/world/src/sim/erosion.rs @@ -606,7 +606,6 @@ fn get_max_slope( // simd alternative #[cfg(not(feature = "simd"))] #[derive(Copy, Clone)] -#[allow(non_camel_case_types)] struct M32(u32); #[cfg(not(feature = "simd"))] impl M32 { @@ -614,7 +613,7 @@ impl M32 { fn splat(x: bool) -> Self { if x { Self(u32::MAX) } else { Self(u32::MIN) } } #[inline] - fn test(&self, cmp: u32) -> bool { self.0 != cmp } + fn any(&self) -> bool { self.0 != 0 } } #[cfg(feature = "simd")] type M32 = std::simd::Mask; @@ -1333,7 +1332,7 @@ fn erode( let mut df = 1.0; izip!(&mask, &rec_heights, k_fs_fact, k_df_fact).for_each( |(&mask_kk, &rec_heights_kk, &k_fs_fact_kk, &k_df_fact_kk)| { - if mask_kk.test(0) { + if mask_kk.any() { let h_j = rec_heights_kk; let elev_j = h_j; let dh = 0.0.max(new_h_i as SimdType - elev_j);