]> Cypherpunks repositories - gostls13.git/commitdiff
simd/archsimd: add tests for ExtendLo operations
authorCherry Mui <cherryyz@google.com>
Mon, 29 Dec 2025 17:41:57 +0000 (12:41 -0500)
committerCherry Mui <cherryyz@google.com>
Tue, 30 Dec 2025 00:21:28 +0000 (16:21 -0800)
Change-Id: I77a5f0dc58e068882a177dc32d162821b38f34ef
Reviewed-on: https://go-review.googlesource.com/c/go/+/733101
Reviewed-by: David Chase <drchase@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>

src/simd/archsimd/_gen/tmplgen/main.go
src/simd/archsimd/internal/simd_test/unary_helpers_test.go
src/simd/archsimd/internal/simd_test/unary_test.go

index 5a4a3af27202a377046284eb3d9afbe59c96042b..e764bee498ec1b57c91736220325aa735d08238f 100644 (file)
@@ -52,11 +52,11 @@ func (sat shapeAndTemplate) target(outType string, width int) shapeAndTemplate {
        return newSat
 }
 
-func (sat shapeAndTemplate) shrinkTo(outType string, by int) shapeAndTemplate {
+func (sat shapeAndTemplate) targetFixed(outType string, width, count int) shapeAndTemplate {
        newSat := sat
        newShape := *sat.s
        newShape.output = func(t string, w, c int) (ot string, ow int, oc int) {
-               return outType, w / by, c * by
+               return outType, width, count
        }
        newSat.s = &newShape
        return newSat
@@ -104,6 +104,12 @@ var uintShapes = &shapes{
        uints: []int{8, 16, 32, 64},
 }
 
+var integerShapes = &shapes{
+       vecs:  []int{128, 256, 512},
+       ints:  []int{8, 16, 32, 64},
+       uints: []int{8, 16, 32, 64},
+}
+
 var avx512Shapes = &shapes{
        vecs:   []int{512},
        ints:   []int{8, 16, 32, 64},
@@ -395,6 +401,41 @@ var (
        unaryToFloat64 = convertTemplate.target("float", 64)
 )
 
+var convertLoTemplate = shapedTemplateOf(integerShapes, "convert_lo_helpers", `
+// test{{.VType}}ConvertLoTo{{.OVType}} tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low {{.OCount}} elements.
+func test{{.VType}}ConvertLoTo{{.OVType}}(t *testing.T, f func(x archsimd.{{.VType}}) archsimd.{{.OVType}}, want func(x []{{.Etype}}) []{{.OEtype}}) {
+       n := {{.Count}}
+       t.Helper()
+       forSlice(t, {{.Etype}}s, n, func(x []{{.Etype}}) bool {
+               t.Helper()
+               a := archsimd.Load{{.VType}}Slice(x)
+               g := make([]{{.OEtype}}, {{.OCount}})
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() {t.Helper(); t.Logf("x=%v", x)})
+       })
+}
+`)
+
+var (
+       // templates and shapes for conversion of low elements.
+       // The output is fixed to 128- or 256-bits (no 512-bit, as the
+       // regular convertTemplate covers that).
+       // TODO: this includes shapes where in and out have the same element
+       // type or length, which are not needed.
+       unaryToInt64x2  = convertLoTemplate.targetFixed("int", 64, 2)
+       unaryToInt64x4  = convertLoTemplate.targetFixed("int", 64, 4)
+       unaryToUint64x2 = convertLoTemplate.targetFixed("uint", 64, 2)
+       unaryToUint64x4 = convertLoTemplate.targetFixed("uint", 64, 4)
+       unaryToInt32x4  = convertLoTemplate.targetFixed("int", 32, 4)
+       unaryToInt32x8  = convertLoTemplate.targetFixed("int", 32, 8)
+       unaryToUint32x4 = convertLoTemplate.targetFixed("uint", 32, 4)
+       unaryToUint32x8 = convertLoTemplate.targetFixed("uint", 32, 8)
+       unaryToInt16x8  = convertLoTemplate.targetFixed("int", 16, 8)
+       unaryToUint16x8 = convertLoTemplate.targetFixed("uint", 16, 8)
+)
+
 var binaryTemplate = templateOf("binary_helpers", `
 // test{{.VType}}Binary tests the simd binary method f against the expected behavior generated by want
 func test{{.VType}}Binary(t *testing.T, f func(_, _ archsimd.{{.VType}}) archsimd.{{.VType}}, want func(_, _ []{{.Etype}}) []{{.Etype}}) {
@@ -881,7 +922,17 @@ func main() {
                one(*ush, unsafePrologue, unsafePATemplate)
        }
        if *uh != "" {
-               one(*uh, curryTestPrologue("unary simd methods"), unaryTemplate, unaryToInt8, unaryToUint8, unaryToInt16, unaryToUint16, unaryToInt32, unaryToUint32, unaryToInt64, unaryToUint64, unaryToFloat32, unaryToFloat64, unaryFlakyTemplate)
+               one(*uh, curryTestPrologue("unary simd methods"), unaryTemplate,
+                       unaryToInt8, unaryToUint8, unaryToInt16, unaryToUint16,
+                       unaryToInt32, unaryToUint32, unaryToInt64, unaryToUint64,
+                       unaryToFloat32, unaryToFloat64,
+                       unaryToInt64x2, unaryToInt64x4,
+                       unaryToUint64x2, unaryToUint64x4,
+                       unaryToInt32x4, unaryToInt32x8,
+                       unaryToUint32x4, unaryToUint32x8,
+                       unaryToInt16x8, unaryToUint16x8,
+                       unaryFlakyTemplate,
+               )
        }
        if *bh != "" {
                one(*bh, curryTestPrologue("binary simd methods"), binaryTemplate)
index e545a8330d348899b5ccd873176c83d3b1c0923f..5d14c4ff05ec72cf9686f5469c6531f04fd7a4a4 100644 (file)
@@ -5233,6 +5233,3606 @@ func testFloat64x8ConvertToFloat64(t *testing.T, f func(x archsimd.Float64x8) ar
        })
 }
 
+// testInt8x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int8x16) archsimd.Int64x2, want func(x []int8) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int16x8) archsimd.Int64x2, want func(x []int16) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x4ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int32x4) archsimd.Int64x2, want func(x []int32) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x2ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int64x2) archsimd.Int64x2, want func(x []int64) []int64) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Int64x2, want func(x []uint8) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Int64x2, want func(x []uint16) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x4ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Int64x2, want func(x []uint32) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x2ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Int64x2, want func(x []uint64) []int64) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x32ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int8x32) archsimd.Int64x2, want func(x []int8) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int16x16) archsimd.Int64x2, want func(x []int16) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int32x8) archsimd.Int64x2, want func(x []int32) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x4ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int64x4) archsimd.Int64x2, want func(x []int64) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x32ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Int64x2, want func(x []uint8) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Int64x2, want func(x []uint16) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Int64x2, want func(x []uint32) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x4ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Int64x2, want func(x []uint64) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x64ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int8x64) archsimd.Int64x2, want func(x []int8) []int64) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x32ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int16x32) archsimd.Int64x2, want func(x []int16) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int32x16) archsimd.Int64x2, want func(x []int32) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Int64x8) archsimd.Int64x2, want func(x []int64) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x64ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Int64x2, want func(x []uint8) []int64) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x32ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Int64x2, want func(x []uint16) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x16ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Int64x2, want func(x []uint32) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToInt64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x8ConvertLoToInt64x2(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Int64x2, want func(x []uint64) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]int64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int8x16) archsimd.Int64x4, want func(x []int8) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int16x8) archsimd.Int64x4, want func(x []int16) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x4ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int32x4) archsimd.Int64x4, want func(x []int32) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x2ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int64x2) archsimd.Int64x4, want func(x []int64) []int64) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Int64x4, want func(x []uint8) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Int64x4, want func(x []uint16) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x4ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Int64x4, want func(x []uint32) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x2ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Int64x4, want func(x []uint64) []int64) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x32ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int8x32) archsimd.Int64x4, want func(x []int8) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int16x16) archsimd.Int64x4, want func(x []int16) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int32x8) archsimd.Int64x4, want func(x []int32) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x4ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int64x4) archsimd.Int64x4, want func(x []int64) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x32ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Int64x4, want func(x []uint8) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Int64x4, want func(x []uint16) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Int64x4, want func(x []uint32) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x4ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Int64x4, want func(x []uint64) []int64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x64ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int8x64) archsimd.Int64x4, want func(x []int8) []int64) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x32ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int16x32) archsimd.Int64x4, want func(x []int16) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int32x16) archsimd.Int64x4, want func(x []int32) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Int64x8) archsimd.Int64x4, want func(x []int64) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x64ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Int64x4, want func(x []uint8) []int64) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x32ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Int64x4, want func(x []uint16) []int64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x16ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Int64x4, want func(x []uint32) []int64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToInt64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x8ConvertLoToInt64x4(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Int64x4, want func(x []uint64) []int64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]int64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int8x16) archsimd.Uint64x2, want func(x []int8) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int16x8) archsimd.Uint64x2, want func(x []int16) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x4ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int32x4) archsimd.Uint64x2, want func(x []int32) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x2ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int64x2) archsimd.Uint64x2, want func(x []int64) []uint64) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Uint64x2, want func(x []uint8) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Uint64x2, want func(x []uint16) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x4ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Uint64x2, want func(x []uint32) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x2ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Uint64x2, want func(x []uint64) []uint64) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x32ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int8x32) archsimd.Uint64x2, want func(x []int8) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int16x16) archsimd.Uint64x2, want func(x []int16) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int32x8) archsimd.Uint64x2, want func(x []int32) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x4ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int64x4) archsimd.Uint64x2, want func(x []int64) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x32ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Uint64x2, want func(x []uint8) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Uint64x2, want func(x []uint16) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Uint64x2, want func(x []uint32) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x4ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Uint64x2, want func(x []uint64) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt8x64ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int8x64) archsimd.Uint64x2, want func(x []int8) []uint64) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt16x32ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int16x32) archsimd.Uint64x2, want func(x []int16) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt32x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int32x16) archsimd.Uint64x2, want func(x []int32) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testInt64x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Int64x8) archsimd.Uint64x2, want func(x []int64) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint8x64ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Uint64x2, want func(x []uint8) []uint64) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint16x32ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Uint64x2, want func(x []uint16) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint32x16ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Uint64x2, want func(x []uint32) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToUint64x2 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 2 elements.
+func testUint64x8ConvertLoToUint64x2(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Uint64x2, want func(x []uint64) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]uint64, 2)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int8x16) archsimd.Uint64x4, want func(x []int8) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int16x8) archsimd.Uint64x4, want func(x []int16) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x4ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int32x4) archsimd.Uint64x4, want func(x []int32) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x2ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int64x2) archsimd.Uint64x4, want func(x []int64) []uint64) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Uint64x4, want func(x []uint8) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Uint64x4, want func(x []uint16) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x4ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Uint64x4, want func(x []uint32) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x2ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Uint64x4, want func(x []uint64) []uint64) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x32ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int8x32) archsimd.Uint64x4, want func(x []int8) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int16x16) archsimd.Uint64x4, want func(x []int16) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int32x8) archsimd.Uint64x4, want func(x []int32) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x4ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int64x4) archsimd.Uint64x4, want func(x []int64) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x32ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Uint64x4, want func(x []uint8) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Uint64x4, want func(x []uint16) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Uint64x4, want func(x []uint32) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x4ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Uint64x4, want func(x []uint64) []uint64) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x64ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int8x64) archsimd.Uint64x4, want func(x []int8) []uint64) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x32ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int16x32) archsimd.Uint64x4, want func(x []int16) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int32x16) archsimd.Uint64x4, want func(x []int32) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Int64x8) archsimd.Uint64x4, want func(x []int64) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x64ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Uint64x4, want func(x []uint8) []uint64) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x32ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Uint64x4, want func(x []uint16) []uint64) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x16ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Uint64x4, want func(x []uint32) []uint64) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToUint64x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x8ConvertLoToUint64x4(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Uint64x4, want func(x []uint64) []uint64) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]uint64, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int8x16) archsimd.Int32x4, want func(x []int8) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int16x8) archsimd.Int32x4, want func(x []int16) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x4ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int32x4) archsimd.Int32x4, want func(x []int32) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x2ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int64x2) archsimd.Int32x4, want func(x []int64) []int32) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Int32x4, want func(x []uint8) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Int32x4, want func(x []uint16) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x4ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Int32x4, want func(x []uint32) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x2ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Int32x4, want func(x []uint64) []int32) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x32ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int8x32) archsimd.Int32x4, want func(x []int8) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int16x16) archsimd.Int32x4, want func(x []int16) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int32x8) archsimd.Int32x4, want func(x []int32) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x4ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int64x4) archsimd.Int32x4, want func(x []int64) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x32ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Int32x4, want func(x []uint8) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Int32x4, want func(x []uint16) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Int32x4, want func(x []uint32) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x4ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Int32x4, want func(x []uint64) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x64ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int8x64) archsimd.Int32x4, want func(x []int8) []int32) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x32ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int16x32) archsimd.Int32x4, want func(x []int16) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int32x16) archsimd.Int32x4, want func(x []int32) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Int64x8) archsimd.Int32x4, want func(x []int64) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x64ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Int32x4, want func(x []uint8) []int32) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x32ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Int32x4, want func(x []uint16) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x16ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Int32x4, want func(x []uint32) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToInt32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x8ConvertLoToInt32x4(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Int32x4, want func(x []uint64) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]int32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int8x16) archsimd.Int32x8, want func(x []int8) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int16x8) archsimd.Int32x8, want func(x []int16) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x4ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int32x4) archsimd.Int32x8, want func(x []int32) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x2ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int64x2) archsimd.Int32x8, want func(x []int64) []int32) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Int32x8, want func(x []uint8) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Int32x8, want func(x []uint16) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x4ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Int32x8, want func(x []uint32) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x2ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Int32x8, want func(x []uint64) []int32) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x32ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int8x32) archsimd.Int32x8, want func(x []int8) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int16x16) archsimd.Int32x8, want func(x []int16) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int32x8) archsimd.Int32x8, want func(x []int32) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x4ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int64x4) archsimd.Int32x8, want func(x []int64) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x32ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Int32x8, want func(x []uint8) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Int32x8, want func(x []uint16) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Int32x8, want func(x []uint32) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x4ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Int32x8, want func(x []uint64) []int32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x64ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int8x64) archsimd.Int32x8, want func(x []int8) []int32) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x32ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int16x32) archsimd.Int32x8, want func(x []int16) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int32x16) archsimd.Int32x8, want func(x []int32) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Int64x8) archsimd.Int32x8, want func(x []int64) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x64ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Int32x8, want func(x []uint8) []int32) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x32ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Int32x8, want func(x []uint16) []int32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x16ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Int32x8, want func(x []uint32) []int32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToInt32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x8ConvertLoToInt32x8(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Int32x8, want func(x []uint64) []int32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]int32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int8x16) archsimd.Uint32x4, want func(x []int8) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int16x8) archsimd.Uint32x4, want func(x []int16) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x4ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int32x4) archsimd.Uint32x4, want func(x []int32) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x2ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int64x2) archsimd.Uint32x4, want func(x []int64) []uint32) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Uint32x4, want func(x []uint8) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Uint32x4, want func(x []uint16) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x4ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Uint32x4, want func(x []uint32) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x2ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Uint32x4, want func(x []uint64) []uint32) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x32ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int8x32) archsimd.Uint32x4, want func(x []int8) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int16x16) archsimd.Uint32x4, want func(x []int16) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int32x8) archsimd.Uint32x4, want func(x []int32) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x4ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int64x4) archsimd.Uint32x4, want func(x []int64) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x32ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Uint32x4, want func(x []uint8) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Uint32x4, want func(x []uint16) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Uint32x4, want func(x []uint32) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x4ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Uint32x4, want func(x []uint64) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt8x64ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int8x64) archsimd.Uint32x4, want func(x []int8) []uint32) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt16x32ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int16x32) archsimd.Uint32x4, want func(x []int16) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt32x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int32x16) archsimd.Uint32x4, want func(x []int32) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testInt64x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Int64x8) archsimd.Uint32x4, want func(x []int64) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint8x64ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Uint32x4, want func(x []uint8) []uint32) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint16x32ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Uint32x4, want func(x []uint16) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint32x16ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Uint32x4, want func(x []uint32) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToUint32x4 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 4 elements.
+func testUint64x8ConvertLoToUint32x4(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Uint32x4, want func(x []uint64) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]uint32, 4)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int8x16) archsimd.Uint32x8, want func(x []int8) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int16x8) archsimd.Uint32x8, want func(x []int16) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x4ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int32x4) archsimd.Uint32x8, want func(x []int32) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x2ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int64x2) archsimd.Uint32x8, want func(x []int64) []uint32) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Uint32x8, want func(x []uint8) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Uint32x8, want func(x []uint16) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x4ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Uint32x8, want func(x []uint32) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x2ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Uint32x8, want func(x []uint64) []uint32) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x32ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int8x32) archsimd.Uint32x8, want func(x []int8) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int16x16) archsimd.Uint32x8, want func(x []int16) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int32x8) archsimd.Uint32x8, want func(x []int32) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x4ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int64x4) archsimd.Uint32x8, want func(x []int64) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x32ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Uint32x8, want func(x []uint8) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Uint32x8, want func(x []uint16) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Uint32x8, want func(x []uint32) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x4ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Uint32x8, want func(x []uint64) []uint32) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x64ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int8x64) archsimd.Uint32x8, want func(x []int8) []uint32) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x32ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int16x32) archsimd.Uint32x8, want func(x []int16) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int32x16) archsimd.Uint32x8, want func(x []int32) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Int64x8) archsimd.Uint32x8, want func(x []int64) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x64ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Uint32x8, want func(x []uint8) []uint32) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x32ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Uint32x8, want func(x []uint16) []uint32) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x16ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Uint32x8, want func(x []uint32) []uint32) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToUint32x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x8ConvertLoToUint32x8(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Uint32x8, want func(x []uint64) []uint32) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]uint32, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int8x16) archsimd.Int16x8, want func(x []int8) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int16x8) archsimd.Int16x8, want func(x []int16) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x4ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int32x4) archsimd.Int16x8, want func(x []int32) []int16) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x2ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int64x2) archsimd.Int16x8, want func(x []int64) []int16) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Int16x8, want func(x []uint8) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Int16x8, want func(x []uint16) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x4ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Int16x8, want func(x []uint32) []int16) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x2ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Int16x8, want func(x []uint64) []int16) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x32ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int8x32) archsimd.Int16x8, want func(x []int8) []int16) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int16x16) archsimd.Int16x8, want func(x []int16) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int32x8) archsimd.Int16x8, want func(x []int32) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x4ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int64x4) archsimd.Int16x8, want func(x []int64) []int16) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x32ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Int16x8, want func(x []uint8) []int16) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Int16x8, want func(x []uint16) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Int16x8, want func(x []uint32) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x4ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Int16x8, want func(x []uint64) []int16) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x64ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int8x64) archsimd.Int16x8, want func(x []int8) []int16) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x32ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int16x32) archsimd.Int16x8, want func(x []int16) []int16) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int32x16) archsimd.Int16x8, want func(x []int32) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Int64x8) archsimd.Int16x8, want func(x []int64) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x64ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Int16x8, want func(x []uint8) []int16) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x32ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Int16x8, want func(x []uint16) []int16) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x16ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Int16x8, want func(x []uint32) []int16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToInt16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x8ConvertLoToInt16x8(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Int16x8, want func(x []uint64) []int16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]int16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int8x16) archsimd.Uint16x8, want func(x []int8) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int16x8) archsimd.Uint16x8, want func(x []int16) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x4ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x4ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int32x4) archsimd.Uint16x8, want func(x []int32) []uint16) {
+       n := 4
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x4Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x2ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x2ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int64x2) archsimd.Uint16x8, want func(x []int64) []uint16) {
+       n := 2
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x2Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint8x16) archsimd.Uint16x8, want func(x []uint8) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint16x8) archsimd.Uint16x8, want func(x []uint16) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x4ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x4ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint32x4) archsimd.Uint16x8, want func(x []uint32) []uint16) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x4Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x2ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x2ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint64x2) archsimd.Uint16x8, want func(x []uint64) []uint16) {
+       n := 2
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x2Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x32ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x32ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int8x32) archsimd.Uint16x8, want func(x []int8) []uint16) {
+       n := 32
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x32Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int16x16) archsimd.Uint16x8, want func(x []int16) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int32x8) archsimd.Uint16x8, want func(x []int32) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x4ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x4ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int64x4) archsimd.Uint16x8, want func(x []int64) []uint16) {
+       n := 4
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x4Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x32ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x32ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint8x32) archsimd.Uint16x8, want func(x []uint8) []uint16) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x32Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint16x16) archsimd.Uint16x8, want func(x []uint16) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint32x8) archsimd.Uint16x8, want func(x []uint32) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x4ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x4ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint64x4) archsimd.Uint16x8, want func(x []uint64) []uint16) {
+       n := 4
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x4Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt8x64ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt8x64ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int8x64) archsimd.Uint16x8, want func(x []int8) []uint16) {
+       n := 64
+       t.Helper()
+       forSlice(t, int8s, n, func(x []int8) bool {
+               t.Helper()
+               a := archsimd.LoadInt8x64Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt16x32ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt16x32ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int16x32) archsimd.Uint16x8, want func(x []int16) []uint16) {
+       n := 32
+       t.Helper()
+       forSlice(t, int16s, n, func(x []int16) bool {
+               t.Helper()
+               a := archsimd.LoadInt16x32Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt32x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt32x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int32x16) archsimd.Uint16x8, want func(x []int32) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, int32s, n, func(x []int32) bool {
+               t.Helper()
+               a := archsimd.LoadInt32x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testInt64x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testInt64x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Int64x8) archsimd.Uint16x8, want func(x []int64) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, int64s, n, func(x []int64) bool {
+               t.Helper()
+               a := archsimd.LoadInt64x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint8x64ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint8x64ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint8x64) archsimd.Uint16x8, want func(x []uint8) []uint16) {
+       n := 64
+       t.Helper()
+       forSlice(t, uint8s, n, func(x []uint8) bool {
+               t.Helper()
+               a := archsimd.LoadUint8x64Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint16x32ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint16x32ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint16x32) archsimd.Uint16x8, want func(x []uint16) []uint16) {
+       n := 32
+       t.Helper()
+       forSlice(t, uint16s, n, func(x []uint16) bool {
+               t.Helper()
+               a := archsimd.LoadUint16x32Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint32x16ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint32x16ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint32x16) archsimd.Uint16x8, want func(x []uint32) []uint16) {
+       n := 16
+       t.Helper()
+       forSlice(t, uint32s, n, func(x []uint32) bool {
+               t.Helper()
+               a := archsimd.LoadUint32x16Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
+// testUint64x8ConvertLoToUint16x8 tests the simd conversion method f against the expected behavior generated by want.
+// This converts only the low 8 elements.
+func testUint64x8ConvertLoToUint16x8(t *testing.T, f func(x archsimd.Uint64x8) archsimd.Uint16x8, want func(x []uint64) []uint16) {
+       n := 8
+       t.Helper()
+       forSlice(t, uint64s, n, func(x []uint64) bool {
+               t.Helper()
+               a := archsimd.LoadUint64x8Slice(x)
+               g := make([]uint16, 8)
+               f(a).StoreSlice(g)
+               w := want(x)
+               return checkSlicesLogInput(t, g, w, 0.0, func() { t.Helper(); t.Logf("x=%v", x) })
+       })
+}
+
 // testFloat32x4UnaryFlaky tests the simd unary method f against the expected behavior generated by want,
 // but using a flakiness parameter because we haven't exactly figured out how simd floating point works
 func testFloat32x4UnaryFlaky(t *testing.T, f func(x archsimd.Float32x4) archsimd.Float32x4, want func(x []float32) []float32, flakiness float64) {
index b6d814a405649ea6b02fe243e9e471a585028fcf..5d00eba03dad0659401457e9c9248e8cdb404e1f 100644 (file)
@@ -200,6 +200,35 @@ func TestExtend(t *testing.T) {
        }
 }
 
+func TestExtendLo(t *testing.T) {
+       testInt8x16ConvertLoToInt64x2(t, archsimd.Int8x16.ExtendLo2ToInt64, map1n[int8](toInt64, 2))
+       testInt16x8ConvertLoToInt64x2(t, archsimd.Int16x8.ExtendLo2ToInt64, map1n[int16](toInt64, 2))
+       testInt32x4ConvertLoToInt64x2(t, archsimd.Int32x4.ExtendLo2ToInt64, map1n[int32](toInt64, 2))
+       testUint8x16ConvertLoToUint64x2(t, archsimd.Uint8x16.ExtendLo2ToUint64, map1n[uint8](toUint64, 2))
+       testUint16x8ConvertLoToUint64x2(t, archsimd.Uint16x8.ExtendLo2ToUint64, map1n[uint16](toUint64, 2))
+       testUint32x4ConvertLoToUint64x2(t, archsimd.Uint32x4.ExtendLo2ToUint64, map1n[uint32](toUint64, 2))
+       testInt8x16ConvertLoToInt32x4(t, archsimd.Int8x16.ExtendLo4ToInt32, map1n[int8](toInt32, 4))
+       testInt16x8ConvertLoToInt32x4(t, archsimd.Int16x8.ExtendLo4ToInt32, map1n[int16](toInt32, 4))
+       testUint8x16ConvertLoToUint32x4(t, archsimd.Uint8x16.ExtendLo4ToUint32, map1n[uint8](toUint32, 4))
+       testUint16x8ConvertLoToUint32x4(t, archsimd.Uint16x8.ExtendLo4ToUint32, map1n[uint16](toUint32, 4))
+       testInt8x16ConvertLoToInt16x8(t, archsimd.Int8x16.ExtendLo8ToInt16, map1n[int8](toInt16, 8))
+       testUint8x16ConvertLoToUint16x8(t, archsimd.Uint8x16.ExtendLo8ToUint16, map1n[uint8](toUint16, 8))
+
+       if archsimd.X86.AVX2() {
+               testInt8x16ConvertLoToInt64x4(t, archsimd.Int8x16.ExtendLo4ToInt64, map1n[int8](toInt64, 4))
+               testInt16x8ConvertLoToInt64x4(t, archsimd.Int16x8.ExtendLo4ToInt64, map1n[int16](toInt64, 4))
+               testUint8x16ConvertLoToUint64x4(t, archsimd.Uint8x16.ExtendLo4ToUint64, map1n[uint8](toUint64, 4))
+               testUint16x8ConvertLoToUint64x4(t, archsimd.Uint16x8.ExtendLo4ToUint64, map1n[uint16](toUint64, 4))
+               testInt8x16ConvertLoToInt32x8(t, archsimd.Int8x16.ExtendLo8ToInt32, map1n[int8](toInt32, 8))
+               testUint8x16ConvertLoToUint32x8(t, archsimd.Uint8x16.ExtendLo8ToUint32, map1n[uint8](toUint32, 8))
+       }
+
+       if archsimd.X86.AVX512() {
+               testInt8x16ConvertToInt64(t, archsimd.Int8x16.ExtendLo8ToInt64, map1n[int8](toInt64, 8))
+               testUint8x16ConvertToUint64(t, archsimd.Uint8x16.ExtendLo8ToUint64, map1n[uint8](toUint64, 8))
+       }
+}
+
 func TestTruncate(t *testing.T) {
        if archsimd.X86.AVX512() {
                testInt16x8ConvertToInt8(t, archsimd.Int16x8.TruncateToInt8, map1n[int16](toInt8, 16))