STLdoc
STLdocumentation
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
Static Public Member Functions | List of all members
_Ctraits< _Ty > Class Template Reference

Static Public Member Functions

static _Ty _Flt_eps ()
 
static _Ty _Flt_max ()
 
static _Ty _Cosh (_Ty _Left, _Ty _Right)
 
static short _Exp (_Ty *_Pleft, _Ty _Right, short _Exponent)
 
static _Ty _Infv ()
 
static bool _Isinf (_Ty _Left)
 
static bool _Isnan (_Ty _Left)
 
static _Ty _Nanv ()
 
static _Ty _Sinh (_Ty _Left, _Ty _Right)
 
static _Ty asinh (_Ty _Left)
 
static _Ty atan2 (_Ty _Yval, _Ty _Xval)
 
static _Ty cos (_Ty _Left)
 
static _Ty exp (_Ty _Left)
 
static _Ty ldexp (_Ty _Left, int _Exponent)
 
static _Ty log (_Ty _Left)
 
static _Ty log1p (_Ty _Left)
 
static _Ty pow (_Ty _Left, _Ty _Right)
 
static _Ty sin (_Ty _Left)
 
static _Ty sqrt (_Ty _Left)
 
static _Ty tan (_Ty _Left)
 

Member Function Documentation

template<class _Ty >
static _Ty _Ctraits< _Ty >::_Cosh ( _Ty  _Left,
_Ty  _Right 
)
inlinestatic
70  { // return cosh(_Left) * _Right
71  return (_CSTD _Cosh((double)_Left, (double)_Right));
72  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty _Cosh(_Ty _Left, _Ty _Right)
Definition: complex:69
#define _CSTD
Definition: yvals.h:570
constexpr const _Ty &() _Right
Definition: algorithm:3723
template<class _Ty >
static short _Ctraits< _Ty >::_Exp ( _Ty *  _Pleft,
_Ty  _Right,
short  _Exponent 
)
inlinestatic
75  { // compute exp(*_Pleft) * _Right * 2 ^ _Exponent
76  double _Tmp = (double)*_Pleft;
77  short _Ans = _CSTD _Exp(&_Tmp, (double)_Right, _Exponent);
78  *_Pleft = (_Ty)_Tmp;
79  return (_Ans);
80  }
#define _CSTD
Definition: yvals.h:570
static short _Exp(_Ty *_Pleft, _Ty _Right, short _Exponent)
Definition: complex:74
constexpr const _Ty &() _Right
Definition: algorithm:3723
template<class _Ty >
static _Ty _Ctraits< _Ty >::_Flt_eps ( )
inlinestatic
60  { // get epsilon
62  }
Definition: limits:102
template<class _Ty >
static _Ty _Ctraits< _Ty >::_Flt_max ( )
inlinestatic
65  { // get max
66  return ((numeric_limits<_Ty>::max)());
67  }
Definition: limits:102
template<class _Ty >
static _Ty _Ctraits< _Ty >::_Infv ( )
inlinestatic
83  { // return infinity
85  }
Definition: limits:102
template<class _Ty >
static bool _Ctraits< _Ty >::_Isinf ( _Ty  _Left)
inlinestatic
88  { // test for infinity
89  double _Tmp = (double)_Left;
90  return (_CSTD _Dtest(&_Tmp) == _INFCODE);
91  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
#define _INFCODE
Definition: corecrt_math.h:97
#define _CSTD
Definition: yvals.h:570
_CRTIMP2_PURE short __CLRCALL_PURE_OR_CDECL _Dtest(double *)
template<class _Ty >
static bool _Ctraits< _Ty >::_Isnan ( _Ty  _Left)
inlinestatic
94  { // test for NaN
95  double _Tmp = (double)_Left;
96  return (_CSTD _Dtest(&_Tmp) == _NANCODE);
97  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
#define _NANCODE
Definition: corecrt_math.h:98
#define _CSTD
Definition: yvals.h:570
_CRTIMP2_PURE short __CLRCALL_PURE_OR_CDECL _Dtest(double *)
template<class _Ty >
static _Ty _Ctraits< _Ty >::_Nanv ( )
inlinestatic
100  { // return NaN
102  }
Definition: limits:102
template<class _Ty >
static _Ty _Ctraits< _Ty >::_Sinh ( _Ty  _Left,
_Ty  _Right 
)
inlinestatic
105  { // return sinh(_Left) * _Right
106  return (_CSTD _Sinh((double)_Left, (double)_Right));
107  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty _Sinh(_Ty _Left, _Ty _Right)
Definition: complex:104
#define _CSTD
Definition: yvals.h:570
constexpr const _Ty &() _Right
Definition: algorithm:3723
template<class _Ty >
static _Ty _Ctraits< _Ty >::asinh ( _Ty  _Left)
inlinestatic
110  { // return asinh(_Left)
111  constexpr _Ty _Ln2 = 0.69314718055994530941723212145817658L;
112 
113  bool _Neg = _Left < 0;
114  _Ty _Ans;
115 
116  if (_Neg)
117  _Left = -_Left;
118  if (_Left < 2 / _Flt_eps())
119  _Ans = log1p(_Left
120  + _Left * _Left / (1 + sqrt(_Left * _Left + 1)));
121  else
122  _Ans = log(_Left) + _Ln2;
123  return (_Neg ? -_Ans : _Ans);
124  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty sqrt(_Ty _Left)
Definition: complex:174
static _Ty log(_Ty _Left)
Definition: complex:146
static _Ty log1p(_Ty _Left)
Definition: complex:151
static _Ty _Flt_eps()
Definition: complex:59
template<class _Ty >
static _Ty _Ctraits< _Ty >::atan2 ( _Ty  _Yval,
_Ty  _Xval 
)
inlinestatic
127  { // return atan(_Yval / _Xval)
128  return (_CSTD atan2((double)_Yval, (double)_Xval));
129  }
static _Ty atan2(_Ty _Yval, _Ty _Xval)
Definition: complex:126
#define _CSTD
Definition: yvals.h:570
template<class _Ty >
static _Ty _Ctraits< _Ty >::cos ( _Ty  _Left)
inlinestatic
132  { // return cos(_Left)
133  return (_CSTD cos((double)_Left));
134  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
#define _CSTD
Definition: yvals.h:570
static _Ty cos(_Ty _Left)
Definition: complex:131
template<class _Ty >
static _Ty _Ctraits< _Ty >::exp ( _Ty  _Left)
inlinestatic
137  { // return exp(_Left)
138  return (_CSTD exp((double)_Left));
139  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty exp(_Ty _Left)
Definition: complex:136
#define _CSTD
Definition: yvals.h:570
template<class _Ty >
static _Ty _Ctraits< _Ty >::ldexp ( _Ty  _Left,
int  _Exponent 
)
inlinestatic
142  { // return _Left * 2 ^ _Exponent
143  return (_CSTD ldexp((double)_Left, _Exponent));
144  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
#define _CSTD
Definition: yvals.h:570
static _Ty ldexp(_Ty _Left, int _Exponent)
Definition: complex:141
template<class _Ty >
static _Ty _Ctraits< _Ty >::log ( _Ty  _Left)
inlinestatic
147  { // return log(_Left)
148  return (_CSTD log((double)_Left));
149  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty log(_Ty _Left)
Definition: complex:146
#define _CSTD
Definition: yvals.h:570
template<class _Ty >
static _Ty _Ctraits< _Ty >::log1p ( _Ty  _Left)
inlinestatic
152  { // return log(1 + _Left)
153  if (_Left < -1)
154  return (_Nanv());
155  else if (_Left == 0)
156  return (_Left);
157  else
158  { // compute log(1 + _Left) with fixup for small _Left
159  _Ty _Leftp1 = 1 + _Left;
160  return (log(_Leftp1) - ((_Leftp1 - 1) - _Left) / _Leftp1);
161  }
162  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty log(_Ty _Left)
Definition: complex:146
static _Ty _Nanv()
Definition: complex:99
template<class _Ty >
static _Ty _Ctraits< _Ty >::pow ( _Ty  _Left,
_Ty  _Right 
)
inlinestatic
165  { // return _Left ^ _Right
166  return (_CSTD pow((double)_Left, (double)_Right));
167  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty pow(_Ty _Left, _Ty _Right)
Definition: complex:164
#define _CSTD
Definition: yvals.h:570
constexpr const _Ty &() _Right
Definition: algorithm:3723
template<class _Ty >
static _Ty _Ctraits< _Ty >::sin ( _Ty  _Left)
inlinestatic
170  { // return sin(_Left)
171  return (_CSTD sin((double)_Left));
172  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
#define _CSTD
Definition: yvals.h:570
static _Ty sin(_Ty _Left)
Definition: complex:169
template<class _Ty >
static _Ty _Ctraits< _Ty >::sqrt ( _Ty  _Left)
inlinestatic
175  { // return sqrt(_Left)
176  return (_CSTD sqrt((double)_Left));
177  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty sqrt(_Ty _Left)
Definition: complex:174
#define _CSTD
Definition: yvals.h:570
template<class _Ty >
static _Ty _Ctraits< _Ty >::tan ( _Ty  _Left)
inlinestatic
180  { // return tan(_Left)
181  return (_CSTD tan((double)_Left));
182  }
constexpr const _Ty &() _Left
Definition: algorithm:3722
static _Ty tan(_Ty _Left)
Definition: complex:179
#define _CSTD
Definition: yvals.h:570

The documentation for this class was generated from the following file: