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
e8387122
Commit
e8387122
authored
Aug 18, 2017
by
Vladislav Sovrasov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
TLD: fix NCC calculation
parent
255de877
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
14 deletions
+8
-14
tldUtils.cpp
modules/tracking/src/tldUtils.cpp
+8
-14
No files found.
modules/tracking/src/tldUtils.cpp
View file @
e8387122
...
@@ -171,20 +171,14 @@ double NCC(const Mat_<uchar>& patch1, const Mat_<uchar>& patch2)
...
@@ -171,20 +171,14 @@ double NCC(const Mat_<uchar>& patch1, const Mat_<uchar>& patch2)
CV_Assert
(
patch1
.
cols
==
patch2
.
cols
);
CV_Assert
(
patch1
.
cols
==
patch2
.
cols
);
int
N
=
patch1
.
rows
*
patch1
.
cols
;
int
N
=
patch1
.
rows
*
patch1
.
cols
;
int
s1
=
0
,
s2
=
0
,
n1
=
0
,
n2
=
0
,
prod
=
0
;
double
s1
=
sum
(
patch1
)(
0
);
for
(
int
i
=
0
;
i
<
patch1
.
rows
;
i
++
)
double
s2
=
sum
(
patch2
)(
0
);
{
double
n1
=
norm
(
patch1
,
NORM_L2SQR
);
for
(
int
j
=
0
;
j
<
patch1
.
cols
;
j
++
)
double
n2
=
norm
(
patch2
,
NORM_L2SQR
);
{
double
prod
=
patch1
.
dot
(
patch2
);
int
p1
=
patch1
(
i
,
j
),
p2
=
patch2
(
i
,
j
);
double
sq1
=
sqrt
(
std
::
max
(
0.0
,
n1
-
1.0
*
s1
*
s1
/
N
));
s1
+=
p1
;
s2
+=
p2
;
double
sq2
=
sqrt
(
std
::
max
(
0.0
,
n2
-
1.0
*
s2
*
s2
/
N
));
n1
+=
(
p1
*
p1
);
n2
+=
(
p2
*
p2
);
return
(
sq2
==
0
)
?
sq1
/
abs
(
sq1
)
:
(
prod
-
s1
*
s2
/
N
)
/
sq1
/
sq2
;
prod
+=
(
p1
*
p2
);
}
}
double
sq1
=
sqrt
(
std
::
max
(
0.0
,
n1
-
1.0
*
s1
*
s1
/
N
)),
sq2
=
sqrt
(
std
::
max
(
0.0
,
n2
-
1.0
*
s2
*
s2
/
N
));
double
ares
=
(
sq2
==
0
)
?
sq1
/
abs
(
sq1
)
:
(
prod
-
s1
*
s2
/
N
)
/
sq1
/
sq2
;
return
ares
;
}
}
int
getMedian
(
const
std
::
vector
<
int
>&
values
,
int
size
)
int
getMedian
(
const
std
::
vector
<
int
>&
values
,
int
size
)
...
...
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