Commit 7e06b181 authored by Andrey Pavlenko's avatar Andrey Pavlenko

workaround for the 'Bug #1784 (cvFloor/cvCeil)'; typos fixed; two more tests for checkRange

parent 54001572
...@@ -2032,8 +2032,9 @@ template<> struct mat_type_assotiations<CV_32S> ...@@ -2032,8 +2032,9 @@ template<> struct mat_type_assotiations<CV_32S>
static const type max_allowable = INT_MAX; static const type max_allowable = INT_MAX;
}; };
// inclusive maxVal !!!
template<int depth> template<int depth>
bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double& bad_value) bool checkIntegerRange(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double& bad_value)
{ {
typedef mat_type_assotiations<depth> type_ass; typedef mat_type_assotiations<depth> type_ass;
...@@ -2041,7 +2042,7 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double ...@@ -2041,7 +2042,7 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double
{ {
return true; return true;
} }
else if (minVal >= type_ass::max_allowable || maxVal <= type_ass::min_allowable || maxVal <= minVal) else if (minVal > type_ass::max_allowable || maxVal < type_ass::min_allowable || maxVal < minVal)
{ {
bad_pt = cv::Point(0,0); bad_pt = cv::Point(0,0);
return false; return false;
...@@ -2051,7 +2052,7 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double ...@@ -2051,7 +2052,7 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double
for (int j = 0; j < as_one_channel.rows; ++j) for (int j = 0; j < as_one_channel.rows; ++j)
for (int i = 0; i < as_one_channel.cols; ++i) for (int i = 0; i < as_one_channel.cols; ++i)
{ {
if (as_one_channel.at<typename type_ass::type>(j ,i) < minVal || as_one_channel.at<typename type_ass::type>(j ,i) >= maxVal) if (as_one_channel.at<typename type_ass::type>(j ,i) < minVal || as_one_channel.at<typename type_ass::type>(j ,i) > maxVal)
{ {
bad_pt.y = j ; bad_pt.y = j ;
bad_pt.x = i % src.channels(); bad_pt.x = i % src.channels();
...@@ -2064,15 +2065,15 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double ...@@ -2064,15 +2065,15 @@ bool chackIntegerRang(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double
return true; return true;
} }
typedef bool (*check_pange_function)(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double& bad_value); typedef bool (*check_range_function)(cv::Mat src, Point& bad_pt, int minVal, int maxVal, double& bad_value);
check_pange_function check_range_functions[] = check_range_function check_range_functions[] =
{ {
&chackIntegerRang<CV_8U>, &checkIntegerRange<CV_8U>,
&chackIntegerRang<CV_8S>, &checkIntegerRange<CV_8S>,
&chackIntegerRang<CV_16U>, &checkIntegerRange<CV_16U>,
&chackIntegerRang<CV_16S>, &checkIntegerRange<CV_16S>,
&chackIntegerRang<CV_32S> &checkIntegerRange<CV_32S>
}; };
bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double maxVal) bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double maxVal)
...@@ -2102,8 +2103,9 @@ bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double ma ...@@ -2102,8 +2103,9 @@ bool checkRange(InputArray _src, bool quiet, Point* pt, double minVal, double ma
if (depth < CV_32F) if (depth < CV_32F)
{ {
int minVali = cvFloor(minVal); // see "Bug #1784"
int maxVali = cvCeil(maxVal); int minVali = minVal<(-INT_MAX - 1) ? (-INT_MAX - 1) : cvFloor(minVal);
int maxVali = maxVal>INT_MAX ? INT_MAX : cvCeil(maxVal) - 1; // checkIntegerRang() use inclusive maxVal
(check_range_functions[depth])(src, badPt, minVali, maxVali, badValue); (check_range_functions[depth])(src, badPt, minVali, maxVali, badValue);
} }
......
...@@ -2347,6 +2347,41 @@ void Core_SolvePolyTest::run( int ) ...@@ -2347,6 +2347,41 @@ void Core_SolvePolyTest::run( int )
} }
} }
class Core_CheckRange_Empty : public cvtest::BaseTest
{
public:
Core_CheckRange_Empty(){}
~Core_CheckRange_Empty(){}
protected:
virtual void run( int start_from );
};
void Core_CheckRange_Empty::run( int )
{
cv::Mat m;
ASSERT_TRUE( cv::checkRange(m) );
}
TEST(Core_CheckRange_Empty, accuracy) { Core_CheckRange_Empty test; test.safe_run(); }
class Core_CheckRange_INT_MAX : public cvtest::BaseTest
{
public:
Core_CheckRange_INT_MAX(){}
~Core_CheckRange_INT_MAX(){}
protected:
virtual void run( int start_from );
};
void Core_CheckRange_INT_MAX::run( int )
{
cv::Mat m(3, 3, CV_32SC1, cv::Scalar(INT_MAX));
ASSERT_FALSE( cv::checkRange(m, true, 0, 0, INT_MAX) );
ASSERT_TRUE( cv::checkRange(m) );
}
TEST(Core_CheckRange_INT_MAX, accuracy) { Core_CheckRange_INT_MAX test; test.safe_run(); }
template <typename T> class Core_CheckRange : public testing::Test {}; template <typename T> class Core_CheckRange : public testing::Test {};
TYPED_TEST_CASE_P(Core_CheckRange); TYPED_TEST_CASE_P(Core_CheckRange);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment