123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- // -*- C++ -*-
- //===---------------------- support/win32/math_win32.h --------------------===//
- //
- // The LLVM Compiler Infrastructure
- //
- // This file is dual licensed under the MIT and the University of Illinois Open
- // Source Licenses. See LICENSE.TXT for details.
- //
- //===----------------------------------------------------------------------===//
- #ifndef _LIBCPP_SUPPORT_WIN32_MATH_WIN32_H
- #define _LIBCPP_SUPPORT_WIN32_MATH_WIN32_H
- #if !defined(_LIBCPP_MSVCRT)
- #error "This header complements Microsoft's C Runtime library, and should not be included otherwise."
- #else
- #include <math.h>
- #include <float.h> // _FPCLASS_PN etc.
- #include <crtversion.h>
- #if ((_VC_CRT_MAJOR_VERSION-0) < 12)
- // Necessary?
- typedef float float_t;
- typedef double double_t;
- _LIBCPP_ALWAYS_INLINE bool isfinite( double num )
- {
- return _finite(num) != 0;
- }
- _LIBCPP_ALWAYS_INLINE bool isinf( double num )
- {
- return !isfinite(num) && !_isnan(num);
- }
- _LIBCPP_ALWAYS_INLINE bool isnan( double num )
- {
- return _isnan(num) != 0;
- }
- _LIBCPP_ALWAYS_INLINE bool isnormal( double num )
- {
- int class_ = _fpclass(num);
- return class_ == _FPCLASS_NN || class_ == _FPCLASS_PN;
- }
- _LIBCPP_ALWAYS_INLINE bool isgreater( double x, double y )
- {
- if(_fpclass(x) == _FPCLASS_SNAN || _fpclass(y) == _FPCLASS_SNAN) return false;
- else return x > y;
- }
- _LIBCPP_ALWAYS_INLINE bool isgreaterequal( double x, double y )
- {
- if(_fpclass(x) == _FPCLASS_SNAN || _fpclass(y) == _FPCLASS_SNAN) return false;
- else return x >= y;
- }
- _LIBCPP_ALWAYS_INLINE bool isless( double x, double y )
- {
- if(_fpclass(x) == _FPCLASS_SNAN || _fpclass(y) == _FPCLASS_SNAN) return false;
- else return x < y;
- }
- _LIBCPP_ALWAYS_INLINE bool islessequal( double x, double y )
- {
- if(::_fpclass(x) == _FPCLASS_SNAN || ::_fpclass(y) == _FPCLASS_SNAN) return false;
- else return x <= y;
- }
- _LIBCPP_ALWAYS_INLINE bool islessgreater( double x, double y )
- {
- if(::_fpclass(x) == _FPCLASS_SNAN || ::_fpclass(y) == _FPCLASS_SNAN) return false;
- else return x < y || x > y;
- }
- _LIBCPP_ALWAYS_INLINE bool isunordered( double x, double y )
- {
- return isnan(x) || isnan(y);
- }
- _LIBCPP_ALWAYS_INLINE bool signbit( double num )
- {
- switch(_fpclass(num))
- {
- case _FPCLASS_SNAN:
- case _FPCLASS_QNAN:
- case _FPCLASS_NINF:
- case _FPCLASS_NN:
- case _FPCLASS_ND:
- case _FPCLASS_NZ:
- return true;
- case _FPCLASS_PZ:
- case _FPCLASS_PD:
- case _FPCLASS_PN:
- case _FPCLASS_PINF:
- return false;
- }
- return false;
- }
- _LIBCPP_ALWAYS_INLINE float copysignf( float x, float y )
- {
- return (signbit (x) != signbit (y) ? - x : x);
- }
- _LIBCPP_ALWAYS_INLINE double copysign( double x, double y )
- {
- return ::_copysign(x,y);
- }
- _LIBCPP_ALWAYS_INLINE double copysignl( long double x, long double y )
- {
- return ::_copysignl(x,y);
- }
- _LIBCPP_ALWAYS_INLINE int fpclassify( double num )
- {
- return _fpclass(num);
- }
- #endif
- #endif // _LIBCPP_MSVCRT
- #endif // _LIBCPP_SUPPORT_WIN32_MATH_WIN32_H
|