Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
75adb698
Commit
75adb698
authored
Nov 30, 2016
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #875 from sovrasov:fix_balance_white
parents
afd8a833
be70e0b7
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
32 additions
and
9 deletions
+32
-9
simple_color_balance.cpp
modules/xphoto/src/simple_color_balance.cpp
+1
-1
simple_color_balance.cpp
modules/xphoto/test/simple_color_balance.cpp
+30
-7
test_grayworld.cpp
modules/xphoto/test/test_grayworld.cpp
+1
-1
No files found.
modules/xphoto/src/simple_color_balance.cpp
View file @
75adb698
...
@@ -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
;
}
}
...
...
modules/xphoto/test/simple_color_balance.cpp
View file @
75adb698
...
@@ -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.005
f
;
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.
pn
g"
,
i
+
1
);
cv
::
String
previousResultName
=
dir
+
cv
::
format
(
"results/%02d.
jp
g"
,
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
);
}
}
}
modules/xphoto/test/test_grayworld.cpp
View file @
75adb698
...
@@ -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.5
f
;
const
float
wb_thresh
=
0.5
f
;
const
float
acc_thresh
=
2.
f
;
const
float
acc_thresh
=
2.
f
;
Ptr
<
xphoto
::
GrayworldWB
>
wb
=
xphoto
::
createGrayworldWB
();
Ptr
<
xphoto
::
GrayworldWB
>
wb
=
xphoto
::
createGrayworldWB
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment