#define SIMDE_TEST_X86_AVX512_INSN load #include #include static int test_simde_mm512_load_si512 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { SIMDE_ALIGN_LIKE_64(simde__m512i) const int32_t a[16]; const int32_t r[16]; } test_vec[] = { { { -INT32_C( 1085279312), INT32_C( 1689654203), -INT32_C( 1704027444), INT32_C( 1992004399), INT32_C( 1598136076), -INT32_C( 1107314712), INT32_C( 1634510512), INT32_C( 2144272078), -INT32_C( 1405215247), -INT32_C( 65931984), -INT32_C( 1097433201), INT32_C( 523522579), -INT32_C( 629246223), -INT32_C( 560497363), -INT32_C( 230751453), -INT32_C( 210694911) }, { -INT32_C( 1085279312), INT32_C( 1689654203), -INT32_C( 1704027444), INT32_C( 1992004399), INT32_C( 1598136076), -INT32_C( 1107314712), INT32_C( 1634510512), INT32_C( 2144272078), -INT32_C( 1405215247), -INT32_C( 65931984), -INT32_C( 1097433201), INT32_C( 523522579), -INT32_C( 629246223), -INT32_C( 560497363), -INT32_C( 230751453), -INT32_C( 210694911) } }, { { INT32_C( 1537191723), INT32_C( 878227620), INT32_C( 1139994160), INT32_C( 845293376), -INT32_C( 905125475), -INT32_C( 2102877346), -INT32_C( 1468733529), INT32_C( 547087861), INT32_C( 964377492), INT32_C( 460182507), INT32_C( 39739330), INT32_C( 590659974), INT32_C( 15614114), -INT32_C( 1954375964), INT32_C( 1932785278), INT32_C( 1888735195) }, { INT32_C( 1537191723), INT32_C( 878227620), INT32_C( 1139994160), INT32_C( 845293376), -INT32_C( 905125475), -INT32_C( 2102877346), -INT32_C( 1468733529), INT32_C( 547087861), INT32_C( 964377492), INT32_C( 460182507), INT32_C( 39739330), INT32_C( 590659974), INT32_C( 15614114), -INT32_C( 1954375964), INT32_C( 1932785278), INT32_C( 1888735195) } }, { { -INT32_C( 173470198), -INT32_C( 1542383902), -INT32_C( 56201355), -INT32_C( 769664208), -INT32_C( 2945765), INT32_C( 579491236), INT32_C( 664125004), -INT32_C( 1751701363), INT32_C( 411844662), -INT32_C( 860054186), INT32_C( 1036542733), INT32_C( 1494279998), -INT32_C( 1722162187), -INT32_C( 2068061384), INT32_C( 783044769), -INT32_C( 1362803848) }, { -INT32_C( 173470198), -INT32_C( 1542383902), -INT32_C( 56201355), -INT32_C( 769664208), -INT32_C( 2945765), INT32_C( 579491236), INT32_C( 664125004), -INT32_C( 1751701363), INT32_C( 411844662), -INT32_C( 860054186), INT32_C( 1036542733), INT32_C( 1494279998), -INT32_C( 1722162187), -INT32_C( 2068061384), INT32_C( 783044769), -INT32_C( 1362803848) } }, { { -INT32_C( 624471420), -INT32_C( 56196113), INT32_C( 607809254), INT32_C( 1266567766), INT32_C( 1709496109), INT32_C( 1558880186), INT32_C( 1737135855), INT32_C( 1561678041), -INT32_C( 1858544478), INT32_C( 1183768160), -INT32_C( 1553217459), INT32_C( 1072621842), INT32_C( 2057622208), INT32_C( 1624673905), -INT32_C( 20487900), INT32_C( 1398529201) }, { -INT32_C( 624471420), -INT32_C( 56196113), INT32_C( 607809254), INT32_C( 1266567766), INT32_C( 1709496109), INT32_C( 1558880186), INT32_C( 1737135855), INT32_C( 1561678041), -INT32_C( 1858544478), INT32_C( 1183768160), -INT32_C( 1553217459), INT32_C( 1072621842), INT32_C( 2057622208), INT32_C( 1624673905), -INT32_C( 20487900), INT32_C( 1398529201) } }, { { INT32_C( 434410425), -INT32_C( 1084263822), INT32_C( 1281542714), INT32_C( 1938510003), -INT32_C( 1813106654), -INT32_C( 470563650), -INT32_C( 689849819), INT32_C( 1328102550), INT32_C( 1114115792), -INT32_C( 1157511040), INT32_C( 1174889362), -INT32_C( 709258317), -INT32_C( 2123847741), -INT32_C( 1855693972), -INT32_C( 1419229931), INT32_C( 1392218498) }, { INT32_C( 434410425), -INT32_C( 1084263822), INT32_C( 1281542714), INT32_C( 1938510003), -INT32_C( 1813106654), -INT32_C( 470563650), -INT32_C( 689849819), INT32_C( 1328102550), INT32_C( 1114115792), -INT32_C( 1157511040), INT32_C( 1174889362), -INT32_C( 709258317), -INT32_C( 2123847741), -INT32_C( 1855693972), -INT32_C( 1419229931), INT32_C( 1392218498) } }, { { INT32_C( 546595743), -INT32_C( 1092905685), -INT32_C( 1425743112), INT32_C( 947961205), -INT32_C( 776279963), INT32_C( 1482825283), -INT32_C( 435959196), -INT32_C( 80150948), -INT32_C( 1927558046), INT32_C( 1498150497), INT32_C( 1308905433), INT32_C( 1921483789), -INT32_C( 1354546836), -INT32_C( 1022909089), -INT32_C( 861336976), INT32_C( 1808261385) }, { INT32_C( 546595743), -INT32_C( 1092905685), -INT32_C( 1425743112), INT32_C( 947961205), -INT32_C( 776279963), INT32_C( 1482825283), -INT32_C( 435959196), -INT32_C( 80150948), -INT32_C( 1927558046), INT32_C( 1498150497), INT32_C( 1308905433), INT32_C( 1921483789), -INT32_C( 1354546836), -INT32_C( 1022909089), -INT32_C( 861336976), INT32_C( 1808261385) } }, { { INT32_C( 251192237), -INT32_C( 1301855015), -INT32_C( 1610519661), INT32_C( 1527941359), INT32_C( 671765961), INT32_C( 1810633211), INT32_C( 624399644), INT32_C( 613482103), -INT32_C( 1154250527), INT32_C( 1617795788), -INT32_C( 184521210), -INT32_C( 1085205514), INT32_C( 1676172136), -INT32_C( 1982933907), -INT32_C( 525466263), -INT32_C( 452641276) }, { INT32_C( 251192237), -INT32_C( 1301855015), -INT32_C( 1610519661), INT32_C( 1527941359), INT32_C( 671765961), INT32_C( 1810633211), INT32_C( 624399644), INT32_C( 613482103), -INT32_C( 1154250527), INT32_C( 1617795788), -INT32_C( 184521210), -INT32_C( 1085205514), INT32_C( 1676172136), -INT32_C( 1982933907), -INT32_C( 525466263), -INT32_C( 452641276) } }, { { -INT32_C( 1818216250), -INT32_C( 655159598), INT32_C( 1942942588), INT32_C( 1865555718), -INT32_C( 405661062), INT32_C( 1483776494), -INT32_C( 1439162714), INT32_C( 596655452), INT32_C( 1219899509), -INT32_C( 1155487426), -INT32_C( 1557205348), -INT32_C( 2012061683), INT32_C( 1768940667), INT32_C( 750903429), INT32_C( 1540815614), -INT32_C( 1384225225) }, { -INT32_C( 1818216250), -INT32_C( 655159598), INT32_C( 1942942588), INT32_C( 1865555718), -INT32_C( 405661062), INT32_C( 1483776494), -INT32_C( 1439162714), INT32_C( 596655452), INT32_C( 1219899509), -INT32_C( 1155487426), -INT32_C( 1557205348), -INT32_C( 2012061683), INT32_C( 1768940667), INT32_C( 750903429), INT32_C( 1540815614), -INT32_C( 1384225225) } } }; for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_test_x86_assert_equal_i32x16(simde_mm512_load_si512(test_vec[i].a), simde_mm512_loadu_epi32(test_vec[i].r)); } return 0; #else fputc('\n', stdout); for (int i = 0 ; i < 8 ; i++) { simde__m512i a = simde_test_x86_random_i32x16(); simde__m512i r = a; simde_test_x86_write_i32x16(2, a, SIMDE_TEST_VEC_POS_FIRST); simde_test_x86_write_i32x16(2, r, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif } SIMDE_TEST_FUNC_LIST_BEGIN SIMDE_TEST_FUNC_LIST_ENTRY(mm512_load_si512) SIMDE_TEST_FUNC_LIST_END #include