limits.hpp 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*M///////////////////////////////////////////////////////////////////////////////////////
  2. //
  3. // IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
  4. //
  5. // By downloading, copying, installing or using the software you agree to this license.
  6. // If you do not agree to this license, do not download, install,
  7. // copy or use the software.
  8. //
  9. //
  10. // License Agreement
  11. // For Open Source Computer Vision Library
  12. //
  13. // Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
  14. // Copyright (C) 2009, Willow Garage Inc., all rights reserved.
  15. // Third party copyrights are property of their respective owners.
  16. //
  17. // Redistribution and use in source and binary forms, with or without modification,
  18. // are permitted provided that the following conditions are met:
  19. //
  20. // * Redistribution's of source code must retain the above copyright notice,
  21. // this list of conditions and the following disclaimer.
  22. //
  23. // * Redistribution's in binary form must reproduce the above copyright notice,
  24. // this list of conditions and the following disclaimer in the documentation
  25. // and/or other materials provided with the distribution.
  26. //
  27. // * The name of the copyright holders may not be used to endorse or promote products
  28. // derived from this software without specific prior written permission.
  29. //
  30. // This software is provided by the copyright holders and contributors "as is" and
  31. // any express or implied warranties, including, but not limited to, the implied
  32. // warranties of merchantability and fitness for a particular purpose are disclaimed.
  33. // In no event shall the Intel Corporation or contributors be liable for any direct,
  34. // indirect, incidental, special, exemplary, or consequential damages
  35. // (including, but not limited to, procurement of substitute goods or services;
  36. // loss of use, data, or profits; or business interruption) however caused
  37. // and on any theory of liability, whether in contract, strict liability,
  38. // or tort (including negligence or otherwise) arising in any way out of
  39. // the use of this software, even if advised of the possibility of such damage.
  40. //
  41. //M*/
  42. #ifndef OPENCV_CUDA_LIMITS_HPP
  43. #define OPENCV_CUDA_LIMITS_HPP
  44. #include <limits.h>
  45. #include <float.h>
  46. #include "common.hpp"
  47. /** @file
  48. * @deprecated Use @ref cudev instead.
  49. */
  50. //! @cond IGNORED
  51. namespace cv { namespace cuda { namespace device
  52. {
  53. template <class T> struct numeric_limits;
  54. template <> struct numeric_limits<bool>
  55. {
  56. __device__ __forceinline__ static bool min() { return false; }
  57. __device__ __forceinline__ static bool max() { return true; }
  58. static const bool is_signed = false;
  59. };
  60. template <> struct numeric_limits<signed char>
  61. {
  62. __device__ __forceinline__ static signed char min() { return SCHAR_MIN; }
  63. __device__ __forceinline__ static signed char max() { return SCHAR_MAX; }
  64. static const bool is_signed = true;
  65. };
  66. template <> struct numeric_limits<unsigned char>
  67. {
  68. __device__ __forceinline__ static unsigned char min() { return 0; }
  69. __device__ __forceinline__ static unsigned char max() { return UCHAR_MAX; }
  70. static const bool is_signed = false;
  71. };
  72. template <> struct numeric_limits<short>
  73. {
  74. __device__ __forceinline__ static short min() { return SHRT_MIN; }
  75. __device__ __forceinline__ static short max() { return SHRT_MAX; }
  76. static const bool is_signed = true;
  77. };
  78. template <> struct numeric_limits<unsigned short>
  79. {
  80. __device__ __forceinline__ static unsigned short min() { return 0; }
  81. __device__ __forceinline__ static unsigned short max() { return USHRT_MAX; }
  82. static const bool is_signed = false;
  83. };
  84. template <> struct numeric_limits<int>
  85. {
  86. __device__ __forceinline__ static int min() { return INT_MIN; }
  87. __device__ __forceinline__ static int max() { return INT_MAX; }
  88. static const bool is_signed = true;
  89. };
  90. template <> struct numeric_limits<unsigned int>
  91. {
  92. __device__ __forceinline__ static unsigned int min() { return 0; }
  93. __device__ __forceinline__ static unsigned int max() { return UINT_MAX; }
  94. static const bool is_signed = false;
  95. };
  96. template <> struct numeric_limits<float>
  97. {
  98. __device__ __forceinline__ static float min() { return FLT_MIN; }
  99. __device__ __forceinline__ static float max() { return FLT_MAX; }
  100. __device__ __forceinline__ static float epsilon() { return FLT_EPSILON; }
  101. static const bool is_signed = true;
  102. };
  103. template <> struct numeric_limits<double>
  104. {
  105. __device__ __forceinline__ static double min() { return DBL_MIN; }
  106. __device__ __forceinline__ static double max() { return DBL_MAX; }
  107. __device__ __forceinline__ static double epsilon() { return DBL_EPSILON; }
  108. static const bool is_signed = true;
  109. };
  110. }}} // namespace cv { namespace cuda { namespace cudev {
  111. //! @endcond
  112. #endif // OPENCV_CUDA_LIMITS_HPP