WPILibC++ 2023.4.3
Complex.h
Go to the documentation of this file.
1// This file is part of Eigen, a lightweight C++ template library
2// for linear algebra.
3//
4// Copyright (C) 2014 Benoit Steiner (benoit.steiner.goog@gmail.com)
5//
6// This Source Code Form is subject to the terms of the Mozilla
7// Public License v. 2.0. If a copy of the MPL was not distributed
8// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10#ifndef EIGEN_COMPLEX_AVX_H
11#define EIGEN_COMPLEX_AVX_H
12
13namespace Eigen {
14
15namespace internal {
16
17//---------- float ----------
19{
21 EIGEN_STRONG_INLINE explicit Packet4cf(const __m256& a) : v(a) {}
22 __m256 v;
23};
24
25#ifndef EIGEN_VECTORIZE_AVX512
26template<> struct packet_traits<std::complex<float> > : default_packet_traits
27{
28 typedef Packet4cf type;
29 typedef Packet2cf half;
30 enum {
31 Vectorizable = 1,
33 size = 4,
34 HasHalfPacket = 1,
35
36 HasAdd = 1,
37 HasSub = 1,
38 HasMul = 1,
39 HasDiv = 1,
40 HasNegate = 1,
41 HasSqrt = 1,
42 HasAbs = 0,
43 HasAbs2 = 0,
44 HasMin = 0,
45 HasMax = 0,
46 HasSetLinear = 0
47 };
48};
49#endif
50
51template<> struct unpacket_traits<Packet4cf> {
52 typedef std::complex<float> type;
53 typedef Packet2cf half;
55 enum {
61 };
62};
63
64template<> EIGEN_STRONG_INLINE Packet4cf padd<Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_add_ps(a.v,b.v)); }
65template<> EIGEN_STRONG_INLINE Packet4cf psub<Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_sub_ps(a.v,b.v)); }
67{
68 return Packet4cf(pnegate(a.v));
69}
71{
72 const __m256 mask = _mm256_castsi256_ps(_mm256_setr_epi32(0x00000000,0x80000000,0x00000000,0x80000000,0x00000000,0x80000000,0x00000000,0x80000000));
73 return Packet4cf(_mm256_xor_ps(a.v,mask));
74}
75
77{
78 __m256 tmp1 = _mm256_mul_ps(_mm256_moveldup_ps(a.v), b.v);
79 __m256 tmp2 = _mm256_mul_ps(_mm256_movehdup_ps(a.v), _mm256_permute_ps(b.v, _MM_SHUFFLE(2,3,0,1)));
80 __m256 result = _mm256_addsub_ps(tmp1, tmp2);
81 return Packet4cf(result);
82}
83
84template <>
86 __m256 eq = _mm256_cmp_ps(a.v, b.v, _CMP_EQ_OQ);
87 return Packet4cf(_mm256_and_ps(eq, _mm256_permute_ps(eq, 0xb1)));
88}
89
91template<> EIGEN_STRONG_INLINE Packet4cf pand <Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_and_ps(a.v,b.v)); }
92template<> EIGEN_STRONG_INLINE Packet4cf por <Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_or_ps(a.v,b.v)); }
93template<> EIGEN_STRONG_INLINE Packet4cf pxor <Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_xor_ps(a.v,b.v)); }
94template<> EIGEN_STRONG_INLINE Packet4cf pandnot<Packet4cf>(const Packet4cf& a, const Packet4cf& b) { return Packet4cf(_mm256_andnot_ps(b.v,a.v)); }
95
98
99
100template<> EIGEN_STRONG_INLINE Packet4cf pset1<Packet4cf>(const std::complex<float>& from)
101{
102 return Packet4cf(_mm256_castpd_ps(_mm256_broadcast_sd((const double*)(const void*)&from)));
103}
104
105template<> EIGEN_STRONG_INLINE Packet4cf ploaddup<Packet4cf>(const std::complex<float>* from)
106{
107 // FIXME The following might be optimized using _mm256_movedup_pd
110 return Packet4cf(_mm256_insertf128_ps(_mm256_castps128_ps256(a.v), b.v, 1));
111}
112
113template<> EIGEN_STRONG_INLINE void pstore <std::complex<float> >(std::complex<float>* to, const Packet4cf& from) { EIGEN_DEBUG_ALIGNED_STORE pstore(&numext::real_ref(*to), from.v); }
114template<> EIGEN_STRONG_INLINE void pstoreu<std::complex<float> >(std::complex<float>* to, const Packet4cf& from) { EIGEN_DEBUG_UNALIGNED_STORE pstoreu(&numext::real_ref(*to), from.v); }
115
116template<> EIGEN_DEVICE_FUNC inline Packet4cf pgather<std::complex<float>, Packet4cf>(const std::complex<float>* from, Index stride)
117{
118 return Packet4cf(_mm256_set_ps(std::imag(from[3*stride]), std::real(from[3*stride]),
119 std::imag(from[2*stride]), std::real(from[2*stride]),
120 std::imag(from[1*stride]), std::real(from[1*stride]),
121 std::imag(from[0*stride]), std::real(from[0*stride])));
122}
123
124template<> EIGEN_DEVICE_FUNC inline void pscatter<std::complex<float>, Packet4cf>(std::complex<float>* to, const Packet4cf& from, Index stride)
125{
126 __m128 low = _mm256_extractf128_ps(from.v, 0);
127 to[stride*0] = std::complex<float>(_mm_cvtss_f32(_mm_shuffle_ps(low, low, 0)),
128 _mm_cvtss_f32(_mm_shuffle_ps(low, low, 1)));
129 to[stride*1] = std::complex<float>(_mm_cvtss_f32(_mm_shuffle_ps(low, low, 2)),
130 _mm_cvtss_f32(_mm_shuffle_ps(low, low, 3)));
131
132 __m128 high = _mm256_extractf128_ps(from.v, 1);
133 to[stride*2] = std::complex<float>(_mm_cvtss_f32(_mm_shuffle_ps(high, high, 0)),
134 _mm_cvtss_f32(_mm_shuffle_ps(high, high, 1)));
135 to[stride*3] = std::complex<float>(_mm_cvtss_f32(_mm_shuffle_ps(high, high, 2)),
136 _mm_cvtss_f32(_mm_shuffle_ps(high, high, 3)));
137
138}
139
140template<> EIGEN_STRONG_INLINE std::complex<float> pfirst<Packet4cf>(const Packet4cf& a)
141{
142 return pfirst(Packet2cf(_mm256_castps256_ps128(a.v)));
143}
144
146 __m128 low = _mm256_extractf128_ps(a.v, 0);
147 __m128 high = _mm256_extractf128_ps(a.v, 1);
148 __m128d lowd = _mm_castps_pd(low);
149 __m128d highd = _mm_castps_pd(high);
150 low = _mm_castpd_ps(_mm_shuffle_pd(lowd,lowd,0x1));
151 high = _mm_castpd_ps(_mm_shuffle_pd(highd,highd,0x1));
152 __m256 result = _mm256_setzero_ps();
153 result = _mm256_insertf128_ps(result, low, 1);
154 result = _mm256_insertf128_ps(result, high, 0);
155 return Packet4cf(result);
156}
157
158template<> EIGEN_STRONG_INLINE std::complex<float> predux<Packet4cf>(const Packet4cf& a)
159{
160 return predux(padd(Packet2cf(_mm256_extractf128_ps(a.v,0)),
161 Packet2cf(_mm256_extractf128_ps(a.v,1))));
162}
163
164template<> EIGEN_STRONG_INLINE std::complex<float> predux_mul<Packet4cf>(const Packet4cf& a)
165{
166 return predux_mul(pmul(Packet2cf(_mm256_extractf128_ps(a.v, 0)),
167 Packet2cf(_mm256_extractf128_ps(a.v, 1))));
168}
169
171
173{
174 Packet4cf num = pmul(a, pconj(b));
175 __m256 tmp = _mm256_mul_ps(b.v, b.v);
176 __m256 tmp2 = _mm256_shuffle_ps(tmp,tmp,0xB1);
177 __m256 denom = _mm256_add_ps(tmp, tmp2);
178 return Packet4cf(_mm256_div_ps(num.v, denom));
179}
180
182{
183 return Packet4cf(_mm256_shuffle_ps(x.v, x.v, _MM_SHUFFLE(2, 3, 0 ,1)));
184}
185
186//---------- double ----------
188{
190 EIGEN_STRONG_INLINE explicit Packet2cd(const __m256d& a) : v(a) {}
191 __m256d v;
192};
193
194#ifndef EIGEN_VECTORIZE_AVX512
195template<> struct packet_traits<std::complex<double> > : default_packet_traits
196{
199 enum {
200 Vectorizable = 1,
201 AlignedOnScalar = 0,
202 size = 2,
203 HasHalfPacket = 1,
204
205 HasAdd = 1,
206 HasSub = 1,
207 HasMul = 1,
208 HasDiv = 1,
209 HasNegate = 1,
210 HasSqrt = 1,
211 HasAbs = 0,
212 HasAbs2 = 0,
213 HasMin = 0,
214 HasMax = 0,
215 HasSetLinear = 0
216 };
217};
218#endif
219
220template<> struct unpacket_traits<Packet2cd> {
221 typedef std::complex<double> type;
224 enum {
230 };
231};
232
233template<> EIGEN_STRONG_INLINE Packet2cd padd<Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_add_pd(a.v,b.v)); }
234template<> EIGEN_STRONG_INLINE Packet2cd psub<Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_sub_pd(a.v,b.v)); }
237{
238 const __m256d mask = _mm256_castsi256_pd(_mm256_set_epi32(0x80000000,0x0,0x0,0x0,0x80000000,0x0,0x0,0x0));
239 return Packet2cd(_mm256_xor_pd(a.v,mask));
240}
241
243{
244 __m256d tmp1 = _mm256_shuffle_pd(a.v,a.v,0x0);
245 __m256d even = _mm256_mul_pd(tmp1, b.v);
246 __m256d tmp2 = _mm256_shuffle_pd(a.v,a.v,0xF);
247 __m256d tmp3 = _mm256_shuffle_pd(b.v,b.v,0x5);
248 __m256d odd = _mm256_mul_pd(tmp2, tmp3);
249 return Packet2cd(_mm256_addsub_pd(even, odd));
250}
251
252template <>
254 __m256d eq = _mm256_cmp_pd(a.v, b.v, _CMP_EQ_OQ);
255 return Packet2cd(pand(eq, _mm256_permute_pd(eq, 0x5)));
256}
257
259template<> EIGEN_STRONG_INLINE Packet2cd pand <Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_and_pd(a.v,b.v)); }
260template<> EIGEN_STRONG_INLINE Packet2cd por <Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_or_pd(a.v,b.v)); }
261template<> EIGEN_STRONG_INLINE Packet2cd pxor <Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_xor_pd(a.v,b.v)); }
262template<> EIGEN_STRONG_INLINE Packet2cd pandnot<Packet2cd>(const Packet2cd& a, const Packet2cd& b) { return Packet2cd(_mm256_andnot_pd(b.v,a.v)); }
263
264template<> EIGEN_STRONG_INLINE Packet2cd pload <Packet2cd>(const std::complex<double>* from)
265{ EIGEN_DEBUG_ALIGNED_LOAD return Packet2cd(pload<Packet4d>((const double*)from)); }
266template<> EIGEN_STRONG_INLINE Packet2cd ploadu<Packet2cd>(const std::complex<double>* from)
268
269template<> EIGEN_STRONG_INLINE Packet2cd pset1<Packet2cd>(const std::complex<double>& from)
270{
271 // in case casting to a __m128d* is really not safe, then we can still fallback to this version: (much slower though)
272// return Packet2cd(_mm256_loadu2_m128d((const double*)&from,(const double*)&from));
273 return Packet2cd(_mm256_broadcast_pd((const __m128d*)(const void*)&from));
274}
275
276template<> EIGEN_STRONG_INLINE Packet2cd ploaddup<Packet2cd>(const std::complex<double>* from) { return pset1<Packet2cd>(*from); }
277
278template<> EIGEN_STRONG_INLINE void pstore <std::complex<double> >(std::complex<double> * to, const Packet2cd& from) { EIGEN_DEBUG_ALIGNED_STORE pstore((double*)to, from.v); }
279template<> EIGEN_STRONG_INLINE void pstoreu<std::complex<double> >(std::complex<double> * to, const Packet2cd& from) { EIGEN_DEBUG_UNALIGNED_STORE pstoreu((double*)to, from.v); }
280
281template<> EIGEN_DEVICE_FUNC inline Packet2cd pgather<std::complex<double>, Packet2cd>(const std::complex<double>* from, Index stride)
282{
283 return Packet2cd(_mm256_set_pd(std::imag(from[1*stride]), std::real(from[1*stride]),
284 std::imag(from[0*stride]), std::real(from[0*stride])));
285}
286
287template<> EIGEN_DEVICE_FUNC inline void pscatter<std::complex<double>, Packet2cd>(std::complex<double>* to, const Packet2cd& from, Index stride)
288{
289 __m128d low = _mm256_extractf128_pd(from.v, 0);
290 to[stride*0] = std::complex<double>(_mm_cvtsd_f64(low), _mm_cvtsd_f64(_mm_shuffle_pd(low, low, 1)));
291 __m128d high = _mm256_extractf128_pd(from.v, 1);
292 to[stride*1] = std::complex<double>(_mm_cvtsd_f64(high), _mm_cvtsd_f64(_mm_shuffle_pd(high, high, 1)));
293}
294
295template<> EIGEN_STRONG_INLINE std::complex<double> pfirst<Packet2cd>(const Packet2cd& a)
296{
297 __m128d low = _mm256_extractf128_pd(a.v, 0);
298 EIGEN_ALIGN16 double res[2];
299 _mm_store_pd(res, low);
300 return std::complex<double>(res[0],res[1]);
301}
302
304 __m256d result = _mm256_permute2f128_pd(a.v, a.v, 1);
305 return Packet2cd(result);
306}
307
308template<> EIGEN_STRONG_INLINE std::complex<double> predux<Packet2cd>(const Packet2cd& a)
309{
310 return predux(padd(Packet1cd(_mm256_extractf128_pd(a.v,0)),
311 Packet1cd(_mm256_extractf128_pd(a.v,1))));
312}
313
314template<> EIGEN_STRONG_INLINE std::complex<double> predux_mul<Packet2cd>(const Packet2cd& a)
315{
316 return predux(pmul(Packet1cd(_mm256_extractf128_pd(a.v,0)),
317 Packet1cd(_mm256_extractf128_pd(a.v,1))));
318}
319
321
323{
324 Packet2cd num = pmul(a, pconj(b));
325 __m256d tmp = _mm256_mul_pd(b.v, b.v);
326 __m256d denom = _mm256_hadd_pd(tmp, tmp);
327 return Packet2cd(_mm256_div_pd(num.v, denom));
328}
329
331{
332 return Packet2cd(_mm256_shuffle_pd(x.v, x.v, 0x5));
333}
334
335EIGEN_DEVICE_FUNC inline void
337 __m256d P0 = _mm256_castps_pd(kernel.packet[0].v);
338 __m256d P1 = _mm256_castps_pd(kernel.packet[1].v);
339 __m256d P2 = _mm256_castps_pd(kernel.packet[2].v);
340 __m256d P3 = _mm256_castps_pd(kernel.packet[3].v);
341
342 __m256d T0 = _mm256_shuffle_pd(P0, P1, 15);
343 __m256d T1 = _mm256_shuffle_pd(P0, P1, 0);
344 __m256d T2 = _mm256_shuffle_pd(P2, P3, 15);
345 __m256d T3 = _mm256_shuffle_pd(P2, P3, 0);
346
347 kernel.packet[1].v = _mm256_castpd_ps(_mm256_permute2f128_pd(T0, T2, 32));
348 kernel.packet[3].v = _mm256_castpd_ps(_mm256_permute2f128_pd(T0, T2, 49));
349 kernel.packet[0].v = _mm256_castpd_ps(_mm256_permute2f128_pd(T1, T3, 32));
350 kernel.packet[2].v = _mm256_castpd_ps(_mm256_permute2f128_pd(T1, T3, 49));
351}
352
353EIGEN_DEVICE_FUNC inline void
355 __m256d tmp = _mm256_permute2f128_pd(kernel.packet[0].v, kernel.packet[1].v, 0+(2<<4));
356 kernel.packet[1].v = _mm256_permute2f128_pd(kernel.packet[0].v, kernel.packet[1].v, 1+(3<<4));
357 kernel.packet[0].v = tmp;
358}
359
361 return psqrt_complex<Packet2cd>(a);
362}
363
365 return psqrt_complex<Packet4cf>(a);
366}
367
368} // end namespace internal
369
370} // end namespace Eigen
371
372#endif // EIGEN_COMPLEX_AVX_H
EIGEN_DEVICE_FUNC RealReturnType real() const
Definition: CommonCwiseUnaryOps.h:100
EIGEN_DEVICE_FUNC const ImagReturnType imag() const
Definition: CommonCwiseUnaryOps.h:109
#define EIGEN_ALIGN16
Definition: ConfigureVectorization.h:153
#define EIGEN_MAKE_CONJ_HELPER_CPLX_REAL(PACKET_CPLX, PACKET_REAL)
Definition: ConjHelper.h:14
#define EIGEN_DEBUG_ALIGNED_STORE
Definition: GenericPacketMath.h:35
#define EIGEN_DEBUG_ALIGNED_LOAD
Definition: GenericPacketMath.h:27
#define EIGEN_DEBUG_UNALIGNED_STORE
Definition: GenericPacketMath.h:39
#define EIGEN_DEBUG_UNALIGNED_LOAD
Definition: GenericPacketMath.h:31
#define EIGEN_DEVICE_FUNC
Definition: Macros.h:986
#define EIGEN_STRONG_INLINE
Definition: Macros.h:927
and restrictions which apply to each piece of software is included later in this file and or inside of the individual applicable source files The disclaimer of warranty in the WPILib license above applies to all code in and nothing in any of the other licenses gives permission to use the names of FIRST nor the names of the WPILib contributors to endorse or promote products derived from this software The following pieces of software have additional or alternate and or Google Inc All rights reserved Redistribution and use in source and binary with or without are permitted provided that the following conditions are this list of conditions and the following disclaimer *Redistributions in binary form must reproduce the above copyright this list of conditions and the following disclaimer in the documentation and or other materials provided with the distribution *Neither the name of Google Inc nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS AND ANY EXPRESS OR IMPLIED BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY OR CONSEQUENTIAL WHETHER IN STRICT OR EVEN IF ADVISED OF THE POSSIBILITY OF SUCH January AND DISTRIBUTION Definitions License shall mean the terms and conditions for and distribution as defined by Sections through of this document Licensor shall mean the copyright owner or entity authorized by the copyright owner that is granting the License Legal Entity shall mean the union of the acting entity and all other entities that control are controlled by or are under common control with that entity For the purposes of this definition control direct or to cause the direction or management of such whether by contract or including but not limited to software source documentation and configuration files Object form shall mean any form resulting from mechanical transformation or translation of a Source including but not limited to compiled object generated and conversions to other media types Work shall mean the work of whether in Source or Object made available under the as indicated by a copyright notice that is included in or attached to the whether in Source or Object that is based or other modifications as a an original work of authorship For the purposes of this Derivative Works shall not include works that remain separable from
Definition: ThirdPartyNotices.txt:131
@ Aligned32
Data pointer is aligned on a 32 bytes boundary.
Definition: Constants.h:236
EIGEN_STRONG_INLINE std::complex< double > predux< Packet2cd >(const Packet2cd &a)
Definition: Complex.h:308
EIGEN_STRONG_INLINE Packet4cf ploadu< Packet4cf >(const std::complex< float > *from)
Definition: Complex.h:97
EIGEN_DEVICE_FUNC unpacket_traits< Packet >::type predux(const Packet &a)
Definition: GenericPacketMath.h:875
EIGEN_STRONG_INLINE std::complex< float > predux_mul< Packet4cf >(const Packet4cf &a)
Definition: Complex.h:164
EIGEN_STRONG_INLINE Packet2cd pcplxflip< Packet2cd >(const Packet2cd &x)
Definition: Complex.h:330
EIGEN_STRONG_INLINE Packet4cf psub< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:65
EIGEN_STRONG_INLINE Packet2cd pset1< Packet2cd >(const std::complex< double > &from)
Definition: Complex.h:269
EIGEN_STRONG_INLINE std::complex< float > pfirst< Packet4cf >(const Packet4cf &a)
Definition: Complex.h:140
EIGEN_STRONG_INLINE Packet2cd ploaddup< Packet2cd >(const std::complex< double > *from)
Definition: Complex.h:276
EIGEN_STRONG_INLINE Packet2cd psqrt< Packet2cd >(const Packet2cd &a)
Definition: Complex.h:360
EIGEN_STRONG_INLINE Packet2cf ploaddup< Packet2cf >(const std::complex< float > *from)
Definition: Complex.h:119
EIGEN_STRONG_INLINE Packet2cd pand< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:259
EIGEN_STRONG_INLINE Packet4cf pxor< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:93
EIGEN_DEVICE_FUNC Packet pdiv(const Packet &a, const Packet &b)
Definition: GenericPacketMath.h:244
EIGEN_DEVICE_FUNC void ptranspose(PacketBlock< Packet4f, 4 > &kernel)
Definition: PacketMath.h:1124
EIGEN_STRONG_INLINE Packet2cd ploadu< Packet2cd >(const std::complex< double > *from)
Definition: Complex.h:266
EIGEN_STRONG_INLINE std::complex< double > predux_mul< Packet2cd >(const Packet2cd &a)
Definition: Complex.h:314
EIGEN_STRONG_INLINE std::complex< double > pfirst< Packet2cd >(const Packet2cd &a)
Definition: Complex.h:295
EIGEN_STRONG_INLINE Packet2cd por< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:260
EIGEN_STRONG_INLINE Packet2cd ptrue< Packet2cd >(const Packet2cd &a)
Definition: Complex.h:258
EIGEN_STRONG_INLINE Packet4cf ptrue< Packet4cf >(const Packet4cf &a)
Definition: Complex.h:90
EIGEN_STRONG_INLINE Packet4cf pand< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:91
EIGEN_STRONG_INLINE Packet4bf pand(const Packet4bf &a, const Packet4bf &b)
Definition: PacketMath.h:3507
EIGEN_STRONG_INLINE Packet4cf pset1< Packet4cf >(const std::complex< float > &from)
Definition: Complex.h:100
EIGEN_STRONG_INLINE Packet2cd pload< Packet2cd >(const std::complex< double > *from)
Definition: Complex.h:264
EIGEN_STRONG_INLINE Packet8f ploadu< Packet8f >(const float *from)
Definition: PacketMath.h:581
EIGEN_DEVICE_FUNC unpacket_traits< Packet >::type predux_mul(const Packet &a)
Definition: GenericPacketMath.h:882
EIGEN_STRONG_INLINE Packet2cd pandnot< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:262
EIGEN_DEVICE_FUNC Packet pmul(const Packet &a, const Packet &b)
Definition: GenericPacketMath.h:237
EIGEN_STRONG_INLINE Packet8h ptrue(const Packet8h &a)
Definition: PacketMath.h:978
EIGEN_STRONG_INLINE Packet2cd psub< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:234
EIGEN_STRONG_INLINE Packet8f pload< Packet8f >(const float *from)
Definition: PacketMath.h:577
EIGEN_STRONG_INLINE Packet4d ploadu< Packet4d >(const double *from)
Definition: PacketMath.h:582
EIGEN_STRONG_INLINE Packet4f pcmp_eq(const Packet4f &a, const Packet4f &b)
Definition: PacketMath.h:434
EIGEN_STRONG_INLINE Packet4cf ploaddup< Packet4cf >(const std::complex< float > *from)
Definition: Complex.h:105
EIGEN_STRONG_INLINE Packet4cf pandnot< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:94
EIGEN_DEVICE_FUNC void pstore(Scalar *to, const Packet &from)
Definition: GenericPacketMath.h:696
EIGEN_STRONG_INLINE Packet2cd pxor< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:261
EIGEN_STRONG_INLINE Packet4cf padd< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:64
EIGEN_STRONG_INLINE Packet4f preverse(const Packet4f &a)
Definition: PacketMath.h:891
EIGEN_DEVICE_FUNC void pstoreu(Scalar *to, const Packet &from)
Definition: GenericPacketMath.h:700
EIGEN_DEVICE_FUNC unpacket_traits< Packet >::type pfirst(const Packet &a)
Definition: GenericPacketMath.h:844
EIGEN_STRONG_INLINE Packet2cd pmul< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:242
EIGEN_STRONG_INLINE Packet4cf pmul< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:76
EIGEN_STRONG_INLINE Packet4d pload< Packet4d >(const double *from)
Definition: PacketMath.h:578
EIGEN_STRONG_INLINE Packet4f pconj(const Packet4f &a)
Definition: PacketMath.h:342
EIGEN_STRONG_INLINE Packet4cf pcplxflip< Packet4cf >(const Packet4cf &x)
Definition: Complex.h:181
EIGEN_STRONG_INLINE Packet4cf pload< Packet4cf >(const std::complex< float > *from)
Definition: Complex.h:96
__m256 Packet8f
Definition: PacketMath.h:31
EIGEN_STRONG_INLINE std::complex< float > predux< Packet4cf >(const Packet4cf &a)
Definition: Complex.h:158
DoublePacket< Packet > padd(const DoublePacket< Packet > &a, const DoublePacket< Packet > &b)
Definition: GeneralBlockPanelKernel.h:689
EIGEN_STRONG_INLINE Packet4cf por< Packet4cf >(const Packet4cf &a, const Packet4cf &b)
Definition: Complex.h:92
EIGEN_STRONG_INLINE Packet4f pnegate(const Packet4f &a)
Definition: PacketMath.h:322
EIGEN_STRONG_INLINE Packet2cd padd< Packet2cd >(const Packet2cd &a, const Packet2cd &b)
Definition: Complex.h:233
__m256d Packet4d
Definition: PacketMath.h:33
EIGEN_STRONG_INLINE Packet4cf psqrt< Packet4cf >(const Packet4cf &a)
Definition: Complex.h:364
EIGEN_DEVICE_FUNC internal::add_const_on_value_type< EIGEN_MATHFUNC_RETVAL(real_ref, Scalar)>::type real_ref(const Scalar &x)
Definition: MathFunctions.h:1237
Namespace containing all symbols from the Eigen library.
Definition: MatrixExponential.h:16
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
result
Definition: format.h:2556
Definition: Eigen_Colamd.h:50
Definition: StdDeque.h:50
b
Definition: data.h:44
Definition: Complex.h:187
Definition: Complex.h:188
EIGEN_STRONG_INLINE Packet2cd()
Definition: Complex.h:189
__m256d v
Definition: Complex.h:191
EIGEN_STRONG_INLINE Packet2cd(const __m256d &a)
Definition: Complex.h:190
Definition: Complex.h:19
Packet4f v
Definition: Complex.h:22
Definition: Complex.h:19
EIGEN_STRONG_INLINE Packet4cf(const __m256 &a)
Definition: Complex.h:21
__m256 v
Definition: Complex.h:22
EIGEN_STRONG_INLINE Packet4cf()
Definition: Complex.h:20
Definition: GenericPacketMath.h:1014
Packet packet[N]
Definition: GenericPacketMath.h:1015
Definition: GenericPacketMath.h:43
@ HasSqrt
Definition: GenericPacketMath.h:66
@ HasDiv
Definition: GenericPacketMath.h:65
Definition: GenericPacketMath.h:107
@ HasHalfPacket
Definition: GenericPacketMath.h:114
@ size
Definition: GenericPacketMath.h:112
@ AlignedOnScalar
Definition: GenericPacketMath.h:113
@ Vectorizable
Definition: GenericPacketMath.h:111
@ HasSub
Definition: GenericPacketMath.h:118
@ HasMax
Definition: GenericPacketMath.h:124
@ HasNegate
Definition: GenericPacketMath.h:120
@ HasMul
Definition: GenericPacketMath.h:119
@ HasAdd
Definition: GenericPacketMath.h:117
@ HasSetLinear
Definition: GenericPacketMath.h:126
@ HasMin
Definition: GenericPacketMath.h:123
@ HasAbs2
Definition: GenericPacketMath.h:122
@ HasAbs
Definition: GenericPacketMath.h:121
Packet1cd half
Definition: Complex.h:222
Packet4d as_real
Definition: Complex.h:223
std::complex< double > type
Definition: Complex.h:221
std::complex< float > type
Definition: Complex.h:52
Packet2cf half
Definition: Complex.h:53
Packet8f as_real
Definition: Complex.h:54
Definition: GenericPacketMath.h:133
@ masked_load_available
Definition: GenericPacketMath.h:141
@ size
Definition: GenericPacketMath.h:138
@ masked_store_available
Definition: GenericPacketMath.h:142
@ vectorizable
Definition: GenericPacketMath.h:140
@ alignment
Definition: GenericPacketMath.h:139