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
5dfc2ff4
Commit
5dfc2ff4
authored
Jul 25, 2014
by
jaco
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
templateOrdering bug fixed
parent
80777b19
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
24 additions
and
55 deletions
+24
-55
computeSaliency.cpp
modules/saliency/samples/computeSaliency.cpp
+2
-2
motionSaliencyBinWangApr2014.cpp
modules/saliency/src/motionSaliencyBinWangApr2014.cpp
+22
-53
No files found.
modules/saliency/samples/computeSaliency.cpp
View file @
5dfc2ff4
...
@@ -156,12 +156,12 @@ int main( int argc, char** argv )
...
@@ -156,12 +156,12 @@ int main( int argc, char** argv )
}
}
else
if
(
saliency_algorithm
.
find
(
"BinWangApr2014"
)
==
0
)
else
if
(
saliency_algorithm
.
find
(
"BinWangApr2014"
)
==
0
)
{
{
Ptr
<
Size
>
size
=
Ptr
<
Size
>
(
new
Size
(
64
,
64
)
)
;
Ptr
<
Size
>
size
=
Ptr
<
Size
>
(
new
Size
(
32
,
32
)
)
;
saliencyAlgorithm
.
dynamicCast
<
MotionSaliencyBinWangApr2014
>
()
->
setWsize
(
size
);
saliencyAlgorithm
.
dynamicCast
<
MotionSaliencyBinWangApr2014
>
()
->
setWsize
(
size
);
saliencyAlgorithm
.
dynamicCast
<
MotionSaliencyBinWangApr2014
>
()
->
init
();
saliencyAlgorithm
.
dynamicCast
<
MotionSaliencyBinWangApr2014
>
()
->
init
();
// Create an fake image test
// Create an fake image test
Mat
test
(
64
,
64
,
CV_8U
);
Mat
test
(
32
,
32
,
CV_8U
);
RNG
rand
;
RNG
rand
;
for
(
int
i
=
0
;
i
<
test
.
rows
;
i
++
)
for
(
int
i
=
0
;
i
<
test
.
rows
;
i
++
)
for
(
int
j
=
0
;
j
<
test
.
cols
;
j
++
)
for
(
int
j
=
0
;
j
<
test
.
cols
;
j
++
)
...
...
modules/saliency/src/motionSaliencyBinWangApr2014.cpp
View file @
5dfc2ff4
...
@@ -252,28 +252,29 @@ bool inline pairCompare( pair<float, float> t, pair<float, float> t_plusOne )
...
@@ -252,28 +252,29 @@ bool inline pairCompare( pair<float, float> t, pair<float, float> t_plusOne )
bool
MotionSaliencyBinWangApr2014
::
templateOrdering
()
bool
MotionSaliencyBinWangApr2014
::
templateOrdering
()
{
{
vector
<
pair
<
float
,
float
>
>
pixelTemplates
(
backgroundModel
.
size
()
);
vector
<
pair
<
float
,
float
>
>
pixelTemplates
(
backgroundModel
.
size
()
);
float
temp
;
// Scan all pixels of image
// Scan all pixels of image
for
(
int
i
=
0
;
i
<
backgroundModel
[
0
].
rows
;
i
++
)
for
(
int
i
=
0
;
i
<
backgroundModel
[
0
].
rows
;
i
++
)
{
{
for
(
int
j
=
0
;
j
<
backgroundModel
[
0
].
cols
;
j
++
)
for
(
int
j
=
0
;
j
<
backgroundModel
[
0
].
cols
;
j
++
)
{
{
// scan background model vector from T
2
to Tk
// scan background model vector from T
1
to Tk
for
(
size_t
z
=
2
;
z
<
backgroundModel
.
size
();
z
++
)
for
(
size_t
z
=
1
;
z
<
backgroundModel
.
size
();
z
++
)
{
{
// Fill vector of pairs
// Fill vector of pairs
pixelTemplates
[
z
-
2
].
first
=
backgroundModel
[
z
].
at
<
Vec2f
>
(
i
,
j
)[
0
];
// Current B (background value)
pixelTemplates
[
z
-
1
].
first
=
backgroundModel
[
z
].
at
<
Vec2f
>
(
i
,
j
)[
0
];
// Current B (background value)
pixelTemplates
[
z
-
2
].
second
=
backgroundModel
[
z
].
at
<
Vec2f
>
(
i
,
j
)[
1
];
// Current C (efficacy value)
pixelTemplates
[
z
-
1
].
second
=
backgroundModel
[
z
].
at
<
Vec2f
>
(
i
,
j
)[
1
];
// Current C (efficacy value)
}
}
//SORT template from T
2
to Tk
//SORT template from T
1
to Tk
std
::
sort
(
pixelTemplates
.
begin
(),
pixelTemplates
.
end
(),
pairCompare
);
std
::
sort
(
pixelTemplates
.
begin
(),
pixelTemplates
.
end
(),
pairCompare
);
//REFILL CURRENT MODEL ( T
2
...Tk)
//REFILL CURRENT MODEL ( T
1
...Tk)
for
(
size_t
zz
=
2
;
zz
<
backgroundModel
.
size
();
zz
++
)
for
(
size_t
zz
=
1
;
zz
<
backgroundModel
.
size
();
zz
++
)
{
{
backgroundModel
[
zz
].
at
<
Vec2f
>
(
i
,
j
)[
0
]
=
pixelTemplates
[
zz
-
2
].
first
;
// Replace previous B with new ordered B value
backgroundModel
[
zz
].
at
<
Vec2f
>
(
i
,
j
)[
0
]
=
pixelTemplates
[
zz
-
1
].
first
;
// Replace previous B with new ordered B value
backgroundModel
[
zz
].
at
<
Vec2f
>
(
i
,
j
)[
1
]
=
pixelTemplates
[
zz
-
2
].
second
;
// Replace previous C with new ordered C value
backgroundModel
[
zz
].
at
<
Vec2f
>
(
i
,
j
)[
1
]
=
pixelTemplates
[
zz
-
1
].
second
;
// Replace previous C with new ordered C value
}
}
// SORT Template T0 and T1
// SORT Template T0 and T1
...
@@ -281,10 +282,15 @@ bool MotionSaliencyBinWangApr2014::templateOrdering()
...
@@ -281,10 +282,15 @@ bool MotionSaliencyBinWangApr2014::templateOrdering()
{
{
// swap B value of T0 with B value of T1 (for current model)
// swap B value of T0 with B value of T1 (for current model)
temp
=
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
0
];
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
0
]
=
backgroundModel
[
1
].
at
<
Vec2f
>
(
i
,
j
)[
0
];
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
0
]
=
backgroundModel
[
1
].
at
<
Vec2f
>
(
i
,
j
)[
0
];
backgroundModel
[
1
].
at
<
Vec2f
>
(
i
,
j
)[
0
]
=
temp
;
// set new C0 value for current model)
// set new C0 value for current model)
temp
=
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
1
];
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
1
]
=
gamma
*
thetaL
;
backgroundModel
[
0
].
at
<
Vec2f
>
(
i
,
j
)[
1
]
=
gamma
*
thetaL
;
backgroundModel
[
1
].
at
<
Vec2f
>
(
i
,
j
)[
1
]
=
temp
;
}
}
}
}
...
@@ -300,66 +306,29 @@ bool MotionSaliencyBinWangApr2014::templateReplacement( Mat finalBFMask )
...
@@ -300,66 +306,29 @@ bool MotionSaliencyBinWangApr2014::templateReplacement( Mat finalBFMask )
bool
MotionSaliencyBinWangApr2014
::
computeSaliencyImpl
(
const
InputArray
image
,
OutputArray
saliencyMap
)
bool
MotionSaliencyBinWangApr2014
::
computeSaliencyImpl
(
const
InputArray
image
,
OutputArray
saliencyMap
)
{
{
Mat
highResBFMask
;
Mat
highResBFMask
;
Mat
lowResBFMask
;
Mat
lowResBFMask
;
Mat
not_lowResBFMask
;
Mat
not_lowResBFMask
;
Mat
finalBFMask
;
Mat
finalBFMask
;
Mat
noisePixelsMask
;
Mat
noisePixelsMask
;
Mat
t
(
image
.
getMat
().
rows
,
image
.
getMat
().
cols
,
CV_32FC2
);
/*
Mat t( image.getMat().rows, image.getMat().cols, CV_32FC2 );
t.setTo( 50 );
t.setTo( 50 );
backgroundModel
.
at
(
0
)
=
t
;
backgroundModel.at( 0 ) = t; */
fullResolutionDetection
(
image
.
getMat
(),
highResBFMask
);
fullResolutionDetection
(
image
.
getMat
(),
highResBFMask
);
lowResolutionDetection
(
image
.
getMat
(),
lowResBFMask
);
lowResolutionDetection
(
image
.
getMat
(),
lowResBFMask
);
// Compute the final background-foreground mask. One pixel is marked as foreground if and only if it is
// Compute the final background-foreground mask. One pixel is marked as foreground if and only if it is
// foreground in both masks (full and low)
// foreground in both masks (full and low)
bitwise_and
(
highResBFMask
,
lowResBFMask
,
finalBFMask
);
bitwise_and
(
highResBFMask
,
lowResBFMask
,
finalBFMask
);
//imshow("finalBFMask",finalBFMask*255);
// Detect the noise pixels (i.e. for a given pixel, fullRes(pixel) = foreground and lowRes(pixel)= background)
// Detect the noise pixels (i.e. for a given pixel, fullRes(pixel) = foreground and lowRes(pixel)= background)
bitwise_not
(
lowResBFMask
,
not_lowResBFMask
);
bitwise_not
(
lowResBFMask
,
not_lowResBFMask
);
bitwise_and
(
highResBFMask
,
not_lowResBFMask
,
noisePixelsMask
);
bitwise_and
(
highResBFMask
,
not_lowResBFMask
,
noisePixelsMask
);
//imshow("noisePixelsMask",noisePixelsMask*255);
//waitKey(0);
templateOrdering
();
std
::
ofstream
ofs
;
ofs
.
open
(
"highResBFMask.txt"
,
std
::
ofstream
::
out
);
for
(
int
i
=
0
;
i
<
highResBFMask
.
rows
;
i
++
)
{
for
(
int
j
=
0
;
j
<
highResBFMask
.
cols
;
j
++
)
{
//highResBFMask.at<int>( i, j ) = i + j;
stringstream
str
;
str
<<
(
int
)
highResBFMask
.
at
<
uchar
>
(
i
,
j
)
<<
" "
;
ofs
<<
str
.
str
();
}
stringstream
str2
;
str2
<<
"
\n
"
;
ofs
<<
str2
.
str
();
}
ofs
.
close
();
std
::
ofstream
ofs2
;
ofs2
.
open
(
"lowResBFMask.txt"
,
std
::
ofstream
::
out
);
for
(
int
i
=
0
;
i
<
lowResBFMask
.
rows
;
i
++
)
templateOrdering
();
{
for
(
int
j
=
0
;
j
<
lowResBFMask
.
cols
;
j
++
)
{
stringstream
str
;
str
<<
(
int
)
lowResBFMask
.
at
<
uchar
>
(
i
,
j
)
<<
" "
;
ofs2
<<
str
.
str
();
}
stringstream
str2
;
str2
<<
"
\n
"
;
ofs2
<<
str2
.
str
();
}
ofs2
.
close
();
return
true
;
return
true
;
}
}
...
...
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