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
f9c59c86
Commit
f9c59c86
authored
Jan 16, 2016
by
comdiv
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
revised PredictCollector with set of implementations
parent
89292e35
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
800 additions
and
25 deletions
+800
-25
predict_collector.hpp
modules/face/include/opencv2/face/predict_collector.hpp
+209
-6
eigen_faces.cpp
modules/face/src/eigen_faces.cpp
+1
-1
fisher_faces.cpp
modules/face/src/fisher_faces.cpp
+1
-1
lbph_faces.cpp
modules/face/src/lbph_faces.cpp
+1
-1
map_predict_collector.cpp
modules/face/src/map_predict_collector.cpp
+87
-0
mindist_predict_collector.cpp
modules/face/src/mindist_predict_collector.cpp
+77
-0
predict_collector.cpp
modules/face/src/predict_collector.cpp
+88
-16
stat_predict_collector.cpp
modules/face/src/stat_predict_collector.cpp
+88
-0
std_predict_collector.cpp
modules/face/src/std_predict_collector.cpp
+66
-0
topn_predict_collector.cpp
modules/face/src/topn_predict_collector.cpp
+110
-0
vector_predict_collector.cpp
modules/face/src/vector_predict_collector.cpp
+72
-0
No files found.
modules/face/include/opencv2/face/predict_collector.hpp
View file @
f9c59c86
...
@@ -45,6 +45,9 @@ the use of this software, even if advised of the possibility of such damage.
...
@@ -45,6 +45,9 @@ the use of this software, even if advised of the possibility of such damage.
#ifndef __OPENCV_PREDICT_COLLECTOR_HPP__
#ifndef __OPENCV_PREDICT_COLLECTOR_HPP__
#define __OPENCV_PREDICT_COLLECTOR_HPP__
#define __OPENCV_PREDICT_COLLECTOR_HPP__
#include <cfloat>
#include <cfloat>
#include <list>
#include <vector>
#include <map>
#include "opencv2/core/cvdef.h"
#include "opencv2/core/cvdef.h"
#include "opencv2/core/cvstd.hpp"
#include "opencv2/core/cvstd.hpp"
#undef emit //fix for qt
#undef emit //fix for qt
...
@@ -56,18 +59,40 @@ namespace face {
...
@@ -56,18 +59,40 @@ namespace face {
*/
*/
class
CV_EXPORTS_W
PredictCollector
{
class
CV_EXPORTS_W
PredictCollector
{
protected
:
protected
:
double
_thresh
h
old
;
double
_threshold
;
int
_size
;
int
_size
;
int
_state
;
int
_state
;
int
_excludeLabel
;
double
_distanceKoef
;
double
_minthreshold
;
public
:
public
:
/** @brief creates new predict collector with given threshhold */
/** @brief creates new predict collector with given threshold */
PredictCollector
(
double
threshhold
=
DBL_MAX
)
:
_threshhold
(
threshhold
)
{};
PredictCollector
(
double
threshold
=
DBL_MAX
)
{
_threshold
=
threshold
;
_excludeLabel
=
0
;
_distanceKoef
=
1
;
_minthreshold
=
-
1
;
}
CV_WRAP
virtual
~
PredictCollector
()
{}
CV_WRAP
virtual
~
PredictCollector
()
{}
/** @brief called once at start of recognition
/** @brief called once at start of recognition
@param size total size of prediction evaluation that recognizer could perform
@param size total size of prediction evaluation that recognizer could perform
@param state user defined send-to-back optional value to allow multi-thread, multi-session or aggregation scenarios
@param state user defined send-to-back optional value to allow multi-thread, multi-session or aggregation scenarios
*/
*/
CV_WRAP
virtual
void
init
(
const
int
size
,
const
int
state
=
0
);
CV_WRAP
virtual
void
init
(
const
int
size
,
const
int
state
=
0
);
/** @brief called by recognizer prior to emit to decide if prediction require emiting
@param label current predicted label
@param dist current predicted distance
@param state back send state parameter of prediction session
@return true if prediction is valid and required for emiting
@note can override given label and distance to another values
*/
CV_WRAP
virtual
bool
defaultFilter
(
int
*
label
,
double
*
dist
,
const
int
state
);
/** @brief extension point for filter - called if base filter executed */
CV_WRAP
virtual
bool
filter
(
int
*
label
,
double
*
dist
,
const
int
state
);
/** @brief called with every recognition result
/** @brief called with every recognition result
@param label current prediction label
@param label current prediction label
@param dist current prediction distance (confidence)
@param dist current prediction distance (confidence)
...
@@ -75,6 +100,70 @@ public:
...
@@ -75,6 +100,70 @@ public:
@return true if recognizer should proceed prediction , false - if recognizer should terminate prediction
@return true if recognizer should proceed prediction , false - if recognizer should terminate prediction
*/
*/
CV_WRAP
virtual
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
//not abstract while Python generation require non-abstract class
CV_WRAP
virtual
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
//not abstract while Python generation require non-abstract class
/** @brief outer interface method to be called from recognizer
@param label current prediction label
@param dist current prediction distance (confidence)
@param state user defined send-to-back optional value to allow multi-thread, multi-session or aggregation scenarios
@note wraps filter and emit calls, not tended to be overriden
*/
CV_WRAP
virtual
bool
collect
(
int
label
,
double
dist
,
const
int
state
=
0
);
/**
@brief get size of prediction
### Description
Is set by recognizer and is amount of all available predicts
So we can use it to perform statistic collectors before prediction of whole set
*/
CV_WRAP
virtual
int
getSize
();
/** @brief set size of prediction */
CV_WRAP
virtual
void
setSize
(
int
size
);
/**
@brief get state of prediction
### Description
State is a custom value assigned for prediction session, 0 if it's no-state session
*/
CV_WRAP
virtual
int
getState
();
/** @brief set state of prediction */
CV_WRAP
virtual
void
setState
(
int
state
);
/**
@brief returns currently excluded label, 0 if no set
### Description
We require to exclude label if we want to test card in train set against others
*/
CV_WRAP
virtual
int
getExcludeLabel
();
/** @brief set exclude label of prediction */
CV_WRAP
virtual
void
setExcludeLabel
(
int
excludeLabel
);
/**
@brief returns current distance koeficient (applyed to distance in filter stage)
### Description
It's required if we want to predict with distinct algorithms in one session
so LBPH, Eigen and Fisher distance are different, but we can provide koef for them to translate to
each other (while their distribuition for same train set is close and started from 0)
Default 1 koef means that distance is not corrected
*/
CV_WRAP
virtual
double
getDistanceKoef
();
/** @brief set exclude label of prediction */
CV_WRAP
virtual
void
setDistanceKoef
(
double
distanceKoef
);
/**
@brief returns current minimal threshold
### Description
It's required when we must exclude most closed predictions (for example we
search for close but not same faces - usable for mixed set where doubles exists
in train collection)
*/
CV_WRAP
virtual
double
getMinThreshold
();
/** @brief set minimal threshold for prediction */
CV_WRAP
virtual
void
setMinThreshold
(
double
minthreshold
);
};
};
/** @brief default predict collector that trace minimal distance with treshhold checking (that is default behavior for most predict logic)
/** @brief default predict collector that trace minimal distance with treshhold checking (that is default behavior for most predict logic)
...
@@ -84,20 +173,133 @@ private:
...
@@ -84,20 +173,133 @@ private:
int
_label
;
int
_label
;
double
_dist
;
double
_dist
;
public
:
public
:
/** @brief creates new MinDistancePredictCollector with given thresh
h
old */
/** @brief creates new MinDistancePredictCollector with given threshold */
CV_WRAP
MinDistancePredictCollector
(
double
thresh
hold
=
DBL_MAX
)
:
PredictCollector
(
thresh
hold
)
{
CV_WRAP
MinDistancePredictCollector
(
double
thresh
old
=
DBL_MAX
)
:
PredictCollector
(
thres
hold
)
{
_label
=
-
1
;
_label
=
-
1
;
_dist
=
DBL_MAX
;
_dist
=
DBL_MAX
;
};
};
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
/** @brief result label, 0 if not found */
CV_WRAP
bool
filter
(
int
*
label
,
double
*
dist
,
const
int
state
);
/** @brief result label, -1 if not found */
CV_WRAP
int
getLabel
()
const
;
CV_WRAP
int
getLabel
()
const
;
/** @brief result distance (confidence) DBL_MAX if not found */
/** @brief result distance (confidence) DBL_MAX if not found */
CV_WRAP
double
getDist
()
const
;
CV_WRAP
double
getDist
()
const
;
/** @brief factory method to create cv-pointers to MinDistancePredictCollector */
/** @brief factory method to create cv-pointers to MinDistancePredictCollector */
CV_WRAP
static
Ptr
<
MinDistancePredictCollector
>
create
(
double
threshold
=
DBL_MAX
);
CV_WRAP
static
Ptr
<
MinDistancePredictCollector
>
create
(
double
threshold
=
DBL_MAX
);
};
};
/**
@brief Collects top N most close predictions
@note Prevent doubling of same label - if one label is occured twice - most closed distance value will be set
*/
class
CV_EXPORTS_W
TopNPredictCollector
:
public
PredictCollector
{
private
:
size_t
_size
;
Ptr
<
std
::
list
<
std
::
pair
<
int
,
double
>
>
>
_idx
;
public
:
CV_WRAP
TopNPredictCollector
(
size_t
size
=
5
,
double
threshold
=
DBL_MAX
)
:
PredictCollector
(
threshold
)
{
_size
=
size
;
_idx
=
Ptr
<
std
::
list
<
std
::
pair
<
int
,
double
>
>
>
(
new
std
::
list
<
std
::
pair
<
int
,
double
>
>
);
};
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
CV_WRAP
bool
filter
(
int
*
label
,
double
*
dist
,
const
int
state
);
Ptr
<
std
::
list
<
std
::
pair
<
int
,
double
>
>
>
getResult
();
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
getResultVector
();
// pythonable version
CV_WRAP
static
Ptr
<
TopNPredictCollector
>
create
(
size_t
size
=
5
,
double
threshold
=
DBL_MAX
);
};
/**
@brief Collects all predict results to single vector
@note this collector not analyze double labels in emit, it's raw copy of source prediction result,
remember that filter is still applyed so you can use min/max threshold , distanceKoef and excludeLabel
*/
class
CV_EXPORTS_W
VectorPredictCollector
:
public
PredictCollector
{
private
:
Ptr
<
std
::
vector
<
std
::
pair
<
int
,
double
>
>
>
_idx
;
public
:
CV_WRAP
static
const
int
DEFAULT_SIZE
=
5
;
// top 5 by default
CV_WRAP
VectorPredictCollector
(
double
threshold
=
DBL_MAX
)
:
PredictCollector
(
threshold
)
{
_idx
=
Ptr
<
std
::
vector
<
std
::
pair
<
int
,
double
>
>
>
(
new
std
::
vector
<
std
::
pair
<
int
,
double
>
>
);
}
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
Ptr
<
std
::
vector
<
std
::
pair
<
int
,
double
>
>
>
getResult
();
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
getResultVector
();
// pythonable version
CV_WRAP
static
Ptr
<
VectorPredictCollector
>
create
(
double
threshold
=
DBL_MAX
);
};
/**
@brief Collects all predict results to single vector
@note this collector not analyze double labels in emit, it's raw copy of source prediction result,
remember that filter is still applyed so you can use min/max threshold , distanceKoef and excludeLabel
*/
class
CV_EXPORTS_W
MapPredictCollector
:
public
PredictCollector
{
private
:
Ptr
<
std
::
map
<
int
,
double
>
>
_idx
;
public
:
CV_WRAP
static
const
int
DEFAULT_SIZE
=
5
;
// top 5 by default
CV_WRAP
MapPredictCollector
(
double
threshold
=
DBL_MAX
)
:
PredictCollector
(
threshold
)
{
_idx
=
Ptr
<
std
::
map
<
int
,
double
>
>
(
new
std
::
map
<
int
,
double
>
);
}
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
Ptr
<
std
::
map
<
int
,
double
>
>
getResult
();
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
getResultVector
();
// pythonable version
CV_WRAP
static
Ptr
<
MapPredictCollector
>
create
(
double
threshold
=
DBL_MAX
);
};
/**
@brief Collects basic statistic information about prediction
@note stat predict collector is usefull for determining valid thresholds
on given trained set, additionally it's required to
evaluate unified koefs between algorithms
*/
class
CV_EXPORTS_W
StatPredictCollector
:
public
PredictCollector
{
private
:
double
_min
;
double
_max
;
int
_count
;
double
_sum
;
public
:
CV_WRAP
StatPredictCollector
(
double
threshold
=
DBL_MAX
)
:
PredictCollector
(
threshold
)
{
_min
=
DBL_MAX
;
_max
=
DBL_MIN
;
_count
=
0
;
_sum
=
0
;
}
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
CV_WRAP
double
getMin
();
CV_WRAP
double
getMax
();
CV_WRAP
double
getSum
();
CV_WRAP
int
getCount
();
CV_WRAP
static
Ptr
<
StatPredictCollector
>
create
(
double
threshold
=
DBL_MAX
);
};
/**
@brief evaluates standard deviation of given prediction session over trained set
@note in combine with StatPredictCollector can provide statistically based metrices
for thresholds
*/
class
CV_EXPORTS_W
StdPredictCollector
:
public
PredictCollector
{
private
:
double
_avg
;
double
_n
;
double
_s
;
public
:
CV_WRAP
StdPredictCollector
(
double
threshold
=
DBL_MAX
,
double
avg
=
0
)
:
PredictCollector
(
threshold
)
{
_avg
=
avg
;
_n
=
0
;
_s
=
0
;
}
CV_WRAP
bool
emit
(
const
int
label
,
const
double
dist
,
const
int
state
=
0
);
CV_WRAP
double
getResult
();
CV_WRAP
static
Ptr
<
StdPredictCollector
>
create
(
double
threshold
=
DBL_MAX
,
double
avg
=
0
);
};
//! @}
//! @}
}
}
}
}
#endif
#endif
\ No newline at end of file
modules/face/src/eigen_faces.cpp
View file @
f9c59c86
...
@@ -118,7 +118,7 @@ void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const
...
@@ -118,7 +118,7 @@ void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_projections
.
size
();
sampleIdx
++
)
{
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_projections
.
size
();
sampleIdx
++
)
{
double
dist
=
norm
(
_projections
[
sampleIdx
],
q
,
NORM_L2
);
double
dist
=
norm
(
_projections
[
sampleIdx
],
q
,
NORM_L2
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
if
(
!
collector
->
emi
t
(
label
,
dist
,
state
))
return
;
if
(
!
collector
->
collec
t
(
label
,
dist
,
state
))
return
;
}
}
}
}
...
...
modules/face/src/fisher_faces.cpp
View file @
f9c59c86
...
@@ -138,7 +138,7 @@ void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector, cons
...
@@ -138,7 +138,7 @@ void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector, cons
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_projections
.
size
();
sampleIdx
++
)
{
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_projections
.
size
();
sampleIdx
++
)
{
double
dist
=
norm
(
_projections
[
sampleIdx
],
q
,
NORM_L2
);
double
dist
=
norm
(
_projections
[
sampleIdx
],
q
,
NORM_L2
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
if
(
!
collector
->
emi
t
(
label
,
dist
,
state
))
return
;
if
(
!
collector
->
collec
t
(
label
,
dist
,
state
))
return
;
}
}
}
}
...
...
modules/face/src/lbph_faces.cpp
View file @
f9c59c86
...
@@ -403,7 +403,7 @@ void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector, const int s
...
@@ -403,7 +403,7 @@ void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector, const int s
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_histograms
.
size
();
sampleIdx
++
)
{
for
(
size_t
sampleIdx
=
0
;
sampleIdx
<
_histograms
.
size
();
sampleIdx
++
)
{
double
dist
=
compareHist
(
_histograms
[
sampleIdx
],
query
,
HISTCMP_CHISQR_ALT
);
double
dist
=
compareHist
(
_histograms
[
sampleIdx
],
query
,
HISTCMP_CHISQR_ALT
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
int
label
=
_labels
.
at
<
int
>
((
int
)
sampleIdx
);
if
(
!
collector
->
emi
t
(
label
,
dist
,
state
))
return
;
if
(
!
collector
->
collec
t
(
label
,
dist
,
state
))
return
;
}
}
}
}
...
...
modules/face/src/map_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
#include <iterator>
namespace
cv
{
namespace
face
{
CV_WRAP
bool
MapPredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
//if already in index check which is closer
if
(
_idx
->
find
(
label
)
!=
_idx
->
end
())
{
double
current
=
(
*
_idx
)[
label
];
if
(
dist
<
current
)
{
(
*
_idx
)[
label
]
=
dist
;
}
}
else
{
(
*
_idx
)[
label
]
=
dist
;
}
return
true
;
}
Ptr
<
std
::
map
<
int
,
double
>
>
MapPredictCollector
::
getResult
()
{
return
_idx
;
}
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
MapPredictCollector
::
getResultVector
()
{
std
::
vector
<
std
::
pair
<
int
,
double
>
>
result
;
std
::
copy
(
_idx
->
begin
(),
_idx
->
end
(),
std
::
back_inserter
(
result
));
return
result
;
}
CV_WRAP
Ptr
<
MapPredictCollector
>
MapPredictCollector
::
create
(
double
threshold
)
{
return
Ptr
<
MapPredictCollector
>
(
new
MapPredictCollector
(
threshold
));
}
}
}
\ No newline at end of file
modules/face/src/mindist_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
namespace
cv
{
namespace
face
{
bool
MinDistancePredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
_label
=
label
;
_dist
=
dist
;
return
true
;
}
CV_WRAP
bool
MinDistancePredictCollector
::
filter
(
int
*
label
,
double
*
dist
,
const
int
state
)
{
((
void
)
label
);
((
void
)
state
);
return
*
dist
<
_dist
;
}
int
MinDistancePredictCollector
::
getLabel
()
const
{
return
_label
;
}
double
MinDistancePredictCollector
::
getDist
()
const
{
return
_dist
;
}
Ptr
<
MinDistancePredictCollector
>
MinDistancePredictCollector
::
create
(
double
threshold
)
{
return
Ptr
<
MinDistancePredictCollector
>
(
new
MinDistancePredictCollector
(
threshold
));
}
}
}
\ No newline at end of file
modules/face/src/predict_collector.cpp
View file @
f9c59c86
...
@@ -46,40 +46,112 @@ the use of this software, even if advised of the possibility of such damage.
...
@@ -46,40 +46,112 @@ the use of this software, even if advised of the possibility of such damage.
namespace
cv
{
namespace
cv
{
namespace
face
{
namespace
face
{
void
PredictCollector
::
init
(
const
int
size
,
const
int
state
)
{
void
PredictCollector
::
init
(
const
int
size
,
const
int
state
)
{
//reserve for some-how usage in descendants
//reserve for some-how usage in descendants
_size
=
size
;
_size
=
size
;
_state
=
state
;
_state
=
state
;
}
}
bool
PredictCollector
::
emit
(
const
int
,
const
double
,
const
int
state
)
{
CV_WRAP
bool
PredictCollector
::
defaultFilter
(
int
*
label
,
double
*
dist
,
const
int
state
)
if
(
_state
==
state
)
{
{
return
false
;
// if it's own session - terminate it while default PredictCollector does nothing
// if state provided we should compare it with current state
if
(
_state
!=
0
&&
_state
!=
state
)
{
return
false
;
}
// if exclude label provided we can test it first
if
(
_excludeLabel
!=
0
&&
_excludeLabel
==
*
label
)
{
return
false
;
}
// initially we must recalculate distance by koef iv given
if
(
_distanceKoef
!=
1
)
{
*
dist
=
*
dist
*
_distanceKoef
;
}
// check upper threshold
if
(
*
dist
>
_threshold
)
{
return
false
;
}
}
//check inner threshold
if
(
*
dist
<
_minthreshold
)
{
return
false
;
}
return
true
;
return
true
;
}
}
bool
MinDistancePredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
CV_WRAP
bool
PredictCollector
::
filter
(
int
*
label
,
double
*
dist
,
const
int
state
)
if
(
_state
!=
state
)
{
{
return
true
;
// it works only in one (same) session doesn't accept values for other states
((
void
)
label
);
}
((
void
)
dist
);
if
(
dist
<
_threshhold
&&
dist
<
_dist
)
{
((
void
)
state
);
_label
=
label
;
return
true
;
//no custom logic at base level
_dist
=
dist
;
}
bool
PredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
label
);
((
void
)
dist
);
((
void
)
state
);
return
false
;
// terminate prediction - no any behavior in base PredictCollector
}
CV_WRAP
bool
PredictCollector
::
collect
(
int
label
,
double
dist
,
const
int
state
)
{
if
(
defaultFilter
(
&
label
,
&
dist
,
state
)
&&
filter
(
&
label
,
&
dist
,
state
))
{
return
emit
(
label
,
dist
,
state
);
}
}
return
true
;
return
true
;
}
}
int
MinDistancePredictCollector
::
getLabel
()
const
{
CV_WRAP
int
PredictCollector
::
getSize
()
return
_label
;
{
return
_size
;
}
CV_WRAP
void
PredictCollector
::
setSize
(
int
size
)
{
_size
=
size
;
}
CV_WRAP
int
PredictCollector
::
getState
()
{
return
_state
;
}
CV_WRAP
void
PredictCollector
::
setState
(
int
state
)
{
_state
=
state
;
}
CV_WRAP
int
PredictCollector
::
getExcludeLabel
()
{
return
_excludeLabel
;
}
CV_WRAP
void
PredictCollector
::
setExcludeLabel
(
int
excludeLabel
)
{
_excludeLabel
=
excludeLabel
;
}
CV_WRAP
double
PredictCollector
::
getDistanceKoef
()
{
return
_distanceKoef
;
}
CV_WRAP
void
PredictCollector
::
setDistanceKoef
(
double
distanceKoef
)
{
_distanceKoef
=
distanceKoef
;
}
}
double
MinDistancePredictCollector
::
getDist
()
const
{
CV_WRAP
double
PredictCollector
::
getMinThreshold
()
return
_dist
;
{
return
_minthreshold
;
}
}
Ptr
<
MinDistancePredictCollector
>
MinDistancePredictCollector
::
create
(
double
threshold
)
{
CV_WRAP
void
PredictCollector
::
setMinThreshold
(
double
minthreshold
)
return
Ptr
<
MinDistancePredictCollector
>
(
new
MinDistancePredictCollector
(
threshold
));
{
_minthreshold
=
minthreshold
;
}
}
}
}
...
...
modules/face/src/stat_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
namespace
cv
{
namespace
face
{
CV_WRAP
bool
StatPredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
((
void
)
label
);
_count
++
;
_sum
+=
dist
;
if
(
_min
>
dist
)
{
_min
=
dist
;
}
if
(
_max
<
dist
)
{
_max
=
dist
;
}
return
true
;
}
CV_WRAP
double
StatPredictCollector
::
getMin
()
{
return
_min
;
}
CV_WRAP
double
StatPredictCollector
::
getMax
()
{
return
_max
;
}
CV_WRAP
double
StatPredictCollector
::
getSum
()
{
return
_sum
;
}
CV_WRAP
int
StatPredictCollector
::
getCount
()
{
return
_count
;
}
CV_WRAP
Ptr
<
StatPredictCollector
>
StatPredictCollector
::
create
(
double
threshold
)
{
return
Ptr
<
StatPredictCollector
>
(
new
StatPredictCollector
(
threshold
));
}
}
}
\ No newline at end of file
modules/face/src/std_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
namespace
cv
{
namespace
face
{
CV_WRAP
bool
StdPredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
((
void
)
label
);
_s
+=
pow
(
dist
-
_avg
,
2
);
_n
++
;
return
true
;
}
CV_WRAP
double
StdPredictCollector
::
getResult
()
{
return
sqrt
(
_s
/
(
_n
-
1
));
}
CV_WRAP
Ptr
<
StdPredictCollector
>
StdPredictCollector
::
create
(
double
threshold
,
double
avg
)
{
return
Ptr
<
StdPredictCollector
>
(
new
StdPredictCollector
(
threshold
,
avg
));
}
}
}
\ No newline at end of file
modules/face/src/topn_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
#include <iterator> // std::back_inserter
namespace
cv
{
namespace
face
{
CV_WRAP
bool
TopNPredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
std
::
pair
<
int
,
double
>
p
=
std
::
make_pair
(
label
,
dist
);
if
(
_idx
->
size
()
==
0
||
p
.
second
<=
_idx
->
front
().
second
)
{
_idx
->
push_front
(
p
);
}
else
if
(
p
.
second
>=
_idx
->
back
().
second
)
{
_idx
->
push_back
(
p
);
}
else
{
typedef
std
::
list
<
std
::
pair
<
int
,
double
>
>::
iterator
it_type
;
for
(
it_type
i
=
_idx
->
begin
();
i
!=
_idx
->
end
();
i
++
)
{
if
(
p
.
second
<=
i
->
second
)
{
_idx
->
insert
(
i
,
p
);
break
;
}
}
}
return
true
;
}
CV_WRAP
bool
TopNPredictCollector
::
filter
(
int
*
label
,
double
*
dist
,
const
int
state
)
{
((
void
)
state
);
if
(
_idx
->
size
()
<
_size
)
return
true
;
//not full - can insert;
if
(
*
dist
>=
_idx
->
back
().
second
)
return
false
;
//too far distance
for
(
std
::
list
<
std
::
pair
<
int
,
double
>
>::
iterator
it
=
_idx
->
begin
();
it
!=
_idx
->
end
();
++
it
)
{
if
(
it
->
first
==
*
label
)
{
if
(
it
->
second
<=
*
dist
)
{
return
false
;
//has more close
}
else
{
_idx
->
erase
(
it
);
return
true
;
//no more require pop_back
}
}
}
_idx
->
pop_back
();
return
true
;
}
CV_WRAP
Ptr
<
std
::
list
<
std
::
pair
<
int
,
double
>
>
>
TopNPredictCollector
::
getResult
()
{
return
_idx
;
}
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
TopNPredictCollector
::
getResultVector
()
{
std
::
vector
<
std
::
pair
<
int
,
double
>
>
result
;
std
::
copy
(
_idx
->
begin
(),
_idx
->
end
(),
std
::
back_inserter
(
result
));
return
result
;
}
CV_WRAP
Ptr
<
TopNPredictCollector
>
TopNPredictCollector
::
create
(
size_t
size
,
double
threshold
)
{
return
Ptr
<
TopNPredictCollector
>
(
new
TopNPredictCollector
(
size
,
threshold
));
}
}
}
\ No newline at end of file
modules/face/src/vector_predict_collector.cpp
0 → 100644
View file @
f9c59c86
/*
By downloading, copying, installing or using the software you agree to this license.
If you do not agree to this license, do not download, install,
copy or use the software.
License Agreement
For Open Source Computer Vision Library
(3-clause BSD License)
Copyright (C) 2000-2015, Intel Corporation, all rights reserved.
Copyright (C) 2009-2011, Willow Garage Inc., all rights reserved.
Copyright (C) 2009-2015, NVIDIA Corporation, all rights reserved.
Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
Copyright (C) 2015, OpenCV Foundation, all rights reserved.
Copyright (C) 2015, Itseez Inc., all rights reserved.
Third party copyrights are property of their respective owners.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the names of the copyright holders nor the names of the contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
This software is provided by the copyright holders and contributors "as is" and
any express or implied warranties, including, but not limited to, the implied
warranties of merchantability and fitness for a particular purpose are disclaimed.
In no event shall copyright holders or contributors be liable for any direct,
indirect, incidental, special, exemplary, or consequential damages
(including, but not limited to, procurement of substitute goods or services;
loss of use, data, or profits; or business interruption) however caused
and on any theory of liability, whether in contract, strict liability,
or tort (including negligence or otherwise) arising in any way out of
the use of this software, even if advised of the possibility of such damage.
*/
#include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
namespace
cv
{
namespace
face
{
CV_WRAP
bool
VectorPredictCollector
::
emit
(
const
int
label
,
const
double
dist
,
const
int
state
)
{
((
void
)
state
);
_idx
->
push_back
(
std
::
pair
<
int
,
double
>
(
label
,
dist
));
return
true
;
}
Ptr
<
std
::
vector
<
std
::
pair
<
int
,
double
>
>
>
VectorPredictCollector
::
getResult
()
{
return
_idx
;
}
CV_WRAP
std
::
vector
<
std
::
pair
<
int
,
double
>
>
VectorPredictCollector
::
getResultVector
()
{
return
(
*
_idx
);
}
CV_WRAP
Ptr
<
VectorPredictCollector
>
VectorPredictCollector
::
create
(
double
threshold
)
{
return
Ptr
<
VectorPredictCollector
>
(
new
VectorPredictCollector
(
threshold
));
}
}
}
\ No newline at end of file
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