// fbc_cv is free software and uses the same licence as OpenCV // Email: fengbingchun@163.com #ifndef FBC_CV_CORE_SATURATE_HPP_ #define FBC_CV_CORE_SATURATE_HPP_ // reference: include/opencv2/core/saturate.hpp #include #include #include "fbcdef.hpp" #include "interface.hpp" #include "fast_math.hpp" namespace yt_tinycv { template static inline _Tp saturate_cast(uchar v) { return _Tp(v); } template static inline _Tp saturate_cast(schar v) { return _Tp(v); } template static inline _Tp saturate_cast(ushort v) { return _Tp(v); } template static inline _Tp saturate_cast(short v) { return _Tp(v); } template static inline _Tp saturate_cast(unsigned int v) { return _Tp(v); } template static inline _Tp saturate_cast(int v) { return _Tp(v); } template static inline _Tp saturate_cast(float v) { return _Tp(v); } template static inline _Tp saturate_cast(double v) { return _Tp(v); } template<> inline uchar saturate_cast(schar v) { return (uchar)std::max((int)v, 0); } template<> inline uchar saturate_cast(ushort v) { return (uchar)std::min((unsigned)v, (unsigned)UCHAR_MAX); } template<> inline uchar saturate_cast(int v) { return (uchar)((unsigned)v <= UCHAR_MAX ? v : v > 0 ? UCHAR_MAX : 0); } template<> inline uchar saturate_cast(short v) { return saturate_cast((int)v); } template<> inline uchar saturate_cast(unsigned int v) { return (uchar)std::min(v, (unsigned)UCHAR_MAX); } template<> inline uchar saturate_cast(float v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline uchar saturate_cast(double v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline schar saturate_cast(uchar v) { return (schar)std::min((int)v, SCHAR_MAX); } template<> inline schar saturate_cast(ushort v) { return (schar)std::min((unsigned)v, (unsigned)SCHAR_MAX); } template<> inline schar saturate_cast(int v) { return (schar)((unsigned)(v-SCHAR_MIN) <= (unsigned)UCHAR_MAX ? v : v > 0 ? SCHAR_MAX : SCHAR_MIN); } template<> inline schar saturate_cast(short v) { return saturate_cast((int)v); } template<> inline schar saturate_cast(unsigned v) { return (schar)std::min(v, (unsigned)SCHAR_MAX); } template<> inline schar saturate_cast(float v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline schar saturate_cast(double v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline ushort saturate_cast(schar v) { return (ushort)std::max((int)v, 0); } template<> inline ushort saturate_cast(short v) { return (ushort)std::max((int)v, 0); } template<> inline ushort saturate_cast(int v) { return (ushort)((unsigned)v <= (unsigned)USHRT_MAX ? v : v > 0 ? USHRT_MAX : 0); } template<> inline ushort saturate_cast(unsigned v) { return (ushort)std::min(v, (unsigned)USHRT_MAX); } template<> inline ushort saturate_cast(float v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline ushort saturate_cast(double v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline short saturate_cast(ushort v) { return (short)std::min((int)v, SHRT_MAX); } template<> inline short saturate_cast(int v) { return (short)((unsigned)(v - SHRT_MIN) <= (unsigned)USHRT_MAX ? v : v > 0 ? SHRT_MAX : SHRT_MIN); } template<> inline short saturate_cast(unsigned v) { return (short)std::min(v, (unsigned)SHRT_MAX); } template<> inline short saturate_cast(float v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline short saturate_cast(double v) { int iv = fbcRound(v); return saturate_cast(iv); } template<> inline int saturate_cast(float v) { return fbcRound(v); } template<> inline int saturate_cast(double v) { return fbcRound(v); } template<> inline unsigned saturate_cast(float v) { return fbcRound(v); } template<> inline unsigned saturate_cast(double v) { return fbcRound(v); } } // yt_tinycv #endif // FBC_CV_CORE_SATURATE_HPP_