Commit 75adb698 authored by Alexander Alekhin's avatar Alexander Alekhin

Merge pull request #875 from sovrasov:fix_balance_white

parents afd8a833 be70e0b7
...@@ -123,7 +123,7 @@ void balanceWhiteSimple(std::vector<Mat_<T> > &src, Mat &dst, const float inputM ...@@ -123,7 +123,7 @@ void balanceWhiteSimple(std::vector<Mat_<T> > &src, Mat &dst, const float inputM
n2 -= hist[p2--]; n2 -= hist[p2--];
maxValue -= interval; maxValue -= interval;
} }
p2 = p2 * bins - 1; p2 = (p2 + 1) * bins - 1;
interval /= bins; interval /= bins;
} }
......
...@@ -5,8 +5,7 @@ namespace cvtest ...@@ -5,8 +5,7 @@ namespace cvtest
TEST(xphoto_simplecolorbalance, regression) TEST(xphoto_simplecolorbalance, regression)
{ {
cv::String dir = cvtest::TS::ptr()->get_data_path() + "cv/xphoto/simple_white_balance/"; cv::String dir = cvtest::TS::ptr()->get_data_path() + "cv/xphoto/simple_white_balance/";
int nTests = 12; int nTests = 8;
float threshold = 0.005f;
cv::Ptr<cv::xphoto::WhiteBalancer> wb = cv::xphoto::createSimpleWB(); cv::Ptr<cv::xphoto::WhiteBalancer> wb = cv::xphoto::createSimpleWB();
for (int i = 0; i < nTests; ++i) for (int i = 0; i < nTests; ++i)
...@@ -15,17 +14,41 @@ namespace cvtest ...@@ -15,17 +14,41 @@ namespace cvtest
cv::Mat src = cv::imread( srcName, 1 ); cv::Mat src = cv::imread( srcName, 1 );
ASSERT_TRUE(!src.empty()); ASSERT_TRUE(!src.empty());
cv::String previousResultName = dir + cv::format( "results/%02d.png", i + 1 ); cv::String previousResultName = dir + cv::format( "results/%02d.jpg", i + 1 );
cv::Mat previousResult = cv::imread( previousResultName, 1 ); cv::Mat previousResult = cv::imread( previousResultName, 1 );
cv::Mat currentResult; cv::Mat currentResult;
wb->balanceWhite(src, currentResult); wb->balanceWhite(src, currentResult);
cv::Mat sqrError = ( currentResult - previousResult ) double psnr = cv::PSNR(currentResult, previousResult);
.mul( currentResult - previousResult );
cv::Scalar mse = cv::sum(sqrError) / cv::Scalar::all( double( sqrError.total()*sqrError.channels() ) );
EXPECT_LE( mse[0]+mse[1]+mse[2]+mse[3], threshold ); EXPECT_GE( psnr, 30 );
} }
} }
TEST(xphoto_simplecolorbalance, max_value)
{
const float oldMax = 24000., newMax = 65536.;
Mat test = Mat::zeros(3,3,CV_32FC1);
test.at<float>(0, 0) = oldMax;
test.at<float>(0, 1) = oldMax / 2;
test.at<float>(0, 2) = oldMax / 4;
double minSrc, maxSrc;
cv::minMaxIdx(test, &minSrc, &maxSrc);
cv::Ptr<cv::xphoto::SimpleWB> wb = cv::xphoto::createSimpleWB();
wb->setInputMin((float)minSrc);
wb->setInputMax((float)maxSrc);
wb->setOutputMin(0);
wb->setOutputMax(newMax);
wb->balanceWhite(test, test);
double minDst, maxDst;
cv::minMaxIdx(test, &minDst, &maxDst);
ASSERT_NEAR(maxDst, newMax, newMax*1e-4);
}
} }
...@@ -66,7 +66,7 @@ namespace cvtest { ...@@ -66,7 +66,7 @@ namespace cvtest {
TEST(xphoto_grayworld_white_balance, regression) TEST(xphoto_grayworld_white_balance, regression)
{ {
String dir = cvtest::TS::ptr()->get_data_path() + "cv/xphoto/simple_white_balance/"; String dir = cvtest::TS::ptr()->get_data_path() + "cv/xphoto/simple_white_balance/";
const int nTests = 14; const int nTests = 8;
const float wb_thresh = 0.5f; const float wb_thresh = 0.5f;
const float acc_thresh = 2.f; const float acc_thresh = 2.f;
Ptr<xphoto::GrayworldWB> wb = xphoto::createGrayworldWB(); Ptr<xphoto::GrayworldWB> wb = xphoto::createGrayworldWB();
......
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