// Code generated by 'tmplgen'; DO NOT EDIT. //go:build goexperiment.simd && arm64 // This file contains functions testing simd reduce methods. // Each function in this file is specialized for a // particular simd type x. package simd_test import ( "math" "simd/archsimd" "testing" ) func testInt8x16Reduce(t *testing.T, f func(_ archsimd.Int8x16) int8, want func(_ []int8) int8) { n := 16 t.Helper() forSlice(t, int8s, n, func(x []int8) bool { t.Helper() a := archsimd.LoadInt8x16(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testInt16x8Reduce(t *testing.T, f func(_ archsimd.Int16x8) int16, want func(_ []int16) int16) { n := 8 t.Helper() forSlice(t, int16s, n, func(x []int16) bool { t.Helper() a := archsimd.LoadInt16x8(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testInt32x4Reduce(t *testing.T, f func(_ archsimd.Int32x4) int32, want func(_ []int32) int32) { n := 4 t.Helper() forSlice(t, int32s, n, func(x []int32) bool { t.Helper() a := archsimd.LoadInt32x4(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testUint8x16Reduce(t *testing.T, f func(_ archsimd.Uint8x16) uint8, want func(_ []uint8) uint8) { n := 16 t.Helper() forSlice(t, uint8s, n, func(x []uint8) bool { t.Helper() a := archsimd.LoadUint8x16(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testUint16x8Reduce(t *testing.T, f func(_ archsimd.Uint16x8) uint16, want func(_ []uint16) uint16) { n := 8 t.Helper() forSlice(t, uint16s, n, func(x []uint16) bool { t.Helper() a := archsimd.LoadUint16x8(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testUint32x4Reduce(t *testing.T, f func(_ archsimd.Uint32x4) uint32, want func(_ []uint32) uint32) { n := 4 t.Helper() forSlice(t, uint32s, n, func(x []uint32) bool { t.Helper() a := archsimd.LoadUint32x4(x) g := f(a) w := want(x) if g != w { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) } func testFloat32x4Reduce(t *testing.T, f func(_ archsimd.Float32x4) float32, want func(_ []float32) float32) { n := 4 t.Helper() forSlice(t, float32s, n, func(x []float32) bool { t.Helper() a := archsimd.LoadFloat32x4(x) g := f(a) w := want(x) if g != w && !(math.IsNaN(float64(g)) && math.IsNaN(float64(w))) { t.Errorf("got %v, want %v, input %v", g, w, x) return false } return true }) }