Medial Code Documentation
Loading...
Searching...
No Matches
MathFunctions.h
1// This file is part of Eigen, a lightweight C++ template library
2// for linear algebra.
3//
4// Copyright (C) 2007 Julien Pommier
5// Copyright (C) 2009 Gael Guennebaud <gael.guennebaud@inria.fr>
6// Copyright (C) 2016 Konstantinos Margaritis <markos@freevec.org>
7//
8// This Source Code Form is subject to the terms of the Mozilla
9// Public License v. 2.0. If a copy of the MPL was not distributed
10// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
11
12#ifndef EIGEN_MATH_FUNCTIONS_ALTIVEC_H
13#define EIGEN_MATH_FUNCTIONS_ALTIVEC_H
14
15namespace Eigen {
16
17namespace internal {
18
19template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
20Packet4f plog<Packet4f>(const Packet4f& _x)
21{
22 return plog_float(_x);
23}
24
25template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
26Packet4f pexp<Packet4f>(const Packet4f& _x)
27{
28 return pexp_float(_x);
29}
30
31template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
32Packet4f psin<Packet4f>(const Packet4f& _x)
33{
34 return psin_float(_x);
35}
36
37template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
38Packet4f pcos<Packet4f>(const Packet4f& _x)
39{
40 return pcos_float(_x);
41}
42
43#ifdef EIGEN_VECTORIZE_VSX
44#ifndef EIGEN_COMP_CLANG
45template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
46Packet4f prsqrt<Packet4f>(const Packet4f& x)
47{
48 return vec_rsqrt(x);
49}
50
51template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
52Packet2d prsqrt<Packet2d>(const Packet2d& x)
53{
54 return vec_rsqrt(x);
55}
56#endif
57
58template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS
59Packet4f psqrt<Packet4f>(const Packet4f& x)
60{
61 return vec_sqrt(x);
62}
63
64template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED
65Packet2d psqrt<Packet2d>(const Packet2d& x)
66{
67 return vec_sqrt(x);
68}
69
70#if !EIGEN_COMP_CLANG
71template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS
72Packet4f prsqrt<Packet4f>(const Packet4f& x)
73{
74 return pset1<Packet4f>(1.0f) / psqrt<Packet4f>(x);
75// vec_rsqrt returns different results from the generic version
76// return vec_rsqrt(x);
77}
78
79template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS
80Packet2d prsqrt<Packet2d>(const Packet2d& x)
81{
82 return pset1<Packet2d>(1.0) / psqrt<Packet2d>(x);
83// vec_rsqrt returns different results from the generic version
84// return vec_rsqrt(x);
85}
86#endif
87
88template<> EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS
89Packet2d pexp<Packet2d>(const Packet2d& _x)
90{
91 return pexp_double(_x);
92}
93
94template<> EIGEN_STRONG_INLINE Packet8bf psqrt<Packet8bf> (const Packet8bf& a){
95 BF16_TO_F32_UNARY_OP_WRAPPER(vec_sqrt, a);
96}
97
98template<> EIGEN_STRONG_INLINE Packet8bf prsqrt<Packet8bf> (const Packet8bf& a){
99 BF16_TO_F32_UNARY_OP_WRAPPER(prsqrt<Packet4f>, a);
100}
101
102template<> EIGEN_STRONG_INLINE Packet8bf pexp<Packet8bf> (const Packet8bf& a){
103 BF16_TO_F32_UNARY_OP_WRAPPER(pexp_float, a);
104}
105
106#endif // EIGEN_VECTORIZE_VSX
107
108// Hyperbolic Tangent function.
109template <>
110EIGEN_DEFINE_FUNCTION_ALLOWING_MULTIPLE_DEFINITIONS EIGEN_UNUSED Packet4f
111ptanh<Packet4f>(const Packet4f& x) {
112 return internal::generic_fast_tanh_float(x);
113}
114
115} // end namespace internal
116
117} // end namespace Eigen
118
119#endif // EIGEN_MATH_FUNCTIONS_ALTIVEC_H
Namespace containing all symbols from the Eigen library.
Definition LDLT.h:16