From 8b4facc877f4c473f9ad097cf68c2908374de49f Mon Sep 17 00:00:00 2001 From: Stephen Fegan Date: Wed, 7 Aug 2024 07:45:37 +0200 Subject: [PATCH] Remove idiv implementation There is no integer division in AVX --- include/math/hex_array_vcl.hpp | 28 ---------------------------- 1 file changed, 28 deletions(-) diff --git a/include/math/hex_array_vcl.hpp b/include/math/hex_array_vcl.hpp index 9836a034..c1e371b7 100644 --- a/include/math/hex_array_vcl.hpp +++ b/include/math/hex_array_vcl.hpp @@ -229,16 +229,6 @@ template class alignas(VCLArchitecture::vec_bytes) VCL } } - static inline void positive_hexid_to_ringid_segid_runid_idiv( - const int32_vt hexid, int32_vt& ringid, int32_vt& segid, int32_vt& runid) - { - ringid = positive_hexid_to_ringid(hexid); - const int32_vt ringid_minus_one = ringid - 1; - runid = hexid - ringid_to_nsites_contained(ringid_minus_one); - segid = runid/ringid; - runid -= segid*ringid; - } - static inline void hexid_to_ringid_segid_runid( const int32_vt hexid, int32_vt& ringid, int32_vt& segid, int32_vt& runid) { @@ -1111,24 +1101,6 @@ inline void test_vcl_positive_hexid_to_ringid_segid_runid_muldiv(volatile unsign } } -inline void test_vcl_positive_hexid_to_ringid_segid_runid_idiv(volatile unsigned hexid, - unsigned& ringid, unsigned& segid, unsigned& runid, unsigned iterations = 1) -{ - using Arch = calin::util::vcl::VCL256Architecture; - ringid = 0; - segid = 0; - runid = 0; - while(iterations--) { - Arch::int32_vt v_ringid; - Arch::int32_vt v_segid; - Arch::int32_vt v_runid; - VCL::positive_hexid_to_ringid_segid_runid_idiv(hexid,v_ringid,v_segid,v_runid); - ringid += v_ringid[0]; - segid += v_segid[0]; - runid += v_runid[0]; - } -} - #if 0 unsigned test_avx2_hexid_to_ringid(unsigned hexid); unsigned test_avx2_ringid_to_nsites_contained(unsigned ringid);