NSIMD documentation
Index | Tutorial | FAQ | Contribute | API overview | API reference | Wrapped intrinsics | Modules

Load array of structure

Description

Load array of structures of 2 members from aligned memory.

C base API (generic)

#define vload2a(a0, type)
#define vload2a_e(a0, type, simd_ext)

C advanced API (generic, requires C11)

#define nsimd_load2a(a0)

C++ base API (generic)

template <NSIMD_CONCEPT_VALUE_TYPE T> typename simd_traits<T, NSIMD_SIMD>::simd_vectorx2 NSIMD_VECTORCALL load2a(T const* a0, T);

C++ advanced API

template <NSIMD_CONCEPT_VALUE_TYPE T, NSIMD_CONCEPT_SIMD_EXT SimdExt> packx2<T, 1, SimdExt> load2a(packx2<T, 1, SimdExt> const&, T const* a0);
template <NSIMD_CONCEPT_VALUE_TYPE T, int N, NSIMD_CONCEPT_SIMD_EXT SimdExt> packx2<T, N, SimdExt> load2a(packx2<T, N, SimdExt> const&, T const* a0);
template <NSIMD_CONCEPT_PACKX2 SimdVector, NSIMD_CONCEPT_VALUE_TYPE T>NSIMD_REQUIRES((std::is_same_v<typename SimdVector::value_type, T>)) SimdVector load2a(T const* a0);

C base API (architecture specifics)

AVX2

nsimd_avx2_vf64x2 NSIMD_VECTORCALL nsimd_load2a_avx2_f64(f64 const* a0);
nsimd_avx2_vf32x2 NSIMD_VECTORCALL nsimd_load2a_avx2_f32(f32 const* a0);
nsimd_avx2_vf16x2 NSIMD_VECTORCALL nsimd_load2a_avx2_f16(f16 const* a0);
nsimd_avx2_vi64x2 NSIMD_VECTORCALL nsimd_load2a_avx2_i64(i64 const* a0);
nsimd_avx2_vi32x2 NSIMD_VECTORCALL nsimd_load2a_avx2_i32(i32 const* a0);
nsimd_avx2_vi16x2 NSIMD_VECTORCALL nsimd_load2a_avx2_i16(i16 const* a0);
nsimd_avx2_vi8x2 NSIMD_VECTORCALL nsimd_load2a_avx2_i8(i8 const* a0);
nsimd_avx2_vu64x2 NSIMD_VECTORCALL nsimd_load2a_avx2_u64(u64 const* a0);
nsimd_avx2_vu32x2 NSIMD_VECTORCALL nsimd_load2a_avx2_u32(u32 const* a0);
nsimd_avx2_vu16x2 NSIMD_VECTORCALL nsimd_load2a_avx2_u16(u16 const* a0);
nsimd_avx2_vu8x2 NSIMD_VECTORCALL nsimd_load2a_avx2_u8(u8 const* a0);

SVE512

nsimd_sve512_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve512_f64(f64 const* a0);
nsimd_sve512_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve512_f32(f32 const* a0);
nsimd_sve512_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve512_f16(f16 const* a0);
nsimd_sve512_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve512_i64(i64 const* a0);
nsimd_sve512_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve512_i32(i32 const* a0);
nsimd_sve512_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve512_i16(i16 const* a0);
nsimd_sve512_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve512_i8(i8 const* a0);
nsimd_sve512_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve512_u64(u64 const* a0);
nsimd_sve512_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve512_u32(u32 const* a0);
nsimd_sve512_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve512_u16(u16 const* a0);
nsimd_sve512_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve512_u8(u8 const* a0);

SVE

nsimd_sve_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve_f64(f64 const* a0);
nsimd_sve_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve_f32(f32 const* a0);
nsimd_sve_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve_f16(f16 const* a0);
nsimd_sve_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve_i64(i64 const* a0);
nsimd_sve_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve_i32(i32 const* a0);
nsimd_sve_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve_i16(i16 const* a0);
nsimd_sve_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve_i8(i8 const* a0);
nsimd_sve_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve_u64(u64 const* a0);
nsimd_sve_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve_u32(u32 const* a0);
nsimd_sve_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve_u16(u16 const* a0);
nsimd_sve_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve_u8(u8 const* a0);

CPU

nsimd_cpu_vf64x2 NSIMD_VECTORCALL nsimd_load2a_cpu_f64(f64 const* a0);
nsimd_cpu_vf32x2 NSIMD_VECTORCALL nsimd_load2a_cpu_f32(f32 const* a0);
nsimd_cpu_vf16x2 NSIMD_VECTORCALL nsimd_load2a_cpu_f16(f16 const* a0);
nsimd_cpu_vi64x2 NSIMD_VECTORCALL nsimd_load2a_cpu_i64(i64 const* a0);
nsimd_cpu_vi32x2 NSIMD_VECTORCALL nsimd_load2a_cpu_i32(i32 const* a0);
nsimd_cpu_vi16x2 NSIMD_VECTORCALL nsimd_load2a_cpu_i16(i16 const* a0);
nsimd_cpu_vi8x2 NSIMD_VECTORCALL nsimd_load2a_cpu_i8(i8 const* a0);
nsimd_cpu_vu64x2 NSIMD_VECTORCALL nsimd_load2a_cpu_u64(u64 const* a0);
nsimd_cpu_vu32x2 NSIMD_VECTORCALL nsimd_load2a_cpu_u32(u32 const* a0);
nsimd_cpu_vu16x2 NSIMD_VECTORCALL nsimd_load2a_cpu_u16(u16 const* a0);
nsimd_cpu_vu8x2 NSIMD_VECTORCALL nsimd_load2a_cpu_u8(u8 const* a0);

SVE2048

nsimd_sve2048_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_f64(f64 const* a0);
nsimd_sve2048_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_f32(f32 const* a0);
nsimd_sve2048_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_f16(f16 const* a0);
nsimd_sve2048_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_i64(i64 const* a0);
nsimd_sve2048_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_i32(i32 const* a0);
nsimd_sve2048_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_i16(i16 const* a0);
nsimd_sve2048_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_i8(i8 const* a0);
nsimd_sve2048_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_u64(u64 const* a0);
nsimd_sve2048_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_u32(u32 const* a0);
nsimd_sve2048_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_u16(u16 const* a0);
nsimd_sve2048_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve2048_u8(u8 const* a0);

NEON128

nsimd_neon128_vf64x2 NSIMD_VECTORCALL nsimd_load2a_neon128_f64(f64 const* a0);
nsimd_neon128_vf32x2 NSIMD_VECTORCALL nsimd_load2a_neon128_f32(f32 const* a0);
nsimd_neon128_vf16x2 NSIMD_VECTORCALL nsimd_load2a_neon128_f16(f16 const* a0);
nsimd_neon128_vi64x2 NSIMD_VECTORCALL nsimd_load2a_neon128_i64(i64 const* a0);
nsimd_neon128_vi32x2 NSIMD_VECTORCALL nsimd_load2a_neon128_i32(i32 const* a0);
nsimd_neon128_vi16x2 NSIMD_VECTORCALL nsimd_load2a_neon128_i16(i16 const* a0);
nsimd_neon128_vi8x2 NSIMD_VECTORCALL nsimd_load2a_neon128_i8(i8 const* a0);
nsimd_neon128_vu64x2 NSIMD_VECTORCALL nsimd_load2a_neon128_u64(u64 const* a0);
nsimd_neon128_vu32x2 NSIMD_VECTORCALL nsimd_load2a_neon128_u32(u32 const* a0);
nsimd_neon128_vu16x2 NSIMD_VECTORCALL nsimd_load2a_neon128_u16(u16 const* a0);
nsimd_neon128_vu8x2 NSIMD_VECTORCALL nsimd_load2a_neon128_u8(u8 const* a0);

AVX512_SKYLAKE

nsimd_avx512_skylake_vf64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_f64(f64 const* a0);
nsimd_avx512_skylake_vf32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_f32(f32 const* a0);
nsimd_avx512_skylake_vf16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_f16(f16 const* a0);
nsimd_avx512_skylake_vi64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_i64(i64 const* a0);
nsimd_avx512_skylake_vi32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_i32(i32 const* a0);
nsimd_avx512_skylake_vi16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_i16(i16 const* a0);
nsimd_avx512_skylake_vi8x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_i8(i8 const* a0);
nsimd_avx512_skylake_vu64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_u64(u64 const* a0);
nsimd_avx512_skylake_vu32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_u32(u32 const* a0);
nsimd_avx512_skylake_vu16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_u16(u16 const* a0);
nsimd_avx512_skylake_vu8x2 NSIMD_VECTORCALL nsimd_load2a_avx512_skylake_u8(u8 const* a0);

AARCH64

nsimd_aarch64_vf64x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_f64(f64 const* a0);
nsimd_aarch64_vf32x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_f32(f32 const* a0);
nsimd_aarch64_vf16x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_f16(f16 const* a0);
nsimd_aarch64_vi64x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_i64(i64 const* a0);
nsimd_aarch64_vi32x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_i32(i32 const* a0);
nsimd_aarch64_vi16x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_i16(i16 const* a0);
nsimd_aarch64_vi8x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_i8(i8 const* a0);
nsimd_aarch64_vu64x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_u64(u64 const* a0);
nsimd_aarch64_vu32x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_u32(u32 const* a0);
nsimd_aarch64_vu16x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_u16(u16 const* a0);
nsimd_aarch64_vu8x2 NSIMD_VECTORCALL nsimd_load2a_aarch64_u8(u8 const* a0);

AVX512_KNL

nsimd_avx512_knl_vf64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_f64(f64 const* a0);
nsimd_avx512_knl_vf32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_f32(f32 const* a0);
nsimd_avx512_knl_vf16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_f16(f16 const* a0);
nsimd_avx512_knl_vi64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_i64(i64 const* a0);
nsimd_avx512_knl_vi32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_i32(i32 const* a0);
nsimd_avx512_knl_vi16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_i16(i16 const* a0);
nsimd_avx512_knl_vi8x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_i8(i8 const* a0);
nsimd_avx512_knl_vu64x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_u64(u64 const* a0);
nsimd_avx512_knl_vu32x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_u32(u32 const* a0);
nsimd_avx512_knl_vu16x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_u16(u16 const* a0);
nsimd_avx512_knl_vu8x2 NSIMD_VECTORCALL nsimd_load2a_avx512_knl_u8(u8 const* a0);

SSE2

nsimd_sse2_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sse2_f64(f64 const* a0);
nsimd_sse2_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sse2_f32(f32 const* a0);
nsimd_sse2_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sse2_f16(f16 const* a0);
nsimd_sse2_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sse2_i64(i64 const* a0);
nsimd_sse2_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sse2_i32(i32 const* a0);
nsimd_sse2_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sse2_i16(i16 const* a0);
nsimd_sse2_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sse2_i8(i8 const* a0);
nsimd_sse2_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sse2_u64(u64 const* a0);
nsimd_sse2_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sse2_u32(u32 const* a0);
nsimd_sse2_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sse2_u16(u16 const* a0);
nsimd_sse2_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sse2_u8(u8 const* a0);

SSE42

nsimd_sse42_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sse42_f64(f64 const* a0);
nsimd_sse42_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sse42_f32(f32 const* a0);
nsimd_sse42_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sse42_f16(f16 const* a0);
nsimd_sse42_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sse42_i64(i64 const* a0);
nsimd_sse42_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sse42_i32(i32 const* a0);
nsimd_sse42_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sse42_i16(i16 const* a0);
nsimd_sse42_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sse42_i8(i8 const* a0);
nsimd_sse42_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sse42_u64(u64 const* a0);
nsimd_sse42_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sse42_u32(u32 const* a0);
nsimd_sse42_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sse42_u16(u16 const* a0);
nsimd_sse42_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sse42_u8(u8 const* a0);

SVE256

nsimd_sve256_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve256_f64(f64 const* a0);
nsimd_sve256_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve256_f32(f32 const* a0);
nsimd_sve256_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve256_f16(f16 const* a0);
nsimd_sve256_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve256_i64(i64 const* a0);
nsimd_sve256_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve256_i32(i32 const* a0);
nsimd_sve256_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve256_i16(i16 const* a0);
nsimd_sve256_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve256_i8(i8 const* a0);
nsimd_sve256_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve256_u64(u64 const* a0);
nsimd_sve256_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve256_u32(u32 const* a0);
nsimd_sve256_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve256_u16(u16 const* a0);
nsimd_sve256_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve256_u8(u8 const* a0);

SVE1024

nsimd_sve1024_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_f64(f64 const* a0);
nsimd_sve1024_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_f32(f32 const* a0);
nsimd_sve1024_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_f16(f16 const* a0);
nsimd_sve1024_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_i64(i64 const* a0);
nsimd_sve1024_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_i32(i32 const* a0);
nsimd_sve1024_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_i16(i16 const* a0);
nsimd_sve1024_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_i8(i8 const* a0);
nsimd_sve1024_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_u64(u64 const* a0);
nsimd_sve1024_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_u32(u32 const* a0);
nsimd_sve1024_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_u16(u16 const* a0);
nsimd_sve1024_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve1024_u8(u8 const* a0);

VSX

nsimd_vsx_vf64x2 NSIMD_VECTORCALL nsimd_load2a_vsx_f64(f64 const* a0);
nsimd_vsx_vf32x2 NSIMD_VECTORCALL nsimd_load2a_vsx_f32(f32 const* a0);
nsimd_vsx_vf16x2 NSIMD_VECTORCALL nsimd_load2a_vsx_f16(f16 const* a0);
nsimd_vsx_vi64x2 NSIMD_VECTORCALL nsimd_load2a_vsx_i64(i64 const* a0);
nsimd_vsx_vi32x2 NSIMD_VECTORCALL nsimd_load2a_vsx_i32(i32 const* a0);
nsimd_vsx_vi16x2 NSIMD_VECTORCALL nsimd_load2a_vsx_i16(i16 const* a0);
nsimd_vsx_vi8x2 NSIMD_VECTORCALL nsimd_load2a_vsx_i8(i8 const* a0);
nsimd_vsx_vu64x2 NSIMD_VECTORCALL nsimd_load2a_vsx_u64(u64 const* a0);
nsimd_vsx_vu32x2 NSIMD_VECTORCALL nsimd_load2a_vsx_u32(u32 const* a0);
nsimd_vsx_vu16x2 NSIMD_VECTORCALL nsimd_load2a_vsx_u16(u16 const* a0);
nsimd_vsx_vu8x2 NSIMD_VECTORCALL nsimd_load2a_vsx_u8(u8 const* a0);

SVE128

nsimd_sve128_vf64x2 NSIMD_VECTORCALL nsimd_load2a_sve128_f64(f64 const* a0);
nsimd_sve128_vf32x2 NSIMD_VECTORCALL nsimd_load2a_sve128_f32(f32 const* a0);
nsimd_sve128_vf16x2 NSIMD_VECTORCALL nsimd_load2a_sve128_f16(f16 const* a0);
nsimd_sve128_vi64x2 NSIMD_VECTORCALL nsimd_load2a_sve128_i64(i64 const* a0);
nsimd_sve128_vi32x2 NSIMD_VECTORCALL nsimd_load2a_sve128_i32(i32 const* a0);
nsimd_sve128_vi16x2 NSIMD_VECTORCALL nsimd_load2a_sve128_i16(i16 const* a0);
nsimd_sve128_vi8x2 NSIMD_VECTORCALL nsimd_load2a_sve128_i8(i8 const* a0);
nsimd_sve128_vu64x2 NSIMD_VECTORCALL nsimd_load2a_sve128_u64(u64 const* a0);
nsimd_sve128_vu32x2 NSIMD_VECTORCALL nsimd_load2a_sve128_u32(u32 const* a0);
nsimd_sve128_vu16x2 NSIMD_VECTORCALL nsimd_load2a_sve128_u16(u16 const* a0);
nsimd_sve128_vu8x2 NSIMD_VECTORCALL nsimd_load2a_sve128_u8(u8 const* a0);

VMX

nsimd_vmx_vf64x2 NSIMD_VECTORCALL nsimd_load2a_vmx_f64(f64 const* a0);
nsimd_vmx_vf32x2 NSIMD_VECTORCALL nsimd_load2a_vmx_f32(f32 const* a0);
nsimd_vmx_vf16x2 NSIMD_VECTORCALL nsimd_load2a_vmx_f16(f16 const* a0);
nsimd_vmx_vi64x2 NSIMD_VECTORCALL nsimd_load2a_vmx_i64(i64 const* a0);
nsimd_vmx_vi32x2 NSIMD_VECTORCALL nsimd_load2a_vmx_i32(i32 const* a0);
nsimd_vmx_vi16x2 NSIMD_VECTORCALL nsimd_load2a_vmx_i16(i16 const* a0);
nsimd_vmx_vi8x2 NSIMD_VECTORCALL nsimd_load2a_vmx_i8(i8 const* a0);
nsimd_vmx_vu64x2 NSIMD_VECTORCALL nsimd_load2a_vmx_u64(u64 const* a0);
nsimd_vmx_vu32x2 NSIMD_VECTORCALL nsimd_load2a_vmx_u32(u32 const* a0);
nsimd_vmx_vu16x2 NSIMD_VECTORCALL nsimd_load2a_vmx_u16(u16 const* a0);
nsimd_vmx_vu8x2 NSIMD_VECTORCALL nsimd_load2a_vmx_u8(u8 const* a0);

AVX

nsimd_avx_vf64x2 NSIMD_VECTORCALL nsimd_load2a_avx_f64(f64 const* a0);
nsimd_avx_vf32x2 NSIMD_VECTORCALL nsimd_load2a_avx_f32(f32 const* a0);
nsimd_avx_vf16x2 NSIMD_VECTORCALL nsimd_load2a_avx_f16(f16 const* a0);
nsimd_avx_vi64x2 NSIMD_VECTORCALL nsimd_load2a_avx_i64(i64 const* a0);
nsimd_avx_vi32x2 NSIMD_VECTORCALL nsimd_load2a_avx_i32(i32 const* a0);
nsimd_avx_vi16x2 NSIMD_VECTORCALL nsimd_load2a_avx_i16(i16 const* a0);
nsimd_avx_vi8x2 NSIMD_VECTORCALL nsimd_load2a_avx_i8(i8 const* a0);
nsimd_avx_vu64x2 NSIMD_VECTORCALL nsimd_load2a_avx_u64(u64 const* a0);
nsimd_avx_vu32x2 NSIMD_VECTORCALL nsimd_load2a_avx_u32(u32 const* a0);
nsimd_avx_vu16x2 NSIMD_VECTORCALL nsimd_load2a_avx_u16(u16 const* a0);
nsimd_avx_vu8x2 NSIMD_VECTORCALL nsimd_load2a_avx_u8(u8 const* a0);

C++ base API (architecture specifics)

AVX2

nsimd_avx2_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, avx2);
nsimd_avx2_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, avx2);
nsimd_avx2_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, avx2);
nsimd_avx2_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, avx2);
nsimd_avx2_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, avx2);
nsimd_avx2_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, avx2);
nsimd_avx2_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, avx2);
nsimd_avx2_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, avx2);
nsimd_avx2_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, avx2);
nsimd_avx2_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, avx2);
nsimd_avx2_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, avx2);

SVE512

nsimd_sve512_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve512);
nsimd_sve512_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve512);
nsimd_sve512_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve512);
nsimd_sve512_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve512);
nsimd_sve512_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve512);
nsimd_sve512_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve512);
nsimd_sve512_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve512);
nsimd_sve512_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve512);
nsimd_sve512_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve512);
nsimd_sve512_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve512);
nsimd_sve512_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve512);

SVE

nsimd_sve_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve);
nsimd_sve_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve);
nsimd_sve_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve);
nsimd_sve_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve);
nsimd_sve_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve);
nsimd_sve_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve);
nsimd_sve_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve);
nsimd_sve_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve);
nsimd_sve_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve);
nsimd_sve_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve);
nsimd_sve_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve);

CPU

nsimd_cpu_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, cpu);
nsimd_cpu_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, cpu);
nsimd_cpu_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, cpu);
nsimd_cpu_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, cpu);
nsimd_cpu_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, cpu);
nsimd_cpu_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, cpu);
nsimd_cpu_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, cpu);
nsimd_cpu_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, cpu);
nsimd_cpu_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, cpu);
nsimd_cpu_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, cpu);
nsimd_cpu_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, cpu);

SVE2048

nsimd_sve2048_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve2048);
nsimd_sve2048_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve2048);
nsimd_sve2048_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve2048);
nsimd_sve2048_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve2048);
nsimd_sve2048_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve2048);
nsimd_sve2048_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve2048);
nsimd_sve2048_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve2048);
nsimd_sve2048_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve2048);
nsimd_sve2048_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve2048);
nsimd_sve2048_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve2048);
nsimd_sve2048_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve2048);

NEON128

nsimd_neon128_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, neon128);
nsimd_neon128_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, neon128);
nsimd_neon128_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, neon128);
nsimd_neon128_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, neon128);
nsimd_neon128_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, neon128);
nsimd_neon128_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, neon128);
nsimd_neon128_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, neon128);
nsimd_neon128_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, neon128);
nsimd_neon128_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, neon128);
nsimd_neon128_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, neon128);
nsimd_neon128_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, neon128);

AVX512_SKYLAKE

nsimd_avx512_skylake_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, avx512_skylake);
nsimd_avx512_skylake_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, avx512_skylake);
nsimd_avx512_skylake_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, avx512_skylake);
nsimd_avx512_skylake_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, avx512_skylake);
nsimd_avx512_skylake_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, avx512_skylake);
nsimd_avx512_skylake_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, avx512_skylake);
nsimd_avx512_skylake_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, avx512_skylake);
nsimd_avx512_skylake_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, avx512_skylake);
nsimd_avx512_skylake_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, avx512_skylake);
nsimd_avx512_skylake_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, avx512_skylake);
nsimd_avx512_skylake_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, avx512_skylake);

AARCH64

nsimd_aarch64_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, aarch64);
nsimd_aarch64_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, aarch64);
nsimd_aarch64_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, aarch64);
nsimd_aarch64_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, aarch64);
nsimd_aarch64_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, aarch64);
nsimd_aarch64_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, aarch64);
nsimd_aarch64_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, aarch64);
nsimd_aarch64_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, aarch64);
nsimd_aarch64_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, aarch64);
nsimd_aarch64_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, aarch64);
nsimd_aarch64_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, aarch64);

AVX512_KNL

nsimd_avx512_knl_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, avx512_knl);
nsimd_avx512_knl_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, avx512_knl);
nsimd_avx512_knl_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, avx512_knl);
nsimd_avx512_knl_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, avx512_knl);
nsimd_avx512_knl_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, avx512_knl);
nsimd_avx512_knl_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, avx512_knl);
nsimd_avx512_knl_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, avx512_knl);
nsimd_avx512_knl_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, avx512_knl);
nsimd_avx512_knl_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, avx512_knl);
nsimd_avx512_knl_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, avx512_knl);
nsimd_avx512_knl_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, avx512_knl);

SSE2

nsimd_sse2_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sse2);
nsimd_sse2_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sse2);
nsimd_sse2_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sse2);
nsimd_sse2_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sse2);
nsimd_sse2_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sse2);
nsimd_sse2_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sse2);
nsimd_sse2_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sse2);
nsimd_sse2_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sse2);
nsimd_sse2_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sse2);
nsimd_sse2_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sse2);
nsimd_sse2_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sse2);

SSE42

nsimd_sse42_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sse42);
nsimd_sse42_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sse42);
nsimd_sse42_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sse42);
nsimd_sse42_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sse42);
nsimd_sse42_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sse42);
nsimd_sse42_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sse42);
nsimd_sse42_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sse42);
nsimd_sse42_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sse42);
nsimd_sse42_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sse42);
nsimd_sse42_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sse42);
nsimd_sse42_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sse42);

SVE256

nsimd_sve256_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve256);
nsimd_sve256_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve256);
nsimd_sve256_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve256);
nsimd_sve256_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve256);
nsimd_sve256_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve256);
nsimd_sve256_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve256);
nsimd_sve256_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve256);
nsimd_sve256_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve256);
nsimd_sve256_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve256);
nsimd_sve256_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve256);
nsimd_sve256_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve256);

SVE1024

nsimd_sve1024_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve1024);
nsimd_sve1024_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve1024);
nsimd_sve1024_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve1024);
nsimd_sve1024_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve1024);
nsimd_sve1024_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve1024);
nsimd_sve1024_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve1024);
nsimd_sve1024_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve1024);
nsimd_sve1024_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve1024);
nsimd_sve1024_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve1024);
nsimd_sve1024_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve1024);
nsimd_sve1024_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve1024);

VSX

nsimd_vsx_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, vsx);
nsimd_vsx_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, vsx);
nsimd_vsx_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, vsx);
nsimd_vsx_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, vsx);
nsimd_vsx_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, vsx);
nsimd_vsx_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, vsx);
nsimd_vsx_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, vsx);
nsimd_vsx_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, vsx);
nsimd_vsx_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, vsx);
nsimd_vsx_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, vsx);
nsimd_vsx_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, vsx);

SVE128

nsimd_sve128_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, sve128);
nsimd_sve128_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, sve128);
nsimd_sve128_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, sve128);
nsimd_sve128_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, sve128);
nsimd_sve128_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, sve128);
nsimd_sve128_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, sve128);
nsimd_sve128_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, sve128);
nsimd_sve128_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, sve128);
nsimd_sve128_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, sve128);
nsimd_sve128_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, sve128);
nsimd_sve128_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, sve128);

VMX

nsimd_vmx_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, vmx);
nsimd_vmx_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, vmx);
nsimd_vmx_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, vmx);
nsimd_vmx_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, vmx);
nsimd_vmx_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, vmx);
nsimd_vmx_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, vmx);
nsimd_vmx_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, vmx);
nsimd_vmx_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, vmx);
nsimd_vmx_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, vmx);
nsimd_vmx_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, vmx);
nsimd_vmx_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, vmx);

AVX

nsimd_avx_vf64x2 NSIMD_VECTORCALL load2a(f64 const* a0, f64, avx);
nsimd_avx_vf32x2 NSIMD_VECTORCALL load2a(f32 const* a0, f32, avx);
nsimd_avx_vf16x2 NSIMD_VECTORCALL load2a(f16 const* a0, f16, avx);
nsimd_avx_vi64x2 NSIMD_VECTORCALL load2a(i64 const* a0, i64, avx);
nsimd_avx_vi32x2 NSIMD_VECTORCALL load2a(i32 const* a0, i32, avx);
nsimd_avx_vi16x2 NSIMD_VECTORCALL load2a(i16 const* a0, i16, avx);
nsimd_avx_vi8x2 NSIMD_VECTORCALL load2a(i8 const* a0, i8, avx);
nsimd_avx_vu64x2 NSIMD_VECTORCALL load2a(u64 const* a0, u64, avx);
nsimd_avx_vu32x2 NSIMD_VECTORCALL load2a(u32 const* a0, u32, avx);
nsimd_avx_vu16x2 NSIMD_VECTORCALL load2a(u16 const* a0, u16, avx);
nsimd_avx_vu8x2 NSIMD_VECTORCALL load2a(u8 const* a0, u8, avx);