35#ifndef _BLAZE_MATH_SIMD_PROD_H_
36#define _BLAZE_MATH_SIMD_PROD_H_
67#if BLAZE_AVX512BW_MODE
68 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
69 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15] *
70 (*a)[16] * (*a)[17] * (*a)[18] * (*a)[19] * (*a)[20] * (*a)[21] * (*a)[22] * (*a)[23] *
71 (*a)[24] * (*a)[25] * (*a)[26] * (*a)[27] * (*a)[28] * (*a)[29] * (*a)[30] * (*a)[31] *
72 (*a)[32] * (*a)[33] * (*a)[34] * (*a)[35] * (*a)[36] * (*a)[37] * (*a)[38] * (*a)[39] *
73 (*a)[40] * (*a)[41] * (*a)[42] * (*a)[43] * (*a)[44] * (*a)[45] * (*a)[46] * (*a)[47] *
74 (*a)[48] * (*a)[49] * (*a)[50] * (*a)[51] * (*a)[52] * (*a)[53] * (*a)[54] * (*a)[55] *
75 (*a)[56] * (*a)[57] * (*a)[58] * (*a)[59] * (*a)[60] * (*a)[61] * (*a)[62] * (*a)[63];
77 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
78 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15] *
79 (*a)[16] * (*a)[17] * (*a)[18] * (*a)[19] * (*a)[20] * (*a)[21] * (*a)[22] * (*a)[23] *
80 (*a)[24] * (*a)[25] * (*a)[26] * (*a)[27] * (*a)[28] * (*a)[29] * (*a)[30] * (*a)[31];
82 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
83 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15];
101#if BLAZE_AVX512BW_MODE
102 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
103 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15] *
104 (*a)[16] * (*a)[17] * (*a)[18] * (*a)[19] * (*a)[20] * (*a)[21] * (*a)[22] * (*a)[23] *
105 (*a)[24] * (*a)[25] * (*a)[26] * (*a)[27] * (*a)[28] * (*a)[29] * (*a)[30] * (*a)[31];
107 return (*a)[0] * (*a)[1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
108 (*a)[8] * (*a)[9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15];
110 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3] * (*a)[4] * (*a)[5] * (*a)[6] * (*a)[7];
133template<
typename T >
136#if BLAZE_AVX512BW_MODE
137 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
138 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15] *
139 (*a)[16] * (*a)[17] * (*a)[18] * (*a)[19] * (*a)[20] * (*a)[21] * (*a)[22] * (*a)[23] *
140 (*a)[24] * (*a)[25] * (*a)[26] * (*a)[27] * (*a)[28] * (*a)[29] * (*a)[30] * (*a)[31];
142 return (*a)[ 0] * (*a)[ 1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
143 (*a)[ 8] * (*a)[ 9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15];
145 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3] * (*a)[4] * (*a)[5] * (*a)[6] * (*a)[7];
160template<
typename T >
163#if BLAZE_AVX512BW_MODE
164 return (*a)[0] * (*a)[1] * (*a)[ 2] * (*a)[ 3] * (*a)[ 4] * (*a)[ 5] * (*a)[ 6] * (*a)[ 7] *
165 (*a)[8] * (*a)[9] * (*a)[10] * (*a)[11] * (*a)[12] * (*a)[13] * (*a)[14] * (*a)[15];
167 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3] * (*a)[4] * (*a)[5] * (*a)[6] * (*a)[7];
169 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3];
192template<
typename T >
195#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
196 return _mm512_reduce_mul_epi32( (*a).value );
198 const __m256i b( _mm256_mullo_epi32( (*a).value, _mm256_shuffle_epi32( (*a).value, _MM_SHUFFLE(1,0,3,2) ) ) );
199 const __m256i c( _mm256_mullo_epi32( b, _mm256_shuffle_epi32( b, _MM_SHUFFLE(2,3,0,1) ) ) );
200 const __m128i d( _mm_mullo_epi32( _mm256_extracti128_si256( c, 1 ), _mm256_castsi256_si128( c ) ) );
201 return _mm_extract_epi32( d, 0 );
203 const __m128i b( _mm_mullo_epi32( (*a).value, _mm_shuffle_epi32( (*a).value, _MM_SHUFFLE(1,0,3,2) ) ) );
204 return _mm_extract_epi32( _mm_mullo_epi32( b, _mm_shuffle_epi32( b, 1U ) ), 0 );
206 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3];
221template<
typename T >
224#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
225 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3] * (*a)[4] * (*a)[5] * (*a)[6] * (*a)[7];
227 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3];
229 return (*a)[0] * (*a)[1];
252template<
typename T >
255#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
256 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3] * (*a)[4] * (*a)[5] * (*a)[6] * (*a)[7];
258 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3];
260 return (*a)[0] * (*a)[1];
275template<
typename T >
278#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
279 return (*a)[0] * (*a)[1] * (*a)[2] * (*a)[3];
281 return (*a)[0] * (*a)[1];
308#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
309 return _mm512_reduce_mul_ps( a.value );
311 const __m256 b( _mm256_mul_ps( a.value, _mm256_permute2f128_ps( a.value, a.value, 1 ) ) );
312 const __m256 c( _mm256_mul_ps( b, _mm256_shuffle_ps( b, b, _MM_SHUFFLE(1,0,3,2) ) ) );
313 return _mm_cvtss_f32( _mm256_castps256_ps128( _mm256_mul_ps( c, _mm256_shuffle_ps( c, c, 1 ) ) ) );
315 const __m128 b = _mm_mul_ps( a.value, _mm_movehl_ps( a.value, a.value ) );
316 return _mm_cvtss_f32( _mm_mul_ss( b, _mm_shuffle_ps( b, b, 1U ) ) );
333#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
334 return a[0] * a[1] * a[2] * a[3] * a[4] * a[5] * a[6] * a[7];
336 return a[0] * a[1] * a[2] * a[3];
363#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
364 return _mm512_reduce_mul_pd( a.value );
366 const __m256d b( _mm256_mul_pd( a.value, _mm256_permute2f128_pd( a.value, a.value, 1 ) ) );
367 return _mm_cvtsd_f64( _mm256_castpd256_pd128( _mm256_mul_pd( b, _mm256_shuffle_pd( b, b, 1 ) ) ) );
369 return _mm_cvtsd_f64( _mm_mul_sd( a.value, _mm_unpackhi_pd( a.value, a.value ) ) );
386#if BLAZE_AVX512F_MODE || BLAZE_MIC_MODE
387 return a[0] * a[1] * a[2] * a[3];
Header file for auxiliary alias declarations.
typename T::ValueType ValueType_t
Alias declaration for nested ValueType type definitions.
Definition: Aliases.h:570
Header file for the basic SIMD types.
SIMD type for 64-bit double precision complex values.
SIMD type for 32-bit single precision complex values.
SIMD type for 64-bit double precision floating point data values.
SIMD type for 32-bit single precision floating point data values.
BLAZE_ALWAYS_INLINE const complex< double > prod(const SIMDcdouble &a) noexcept
Returns the product of all elements in the double precision complex SIMD vector.
Definition: Prod.h:384
#define BLAZE_ALWAYS_INLINE
Platform dependent setup of an enforced inline keyword.
Definition: Inline.h:85
System settings for the inline keywords.
System settings for the SSE mode.