8#ifndef EIGEN_MATH_FUNCTIONS_NEON_H
9#define EIGEN_MATH_FUNCTIONS_NEON_H
12#include "../../InternalHeaderCheck.h"
18EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_FLOAT(Packet2f)
19EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_FLOAT(Packet4f)
21#if EIGEN_HAS_ARM64_FP16_VECTOR_ARITHMETIC
23EIGEN_STRONG_INLINE EIGEN_DEVICE_FUNC Packet4hf ptanh<Packet4hf>(
const Packet4hf& x) {
25 return vcvt_f16_f32(ptanh<Packet4f>(vcvt_f32_f16(x)));
29EIGEN_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))));
36BF16_PACKET_FUNCTION(Packet4f, Packet4bf, psin)
37BF16_PACKET_FUNCTION(Packet4f, Packet4bf, pcos)
38BF16_PACKET_FUNCTION(Packet4f, Packet4bf, plog)
39BF16_PACKET_FUNCTION(Packet4f, Packet4bf, pexp)
40BF16_PACKET_FUNCTION(Packet4f, Packet4bf, ptanh)
43EIGEN_STRONG_INLINE Packet4bf pfrexp(
const Packet4bf& a, Packet4bf& exponent) {
45 const Packet4bf out = F32ToBf16(pfrexp<Packet4f>(Bf16ToF32(a), fexponent));
46 exponent = F32ToBf16(fexponent);
51EIGEN_STRONG_INLINE Packet4bf pldexp(
const Packet4bf& a,
const Packet4bf& exponent) {
52 return F32ToBf16(pldexp<Packet4f>(Bf16ToF32(a), Bf16ToF32(exponent)));
57#if EIGEN_ARCH_ARM64 && !EIGEN_APPLE_DOUBLE_NEON_BUG
59EIGEN_INSTANTIATE_GENERIC_MATH_FUNCS_DOUBLE(Packet2d)
Namespace containing all symbols from the Eigen library.
Definition Core:137