15 #ifndef __IPSDKUTIL_INSTRUCTIONSET_LOGICAL_DETAIL_AVX_BITWISEANDREG_H__ 16 #define __IPSDKUTIL_INSTRUCTIONSET_LOGICAL_DETAIL_AVX_BITWISEANDREG_H__ 32 typename boost::enable_if_c<boost::is_integral<T>::value>::type>
34 static IPSDK_FORCEINLINE
43 static IPSDK_FORCEINLINE
51 COPY_IMM_TO_XMM(in1, in11, in12);
52 COPY_IMM_TO_XMM(in2, in21, in22);
53 __m128i out1 = _mm_and_si128(in11, in21);
54 __m128i out2 = _mm_and_si128(in12, in22);
55 COPY_XMM_TO_IMM(out1, out2, out);
62 static IPSDK_FORCEINLINE
67 return _mm256_and_ps(in1, in2);
70 static IPSDK_FORCEINLINE
76 out = _mm256_and_ps(in1, in2);
83 static IPSDK_FORCEINLINE
88 return _mm256_and_pd(in1, in2);
91 static IPSDK_FORCEINLINE
97 out = _mm256_and_pd(in1, in2);
108 #endif // __IPSDKUTIL_INSTRUCTIONSET_LOGICAL_DETAIL_AVX_BITWISEANDREG_H__ Defines the IPSDK_FORCEINLINE.
Functions to convert from 128 (resp. 256) bits registers to 256 (resp. 128) bits registers.
Main namespace for IPSDK library.
Definition: AlgorithmFunctionEfficiency.h:22
double ipReal64
Base types definition.
Definition: BaseTypes.h:57
Predefined types for Avx instruction set management.
eInstructionSet
Enumerate for processor instruction set description.
Definition: InstructionSetTypes.h:31
Advanced Vector Extensions.
Definition: InstructionSetTypes.h:44
Definition of import/export macro for library.
structure used to retrieve AVX type associated to a base type
Definition: AvxTypes.h:33
Definition: BitwiseAndReg.h:30
float ipReal32
Base types definition.
Definition: BaseTypes.h:56