8 #ifndef EIGEN_MATH_FUNCTIONS_NEON_H 9 #define EIGEN_MATH_FUNCTIONS_NEON_H 12 #include "../../InternalHeaderCheck.h" 18 EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_FLOAT(Packet2f)
19 EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_FLOAT(Packet4f)
21 #if EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 23 EIGEN_STRONG_INLINE EIGEN_DEVICE_FUNC Packet4hf ptanh<Packet4hf>(
const Packet4hf& x) {
25 return vcvt_f16_f32(ptanh<Packet4f>(vcvt_f32_f16(x)));
29 EIGEN_STRONG_INLINE EIGEN_DEVICE_FUNC Packet8hf ptanh<Packet8hf>(
const Packet8hf& x) {
31 return vcombine_f16(vcvt_f16_f32(ptanh<Packet4f>(vcvt_f32_f16(vget_low_f16(x)))),
32 vcvt_f16_f32(ptanh<Packet4f>(vcvt_high_f32_f16(x))));
34 #endif // EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC 36 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, psin)
37 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, pcos)
38 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, plog)
39 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, pexp)
40 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, pexp2)
41 BF16_PACKET_FUNCTION(Packet4f, Packet4bf, ptanh)
44 EIGEN_STRONG_INLINE Packet4bf pfrexp(
const Packet4bf& a, Packet4bf& exponent) {
46 const Packet4bf out = F32ToBf16(pfrexp<Packet4f>(Bf16ToF32(a), fexponent));
47 exponent = F32ToBf16(fexponent);
52 EIGEN_STRONG_INLINE Packet4bf pldexp(
const Packet4bf& a,
const Packet4bf& exponent) {
53 return F32ToBf16(pldexp<Packet4f>(Bf16ToF32(a), Bf16ToF32(exponent)));
58 #if EIGEN_ARCH_ARM64 && !EIGEN_APPLE_DOUBLE_NEON_BUG 60 EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_DOUBLE(Packet2d)
68 #endif // EIGEN_MATH_FUNCTIONS_NEON_H Namespace containing all symbols from the Eigen library.
Definition: B01_Experimental.dox:1