Blaze  3.6
SqrAbs.h
Go to the documentation of this file.
1 //=================================================================================================
33 //=================================================================================================
34 
35 #ifndef _BLAZE_MATH_FUNCTORS_SQRABS_H_
36 #define _BLAZE_MATH_FUNCTORS_SQRABS_H_
37 
38 
39 //*************************************************************************************************
40 // Includes
41 //*************************************************************************************************
42 
45 #include <blaze/math/simd/Conj.h>
46 #include <blaze/math/simd/Mult.h>
69 #include <blaze/system/Inline.h>
71 
72 
73 namespace blaze {
74 
75 //=================================================================================================
76 //
77 // CLASS DEFINITION
78 //
79 //=================================================================================================
80 
81 //*************************************************************************************************
85 struct SqrAbs
86 {
87  //**********************************************************************************************
93  template< typename T >
94  BLAZE_ALWAYS_INLINE BLAZE_DEVICE_CALLABLE decltype(auto) operator()( const T& a ) const
95  {
96  return a * conj( a );
97  }
98  //**********************************************************************************************
99 
100  //**********************************************************************************************
105  template< typename T >
106  static constexpr bool simdEnabled() { return HasSIMDMult_v<T,T> && HasSIMDConj_v<T>; }
107  //**********************************************************************************************
108 
109  //**********************************************************************************************
114  static constexpr bool paddingEnabled() { return true; }
115  //**********************************************************************************************
116 
117  //**********************************************************************************************
123  template< typename T >
124  BLAZE_ALWAYS_INLINE decltype(auto) load( const T& a ) const
125  {
127  return a * conj( a );
128  }
129  //**********************************************************************************************
130 };
131 //*************************************************************************************************
132 
133 
134 
135 
136 //=================================================================================================
137 //
138 // YIELDSUNIFORM SPECIALIZATIONS
139 //
140 //=================================================================================================
141 
142 //*************************************************************************************************
144 template< typename T >
145 struct YieldsUniform<SqrAbs,T>
146  : public IsUniform<T>
147 {};
149 //*************************************************************************************************
150 
151 
152 
153 
154 //=================================================================================================
155 //
156 // YIELDSSYMMETRIC SPECIALIZATIONS
157 //
158 //=================================================================================================
159 
160 //*************************************************************************************************
162 template< typename MT >
163 struct YieldsSymmetric<SqrAbs,MT>
164  : public BoolConstant< IsSymmetric_v<MT> || IsHermitian_v<MT> >
165 {};
167 //*************************************************************************************************
168 
169 
170 
171 
172 //=================================================================================================
173 //
174 // YIELDSLOWER SPECIALIZATIONS
175 //
176 //=================================================================================================
177 
178 //*************************************************************************************************
180 template< typename MT >
181 struct YieldsLower<SqrAbs,MT>
182  : public IsLower<MT>
183 {};
185 //*************************************************************************************************
186 
187 
188 
189 
190 //=================================================================================================
191 //
192 // YIELDSUNILOWER SPECIALIZATIONS
193 //
194 //=================================================================================================
195 
196 //*************************************************************************************************
198 template< typename MT >
199 struct YieldsUniLower<SqrAbs,MT>
200  : public IsUniLower<MT>
201 {};
203 //*************************************************************************************************
204 
205 
206 
207 
208 //=================================================================================================
209 //
210 // YIELDSSTRICTLYLOWER SPECIALIZATIONS
211 //
212 //=================================================================================================
213 
214 //*************************************************************************************************
216 template< typename MT >
217 struct YieldsStrictlyLower<SqrAbs,MT>
218  : public IsStrictlyLower<MT>
219 {};
221 //*************************************************************************************************
222 
223 
224 
225 
226 //=================================================================================================
227 //
228 // YIELDSUPPER SPECIALIZATIONS
229 //
230 //=================================================================================================
231 
232 //*************************************************************************************************
234 template< typename MT >
235 struct YieldsUpper<SqrAbs,MT>
236  : public IsUpper<MT>
237 {};
239 //*************************************************************************************************
240 
241 
242 
243 
244 //=================================================================================================
245 //
246 // YIELDSUNIUPPER SPECIALIZATIONS
247 //
248 //=================================================================================================
249 
250 //*************************************************************************************************
252 template< typename MT >
253 struct YieldsUniUpper<SqrAbs,MT>
254  : public IsUniUpper<MT>
255 {};
257 //*************************************************************************************************
258 
259 
260 
261 
262 //=================================================================================================
263 //
264 // YIELDSSTRICTLYUPPER SPECIALIZATIONS
265 //
266 //=================================================================================================
267 
268 //*************************************************************************************************
270 template< typename MT >
271 struct YieldsStrictlyUpper<SqrAbs,MT>
272  : public IsStrictlyUpper<MT>
273 {};
275 //*************************************************************************************************
276 
277 
278 
279 
280 //=================================================================================================
281 //
282 // YIELDSZERO SPECIALIZATIONS
283 //
284 //=================================================================================================
285 
286 //*************************************************************************************************
288 template< typename T >
289 struct YieldsZero<SqrAbs,T>
290  : public IsZero<T>
291 {};
293 //*************************************************************************************************
294 
295 } // namespace blaze
296 
297 #endif
Generic wrapper for the squared abs() function.
Definition: SqrAbs.h:85
Header file for the IsUniUpper type trait.
Header file for the YieldsStrictlyLower type trait.
Header file for the YieldsZero type trait.
Header file for the HasSIMDConj type trait.
Header file for the SIMD multiplication functionality.
Header file for the IsUniLower type trait.
static constexpr bool paddingEnabled()
Returns whether the operation supports padding, i.e. whether it can deal with zeros.
Definition: SqrAbs.h:114
#define BLAZE_CONSTRAINT_MUST_BE_SIMD_PACK(T)
Constraint on the data type.In case the given data type T is not a SIMD pack, a compilation error is ...
Definition: SIMDPack.h:60
static constexpr bool simdEnabled()
Returns whether SIMD is enabled for the specified data type T.
Definition: SqrAbs.h:106
Header file for the SIMD conj functionality.
Header file for the IsUniform type trait.
Header file for the IsStrictlyUpper type trait.
Header file for the IsSymmetric type trait.
Namespace of the Blaze C++ math library.
Definition: Blaze.h:58
#define BLAZE_ALWAYS_INLINE
Platform dependent setup of an enforced inline keyword.
Definition: Inline.h:85
Header file for the YieldsStrictlyUpper type trait.
Header file for the YieldsUniLower type trait.
Header file for the IsLower type trait.
decltype(auto) BLAZE_ALWAYS_INLINE load(const T &a) const
Returns the result of the squared abs() function for the given SIMD vector.
Definition: SqrAbs.h:124
Constraint on the data type.
Header file for the IsStrictlyLower type trait.
Header file for the conjugate shim.
Header file for the HasSIMDMult type trait.
Header file for the YieldsUniform type trait.
Header file for the YieldsSymmetric type trait.
Header file for the YieldsUpper type trait.
Header file for the IsZero type trait.
Header file for the YieldsLower type trait.
IntegralConstant< bool, B > BoolConstant
Generic wrapper for a compile time constant boolean value.The BoolConstant alias template represents ...
Definition: IntegralConstant.h:110
Macro for CUDA compatibility.
Header file for the IntegralConstant class template.
#define BLAZE_DEVICE_CALLABLE
Conditional macro that sets host and device attributes when compiled with CUDA.
Definition: HostDevice.h:94
Header file for the IsUpper type trait.
Header file for the YieldsUniUpper type trait.
decltype(auto) conj(const DenseMatrix< MT, SO > &dm)
Returns a matrix containing the complex conjugate of each single element of dm.
Definition: DMatMapExpr.h:1324
Header file for the IsHermitian type trait.
System settings for the inline keywords.