11#ifndef EIGEN_COMPLEX_NEON_H
12#define EIGEN_COMPLEX_NEON_H
15#include "../../InternalHeaderCheck.h"
21inline uint32x4_t p4ui_CONJ_XOR() {
23#if EIGEN_COMP_CLANG || EIGEN_COMP_CASTXML
24 uint32x4_t ret = {0x00000000, 0x80000000, 0x00000000, 0x80000000};
27 static const uint32_t conj_XOR_DATA[] = {0x00000000, 0x80000000, 0x00000000, 0x80000000};
28 return vld1q_u32(conj_XOR_DATA);
32inline uint32x2_t p2ui_CONJ_XOR() {
33 static const uint32_t conj_XOR_DATA[] = {0x00000000, 0x80000000};
34 return vld1_u32(conj_XOR_DATA);
40 EIGEN_STRONG_INLINE Packet1cf() {}
41 EIGEN_STRONG_INLINE
explicit Packet1cf(
const Packet2f& a) : v(a) {}
45 EIGEN_STRONG_INLINE Packet2cf() {}
46 EIGEN_STRONG_INLINE
explicit Packet2cf(
const Packet4f& a) : v(a) {}
51struct packet_traits<std::complex<float> > : default_packet_traits {
52 typedef Packet2cf type;
53 typedef Packet1cf half;
76struct unpacket_traits<Packet1cf> {
77 typedef std::complex<float> type;
78 typedef Packet1cf half;
79 typedef Packet2f as_real;
84 masked_load_available =
false,
85 masked_store_available =
false
89struct unpacket_traits<Packet2cf> {
90 typedef std::complex<float> type;
91 typedef Packet1cf half;
92 typedef Packet4f as_real;
97 masked_load_available =
false,
98 masked_store_available =
false
103EIGEN_STRONG_INLINE Packet1cf pcast<float, Packet1cf>(
const float& a) {
104 return Packet1cf(vset_lane_f32(a, vdup_n_f32(0.f), 0));
107EIGEN_STRONG_INLINE Packet2cf pcast<Packet2f, Packet2cf>(
const Packet2f& a) {
108 return Packet2cf(vreinterpretq_f32_u64(vmovl_u32(vreinterpret_u32_f32(a))));
112EIGEN_STRONG_INLINE Packet1cf pset1<Packet1cf>(
const std::complex<float>& from) {
113 return Packet1cf(vld1_f32(
reinterpret_cast<const float*
>(&from)));
116EIGEN_STRONG_INLINE Packet2cf pset1<Packet2cf>(
const std::complex<float>& from) {
117 const float32x2_t r64 = vld1_f32(
reinterpret_cast<const float*
>(&from));
118 return Packet2cf(vcombine_f32(r64, r64));
122EIGEN_STRONG_INLINE Packet1cf padd<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
123 return Packet1cf(padd<Packet2f>(a.v, b.v));
126EIGEN_STRONG_INLINE Packet2cf padd<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
127 return Packet2cf(padd<Packet4f>(a.v, b.v));
131EIGEN_STRONG_INLINE Packet1cf psub<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
132 return Packet1cf(psub<Packet2f>(a.v, b.v));
135EIGEN_STRONG_INLINE Packet2cf psub<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
136 return Packet2cf(psub<Packet4f>(a.v, b.v));
140EIGEN_STRONG_INLINE Packet1cf pnegate(
const Packet1cf& a) {
141 return Packet1cf(pnegate<Packet2f>(a.v));
144EIGEN_STRONG_INLINE Packet2cf pnegate(
const Packet2cf& a) {
145 return Packet2cf(pnegate<Packet4f>(a.v));
149EIGEN_STRONG_INLINE Packet1cf pconj(
const Packet1cf& a) {
150 const Packet2ui b = Packet2ui(vreinterpret_u32_f32(a.v));
151 return Packet1cf(vreinterpret_f32_u32(veor_u32(b, p2ui_CONJ_XOR())));
154EIGEN_STRONG_INLINE Packet2cf pconj(
const Packet2cf& a) {
155 const Packet4ui b = Packet4ui(vreinterpretq_u32_f32(a.v));
156 return Packet2cf(vreinterpretq_f32_u32(veorq_u32(b, p4ui_CONJ_XOR())));
160EIGEN_STRONG_INLINE Packet1cf pmul<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
164 v1 = vdup_lane_f32(a.v, 0);
166 v2 = vdup_lane_f32(a.v, 1);
168 v1 = vmul_f32(v1, b.v);
170 v2 = vmul_f32(v2, b.v);
172 v2 = vreinterpret_f32_u32(veor_u32(vreinterpret_u32_f32(v2), p2ui_CONJ_XOR()));
176 return Packet1cf(vadd_f32(v1, v2));
179EIGEN_STRONG_INLINE Packet2cf pmul<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
183 v1 = vcombine_f32(vdup_lane_f32(vget_low_f32(a.v), 0), vdup_lane_f32(vget_high_f32(a.v), 0));
185 v2 = vcombine_f32(vdup_lane_f32(vget_low_f32(a.v), 1), vdup_lane_f32(vget_high_f32(a.v), 1));
187 v1 = vmulq_f32(v1, b.v);
189 v2 = vmulq_f32(v2, b.v);
191 v2 = vreinterpretq_f32_u32(veorq_u32(vreinterpretq_u32_f32(v2), p4ui_CONJ_XOR()));
193 v2 = vrev64q_f32(v2);
195 return Packet2cf(vaddq_f32(v1, v2));
199EIGEN_STRONG_INLINE Packet1cf pcmp_eq(
const Packet1cf& a,
const Packet1cf& b) {
202 Packet2f eq = pcmp_eq<Packet2f>(a.v, b.v);
205 Packet2f eq_swapped = vrev64_f32(eq);
207 return Packet1cf(pand<Packet2f>(eq, eq_swapped));
210EIGEN_STRONG_INLINE Packet2cf pcmp_eq(
const Packet2cf& a,
const Packet2cf& b) {
213 Packet4f eq = pcmp_eq<Packet4f>(a.v, b.v);
216 Packet4f eq_swapped = vrev64q_f32(eq);
218 return Packet2cf(pand<Packet4f>(eq, eq_swapped));
222EIGEN_STRONG_INLINE Packet1cf pand<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
223 return Packet1cf(vreinterpret_f32_u32(vand_u32(vreinterpret_u32_f32(a.v), vreinterpret_u32_f32(b.v))));
226EIGEN_STRONG_INLINE Packet2cf pand<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
227 return Packet2cf(vreinterpretq_f32_u32(vandq_u32(vreinterpretq_u32_f32(a.v), vreinterpretq_u32_f32(b.v))));
231EIGEN_STRONG_INLINE Packet1cf por<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
232 return Packet1cf(vreinterpret_f32_u32(vorr_u32(vreinterpret_u32_f32(a.v), vreinterpret_u32_f32(b.v))));
235EIGEN_STRONG_INLINE Packet2cf por<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
236 return Packet2cf(vreinterpretq_f32_u32(vorrq_u32(vreinterpretq_u32_f32(a.v), vreinterpretq_u32_f32(b.v))));
240EIGEN_STRONG_INLINE Packet1cf pxor<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
241 return Packet1cf(vreinterpret_f32_u32(veor_u32(vreinterpret_u32_f32(a.v), vreinterpret_u32_f32(b.v))));
244EIGEN_STRONG_INLINE Packet2cf pxor<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
245 return Packet2cf(vreinterpretq_f32_u32(veorq_u32(vreinterpretq_u32_f32(a.v), vreinterpretq_u32_f32(b.v))));
249EIGEN_STRONG_INLINE Packet1cf pandnot<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
250 return Packet1cf(vreinterpret_f32_u32(vbic_u32(vreinterpret_u32_f32(a.v), vreinterpret_u32_f32(b.v))));
253EIGEN_STRONG_INLINE Packet2cf pandnot<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
254 return Packet2cf(vreinterpretq_f32_u32(vbicq_u32(vreinterpretq_u32_f32(a.v), vreinterpretq_u32_f32(b.v))));
258EIGEN_STRONG_INLINE Packet1cf pload<Packet1cf>(
const std::complex<float>* from) {
259 EIGEN_DEBUG_ALIGNED_LOAD
return Packet1cf(pload<Packet2f>((
const float*)from));
262EIGEN_STRONG_INLINE Packet2cf pload<Packet2cf>(
const std::complex<float>* from) {
263 EIGEN_DEBUG_ALIGNED_LOAD
return Packet2cf(pload<Packet4f>(
reinterpret_cast<const float*
>(from)));
267EIGEN_STRONG_INLINE Packet1cf ploadu<Packet1cf>(
const std::complex<float>* from) {
268 EIGEN_DEBUG_UNALIGNED_LOAD
return Packet1cf(ploadu<Packet2f>((
const float*)from));
271EIGEN_STRONG_INLINE Packet2cf ploadu<Packet2cf>(
const std::complex<float>* from) {
272 EIGEN_DEBUG_UNALIGNED_LOAD
return Packet2cf(ploadu<Packet4f>(
reinterpret_cast<const float*
>(from)));
276EIGEN_STRONG_INLINE Packet1cf ploaddup<Packet1cf>(
const std::complex<float>* from) {
277 return pset1<Packet1cf>(*from);
280EIGEN_STRONG_INLINE Packet2cf ploaddup<Packet2cf>(
const std::complex<float>* from) {
281 return pset1<Packet2cf>(*from);
285EIGEN_STRONG_INLINE
void pstore<std::complex<float> >(std::complex<float>* to,
const Packet1cf& from) {
286 EIGEN_DEBUG_ALIGNED_STORE pstore((
float*)to, from.v);
289EIGEN_STRONG_INLINE
void pstore<std::complex<float> >(std::complex<float>* to,
const Packet2cf& from) {
290 EIGEN_DEBUG_ALIGNED_STORE pstore(
reinterpret_cast<float*
>(to), from.v);
294EIGEN_STRONG_INLINE
void pstoreu<std::complex<float> >(std::complex<float>* to,
const Packet1cf& from) {
295 EIGEN_DEBUG_UNALIGNED_STORE pstoreu((
float*)to, from.v);
298EIGEN_STRONG_INLINE
void pstoreu<std::complex<float> >(std::complex<float>* to,
const Packet2cf& from) {
299 EIGEN_DEBUG_UNALIGNED_STORE pstoreu(
reinterpret_cast<float*
>(to), from.v);
303EIGEN_DEVICE_FUNC
inline Packet1cf pgather<std::complex<float>, Packet1cf>(
const std::complex<float>* from,
305 const Packet2f tmp = vdup_n_f32(std::real(from[0 * stride]));
306 return Packet1cf(vset_lane_f32(std::imag(from[0 * stride]), tmp, 1));
309EIGEN_DEVICE_FUNC
inline Packet2cf pgather<std::complex<float>, Packet2cf>(
const std::complex<float>* from,
311 Packet4f res = vdupq_n_f32(std::real(from[0 * stride]));
312 res = vsetq_lane_f32(std::imag(from[0 * stride]), res, 1);
313 res = vsetq_lane_f32(std::real(from[1 * stride]), res, 2);
314 res = vsetq_lane_f32(std::imag(from[1 * stride]), res, 3);
315 return Packet2cf(res);
319EIGEN_DEVICE_FUNC
inline void pscatter<std::complex<float>, Packet1cf>(std::complex<float>* to,
const Packet1cf& from,
321 to[stride * 0] = std::complex<float>(vget_lane_f32(from.v, 0), vget_lane_f32(from.v, 1));
324EIGEN_DEVICE_FUNC
inline void pscatter<std::complex<float>, Packet2cf>(std::complex<float>* to,
const Packet2cf& from,
326 to[stride * 0] = std::complex<float>(vgetq_lane_f32(from.v, 0), vgetq_lane_f32(from.v, 1));
327 to[stride * 1] = std::complex<float>(vgetq_lane_f32(from.v, 2), vgetq_lane_f32(from.v, 3));
331EIGEN_STRONG_INLINE
void prefetch<std::complex<float> >(
const std::complex<float>* addr) {
332 EIGEN_ARM_PREFETCH(
reinterpret_cast<const float*
>(addr));
336EIGEN_STRONG_INLINE std::complex<float> pfirst<Packet1cf>(
const Packet1cf& a) {
337 EIGEN_ALIGN16 std::complex<float> x;
338 vst1_f32(
reinterpret_cast<float*
>(&x), a.v);
342EIGEN_STRONG_INLINE std::complex<float> pfirst<Packet2cf>(
const Packet2cf& a) {
343 EIGEN_ALIGN16 std::complex<float> x[2];
344 vst1q_f32(
reinterpret_cast<float*
>(x), a.v);
349EIGEN_STRONG_INLINE Packet1cf preverse(
const Packet1cf& a) {
353EIGEN_STRONG_INLINE Packet2cf preverse(
const Packet2cf& a) {
354 return Packet2cf(vcombine_f32(vget_high_f32(a.v), vget_low_f32(a.v)));
358EIGEN_STRONG_INLINE Packet1cf pcplxflip<Packet1cf>(
const Packet1cf& a) {
359 return Packet1cf(vrev64_f32(a.v));
362EIGEN_STRONG_INLINE Packet2cf pcplxflip<Packet2cf>(
const Packet2cf& a) {
363 return Packet2cf(vrev64q_f32(a.v));
367EIGEN_STRONG_INLINE std::complex<float> predux<Packet1cf>(
const Packet1cf& a) {
368 std::complex<float> s;
369 vst1_f32((
float*)&s, a.v);
373EIGEN_STRONG_INLINE std::complex<float> predux<Packet2cf>(
const Packet2cf& a) {
374 std::complex<float> s;
375 vst1_f32(
reinterpret_cast<float*
>(&s), vadd_f32(vget_low_f32(a.v), vget_high_f32(a.v)));
380EIGEN_STRONG_INLINE std::complex<float> predux_mul<Packet1cf>(
const Packet1cf& a) {
381 std::complex<float> s;
382 vst1_f32((
float*)&s, a.v);
386EIGEN_STRONG_INLINE std::complex<float> predux_mul<Packet2cf>(
const Packet2cf& a) {
387 float32x2_t a1, a2, v1, v2, prod;
388 std::complex<float> s;
390 a1 = vget_low_f32(a.v);
391 a2 = vget_high_f32(a.v);
393 v1 = vdup_lane_f32(a1, 0);
395 v2 = vdup_lane_f32(a1, 1);
397 v1 = vmul_f32(v1, a2);
399 v2 = vmul_f32(v2, a2);
401 v2 = vreinterpret_f32_u32(veor_u32(vreinterpret_u32_f32(v2), p2ui_CONJ_XOR()));
405 prod = vadd_f32(v1, v2);
407 vst1_f32(
reinterpret_cast<float*
>(&s), prod);
412EIGEN_MAKE_CONJ_HELPER_CPLX_REAL(Packet1cf, Packet2f)
413EIGEN_MAKE_CONJ_HELPER_CPLX_REAL(Packet2cf, Packet4f)
416EIGEN_STRONG_INLINE Packet1cf pdiv<Packet1cf>(
const Packet1cf& a,
const Packet1cf& b) {
417 return pdiv_complex(a, b);
420EIGEN_STRONG_INLINE Packet2cf pdiv<Packet2cf>(
const Packet2cf& a,
const Packet2cf& b) {
421 return pdiv_complex(a, b);
424EIGEN_DEVICE_FUNC
inline void ptranspose(PacketBlock<Packet1cf, 1>& ) {}
425EIGEN_DEVICE_FUNC
inline void ptranspose(PacketBlock<Packet2cf, 2>& kernel) {
426 Packet4f tmp = vcombine_f32(vget_high_f32(kernel.packet[0].v), vget_high_f32(kernel.packet[1].v));
427 kernel.packet[0].v = vcombine_f32(vget_low_f32(kernel.packet[0].v), vget_low_f32(kernel.packet[1].v));
428 kernel.packet[1].v = tmp;
432EIGEN_STRONG_INLINE Packet1cf psqrt<Packet1cf>(
const Packet1cf& a) {
433 return psqrt_complex<Packet1cf>(a);
437EIGEN_STRONG_INLINE Packet2cf psqrt<Packet2cf>(
const Packet2cf& a) {
438 return psqrt_complex<Packet2cf>(a);
442EIGEN_STRONG_INLINE Packet1cf plog<Packet1cf>(
const Packet1cf& a) {
443 return plog_complex(a);
447EIGEN_STRONG_INLINE Packet2cf plog<Packet2cf>(
const Packet2cf& a) {
448 return plog_complex(a);
452EIGEN_STRONG_INLINE Packet1cf pexp<Packet1cf>(
const Packet1cf& a) {
453 return pexp_complex(a);
457EIGEN_STRONG_INLINE Packet2cf pexp<Packet2cf>(
const Packet2cf& a) {
458 return pexp_complex(a);
462#if EIGEN_ARCH_ARM64 && !EIGEN_APPLE_DOUBLE_NEON_BUG
465#if EIGEN_COMP_CLANG || EIGEN_COMP_CASTXML || EIGEN_COMP_CPE
466static uint64x2_t p2ul_CONJ_XOR = {0x0, 0x8000000000000000};
468const uint64_t p2ul_conj_XOR_DATA[] = {0x0, 0x8000000000000000};
469static uint64x2_t p2ul_CONJ_XOR = vld1q_u64(p2ul_conj_XOR_DATA);
473 EIGEN_STRONG_INLINE Packet1cd() {}
474 EIGEN_STRONG_INLINE
explicit Packet1cd(
const Packet2d& a) : v(a) {}
479struct packet_traits<std::complex<double> > : default_packet_traits {
480 typedef Packet1cd type;
481 typedef Packet1cd half;
503struct unpacket_traits<Packet1cd> {
504 typedef std::complex<double> type;
505 typedef Packet1cd half;
506 typedef Packet2d as_real;
511 masked_load_available =
false,
512 masked_store_available =
false
517EIGEN_STRONG_INLINE Packet1cd pload<Packet1cd>(
const std::complex<double>* from) {
518 EIGEN_DEBUG_ALIGNED_LOAD
return Packet1cd(pload<Packet2d>(
reinterpret_cast<const double*
>(from)));
522EIGEN_STRONG_INLINE Packet1cd ploadu<Packet1cd>(
const std::complex<double>* from) {
523 EIGEN_DEBUG_UNALIGNED_LOAD
return Packet1cd(ploadu<Packet2d>(
reinterpret_cast<const double*
>(from)));
527EIGEN_STRONG_INLINE Packet1cd pset1<Packet1cd>(
const std::complex<double>& from) {
529 return ploadu<Packet1cd>(&from);
533EIGEN_STRONG_INLINE Packet1cd padd<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
534 return Packet1cd(padd<Packet2d>(a.v, b.v));
538EIGEN_STRONG_INLINE Packet1cd psub<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
539 return Packet1cd(psub<Packet2d>(a.v, b.v));
543EIGEN_STRONG_INLINE Packet1cd pnegate(
const Packet1cd& a) {
544 return Packet1cd(pnegate<Packet2d>(a.v));
548EIGEN_STRONG_INLINE Packet1cd pconj(
const Packet1cd& a) {
549 return Packet1cd(vreinterpretq_f64_u64(veorq_u64(vreinterpretq_u64_f64(a.v), p2ul_CONJ_XOR)));
553EIGEN_STRONG_INLINE Packet1cd pmul<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
557 v1 = vdupq_lane_f64(vget_low_f64(a.v), 0);
559 v2 = vdupq_lane_f64(vget_high_f64(a.v), 0);
561 v1 = vmulq_f64(v1, b.v);
563 v2 = vmulq_f64(v2, b.v);
565 v2 = vreinterpretq_f64_u64(veorq_u64(vreinterpretq_u64_f64(v2), p2ul_CONJ_XOR));
567 v2 = preverse<Packet2d>(v2);
569 return Packet1cd(vaddq_f64(v1, v2));
573EIGEN_STRONG_INLINE Packet1cd pcmp_eq(
const Packet1cd& a,
const Packet1cd& b) {
576 Packet2d eq = pcmp_eq<Packet2d>(a.v, b.v);
579 Packet2d eq_swapped = vreinterpretq_f64_u32(vrev64q_u32(vreinterpretq_u32_f64(eq)));
581 return Packet1cd(pand<Packet2d>(eq, eq_swapped));
585EIGEN_STRONG_INLINE Packet1cd pand<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
586 return Packet1cd(vreinterpretq_f64_u64(vandq_u64(vreinterpretq_u64_f64(a.v), vreinterpretq_u64_f64(b.v))));
590EIGEN_STRONG_INLINE Packet1cd por<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
591 return Packet1cd(vreinterpretq_f64_u64(vorrq_u64(vreinterpretq_u64_f64(a.v), vreinterpretq_u64_f64(b.v))));
595EIGEN_STRONG_INLINE Packet1cd pxor<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
596 return Packet1cd(vreinterpretq_f64_u64(veorq_u64(vreinterpretq_u64_f64(a.v), vreinterpretq_u64_f64(b.v))));
600EIGEN_STRONG_INLINE Packet1cd pandnot<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
601 return Packet1cd(vreinterpretq_f64_u64(vbicq_u64(vreinterpretq_u64_f64(a.v), vreinterpretq_u64_f64(b.v))));
605EIGEN_STRONG_INLINE Packet1cd ploaddup<Packet1cd>(
const std::complex<double>* from) {
606 return pset1<Packet1cd>(*from);
610EIGEN_STRONG_INLINE
void pstore<std::complex<double> >(std::complex<double>* to,
const Packet1cd& from) {
611 EIGEN_DEBUG_ALIGNED_STORE pstore(
reinterpret_cast<double*
>(to), from.v);
615EIGEN_STRONG_INLINE
void pstoreu<std::complex<double> >(std::complex<double>* to,
const Packet1cd& from) {
616 EIGEN_DEBUG_UNALIGNED_STORE pstoreu(
reinterpret_cast<double*
>(to), from.v);
620EIGEN_STRONG_INLINE
void prefetch<std::complex<double> >(
const std::complex<double>* addr) {
621 EIGEN_ARM_PREFETCH(
reinterpret_cast<const double*
>(addr));
625EIGEN_DEVICE_FUNC
inline Packet1cd pgather<std::complex<double>, Packet1cd>(
const std::complex<double>* from,
627 Packet2d res = pset1<Packet2d>(0.0);
628 res = vsetq_lane_f64(std::real(from[0 * stride]), res, 0);
629 res = vsetq_lane_f64(std::imag(from[0 * stride]), res, 1);
630 return Packet1cd(res);
634EIGEN_DEVICE_FUNC
inline void pscatter<std::complex<double>, Packet1cd>(std::complex<double>* to,
const Packet1cd& from,
636 to[stride * 0] = std::complex<double>(vgetq_lane_f64(from.v, 0), vgetq_lane_f64(from.v, 1));
640EIGEN_STRONG_INLINE std::complex<double> pfirst<Packet1cd>(
const Packet1cd& a) {
641 EIGEN_ALIGN16 std::complex<double> res;
642 pstore<std::complex<double> >(&res, a);
647EIGEN_STRONG_INLINE Packet1cd preverse(
const Packet1cd& a) {
652EIGEN_STRONG_INLINE std::complex<double> predux<Packet1cd>(
const Packet1cd& a) {
657EIGEN_STRONG_INLINE std::complex<double> predux_mul<Packet1cd>(
const Packet1cd& a) {
661EIGEN_MAKE_CONJ_HELPER_CPLX_REAL(Packet1cd, Packet2d)
664EIGEN_STRONG_INLINE Packet1cd pdiv<Packet1cd>(
const Packet1cd& a,
const Packet1cd& b) {
665 return pdiv_complex(a, b);
668EIGEN_STRONG_INLINE Packet1cd pcplxflip (
const Packet1cd& x) {
669 return Packet1cd(preverse(Packet2d(x.v)));
672EIGEN_STRONG_INLINE
void ptranspose(PacketBlock<Packet1cd, 2>& kernel) {
673 Packet2d tmp = vcombine_f64(vget_high_f64(kernel.packet[0].v), vget_high_f64(kernel.packet[1].v));
674 kernel.packet[0].v = vcombine_f64(vget_low_f64(kernel.packet[0].v), vget_low_f64(kernel.packet[1].v));
675 kernel.packet[1].v = tmp;
679EIGEN_STRONG_INLINE Packet1cd psqrt<Packet1cd>(
const Packet1cd& a) {
680 return psqrt_complex<Packet1cd>(a);
684EIGEN_STRONG_INLINE Packet1cd plog<Packet1cd>(
const Packet1cd& a) {
685 return plog_complex(a);
@ Aligned16
Definition Constants.h:237
Namespace containing all symbols from the Eigen library.
Definition Core:137