Commit 6dc1f416 authored by Maksim Shabunin's avatar Maksim Shabunin

Merge pull request #638 from mshabunin:fix-face-python-predict

parents 22a136f6 48903ef9
...@@ -256,7 +256,7 @@ public: ...@@ -256,7 +256,7 @@ public:
CV_WRAP virtual void update(InputArrayOfArrays src, InputArray labels); CV_WRAP virtual void update(InputArrayOfArrays src, InputArray labels);
/** @overload */ /** @overload */
CV_WRAP int predict(InputArray src) const; CV_WRAP_AS(predict_label) int predict(InputArray src) const;
/** @brief Predicts a label and associated confidence (e.g. distance) for a given input image. /** @brief Predicts a label and associated confidence (e.g. distance) for a given input image.
...@@ -300,12 +300,11 @@ public: ...@@ -300,12 +300,11 @@ public:
/** @brief - if implemented - send all result of prediction to collector that can be used for somehow custom result handling /** @brief - if implemented - send all result of prediction to collector that can be used for somehow custom result handling
@param src Sample image to get a prediction from. @param src Sample image to get a prediction from.
@param collector User-defined collector object that accepts all results @param collector User-defined collector object that accepts all results
@param state - optional user-defined state token that should be passed back from FaceRecognizer implementation
To implement this method u just have to do same internal cycle as in predict(InputArray src, CV_OUT int &label, CV_OUT double &confidence) but To implement this method u just have to do same internal cycle as in predict(InputArray src, CV_OUT int &label, CV_OUT double &confidence) but
not try to get "best@ result, just resend it to caller side with given collector not try to get "best@ result, just resend it to caller side with given collector
*/ */
CV_WRAP virtual void predict(InputArray src, Ptr<PredictCollector> collector, const int state = 0) const = 0; CV_WRAP_AS(predict_collect) virtual void predict(InputArray src, Ptr<PredictCollector> collector) const = 0;
/** @brief Saves a FaceRecognizer and its model state. /** @brief Saves a FaceRecognizer and its model state.
......
...@@ -44,262 +44,84 @@ the use of this software, even if advised of the possibility of such damage. ...@@ -44,262 +44,84 @@ 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 <list>
#include <vector> #include <vector>
#include <map> #include <map>
#include "opencv2/core/cvdef.h" #include <utility>
#include <cfloat>
#include "opencv2/core/cvstd.hpp" #include "opencv2/core/cvstd.hpp"
#undef emit //fix for qt
namespace cv { namespace cv {
namespace face { namespace face {
//! @addtogroup face //! @addtogroup face
//! @{ //! @{
/** @brief Abstract base class for all strategies of prediction result handling /** @brief Abstract base class for all strategies of prediction result handling
*/ */
class CV_EXPORTS_W PredictCollector { class CV_EXPORTS_W PredictCollector
protected: {
double _threshold;
int _size;
int _state;
int _excludeLabel;
double _distanceKoef;
double _minthreshold;
public: public:
/** @brief creates new predict collector with given threshold */ virtual ~PredictCollector() {}
PredictCollector(double threshold = DBL_MAX) {
_threshold = threshold;
_excludeLabel = 0;
_distanceKoef = 1;
_minthreshold = -1;
}
CV_WRAP virtual ~PredictCollector() {}
/** @brief called once at start of recognition /** @brief Interface method called by face recognizer before results processing
@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
*/
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); virtual void init(size_t size) { (void)size; }
/** @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 Interface method called by face recognizer for each result
@param label current prediction label @param label current prediction label
@param dist current prediction distance (confidence) @param dist current prediction distance (confidence)
@param state user defined send-to-back optional value to allow multi-thread, multi-session or aggregation scenarios
@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
/** @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(); virtual bool collect(int label, double dist) = 0;
/** @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
*/
class CV_EXPORTS_W MinDistancePredictCollector : public PredictCollector {
private:
int _label;
double _dist;
public:
/** @brief creates new MinDistancePredictCollector with given threshold */
CV_WRAP MinDistancePredictCollector(double threshold = DBL_MAX) : PredictCollector(threshold) {
_label = -1;
_dist = DBL_MAX;
};
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);
/** @brief result label, -1 if not found */
CV_WRAP int getLabel() const;
/** @brief result distance (confidence) DBL_MAX if not found */
CV_WRAP double getDist() const;
/** @brief factory method to create cv-pointers to MinDistancePredictCollector */
CV_WRAP static Ptr<MinDistancePredictCollector> create(double threshold = DBL_MAX);
};
/** Trace minimal distance with treshhold checking (that is default behavior for most predict logic)
@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 { class CV_EXPORTS_W StandardCollector : public PredictCollector
private: {
size_t _size;
Ptr<std::list<std::pair<int, double> > > _idx;
public: public:
CV_WRAP TopNPredictCollector(size_t size = 5, double threshold = DBL_MAX) : PredictCollector(threshold) { struct PredictResult
_size = size; {
_idx = Ptr<std::list<std::pair<int, double> > >(new std::list<std::pair<int, double> >); int label;
double distance;
PredictResult(int label_ = -1, double distance_ = DBL_MAX) : label(label_), distance(distance_) {}
}; };
CV_WRAP bool emit(const int label, const double dist, const int state = 0); protected:
CV_WRAP bool filter(int* label, double* dist, const int state); double threshold;
Ptr<std::list<std::pair<int, double> > > getResult(); PredictResult minRes;
CV_WRAP std::vector<std::pair<int, double> > getResultVector(); // pythonable version std::vector<PredictResult> data;
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: public:
CV_WRAP StdPredictCollector(double threshold = DBL_MAX, double avg = 0) : PredictCollector(threshold) { /** @brief Constructor
_avg = avg; @param threshold_ set threshold
_n = 0; */
_s = 0; StandardCollector(double threshold_ = DBL_MAX);
} /** @brief overloaded interface method */
CV_WRAP bool emit(const int label, const double dist, const int state = 0); void init(size_t size);
CV_WRAP double getResult(); /** @brief overloaded interface method */
CV_WRAP static Ptr<StdPredictCollector> create(double threshold = DBL_MAX, double avg = 0); bool collect(int label, double dist);
/** @brief Returns label with minimal distance */
CV_WRAP int getMinLabel() const;
/** @brief Returns minimal distance value */
CV_WRAP double getMinDist() const;
/** @brief Return results as vector
@param sorted If set, results will be sorted by distance
Each values is a pair of label and distance.
*/
CV_WRAP std::vector< std::pair<int, double> > getResults(bool sorted = false) const;
/** @brief Return results as map
Labels are keys, values are minimal distances
*/
std::map<int, double> getResultsMap() const;
/** @brief Static constructor
@param threshold set threshold
*/
CV_WRAP static Ptr<StandardCollector> create(double threshold = DBL_MAX);
}; };
//! @} //! @}
} }
} }
#endif #endif
\ No newline at end of file
...@@ -42,7 +42,7 @@ public: ...@@ -42,7 +42,7 @@ public:
void train(InputArrayOfArrays src, InputArray labels); void train(InputArrayOfArrays src, InputArray labels);
// Send all predict results to caller side for custom result handling // Send all predict results to caller side for custom result handling
void predict(InputArray src, Ptr<PredictCollector> collector, const int state) const; void predict(InputArray src, Ptr<PredictCollector> collector) const;
}; };
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
...@@ -99,7 +99,7 @@ void Eigenfaces::train(InputArrayOfArrays _src, InputArray _local_labels) { ...@@ -99,7 +99,7 @@ void Eigenfaces::train(InputArrayOfArrays _src, InputArray _local_labels) {
} }
} }
void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const int state) const { void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector) const {
// get data // get data
Mat src = _src.getMat(); Mat src = _src.getMat();
// make sure the user is passing correct data // make sure the user is passing correct data
...@@ -114,11 +114,11 @@ void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const ...@@ -114,11 +114,11 @@ void Eigenfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const
} }
// project into PCA subspace // project into PCA subspace
Mat q = LDA::subspaceProject(_eigenvectors, _mean, src.reshape(1, 1)); Mat q = LDA::subspaceProject(_eigenvectors, _mean, src.reshape(1, 1));
collector->init((int)_projections.size(), state); collector->init(_projections.size());
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->collect(label, dist, state))return; if (!collector->collect(label, dist))return;
} }
} }
......
...@@ -80,10 +80,10 @@ int FaceRecognizer::predict(InputArray src) const { ...@@ -80,10 +80,10 @@ int FaceRecognizer::predict(InputArray src) const {
} }
void FaceRecognizer::predict(InputArray src, CV_OUT int &label, CV_OUT double &confidence) const { void FaceRecognizer::predict(InputArray src, CV_OUT int &label, CV_OUT double &confidence) const {
Ptr<MinDistancePredictCollector> collector = MinDistancePredictCollector::create(getThreshold()); Ptr<StandardCollector> collector = StandardCollector::create(getThreshold());
predict(src, collector, 0); predict(src, collector);
label = collector->getLabel(); label = collector->getMinLabel();
confidence = collector->getDist(); confidence = collector->getMinDist();
} }
} }
......
...@@ -37,7 +37,7 @@ public: ...@@ -37,7 +37,7 @@ public:
void train(InputArrayOfArrays src, InputArray labels); void train(InputArrayOfArrays src, InputArray labels);
// Send all predict results to caller side for custom result handling // Send all predict results to caller side for custom result handling
void predict(InputArray src, Ptr<PredictCollector> collector, const int state) const; void predict(InputArray src, Ptr<PredictCollector> collector) const;
}; };
// Removes duplicate elements in a given vector. // Removes duplicate elements in a given vector.
...@@ -120,7 +120,7 @@ void Fisherfaces::train(InputArrayOfArrays src, InputArray _lbls) { ...@@ -120,7 +120,7 @@ void Fisherfaces::train(InputArrayOfArrays src, InputArray _lbls) {
} }
} }
void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector, const int state) const { void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector) const {
Mat src = _src.getMat(); Mat src = _src.getMat();
// check data alignment just for clearer exception messages // check data alignment just for clearer exception messages
if(_projections.empty()) { if(_projections.empty()) {
...@@ -134,11 +134,11 @@ void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector, cons ...@@ -134,11 +134,11 @@ void Fisherfaces::predict(InputArray _src, Ptr<PredictCollector> collector, cons
// project into LDA subspace // project into LDA subspace
Mat q = LDA::subspaceProject(_eigenvectors, _mean, src.reshape(1,1)); Mat q = LDA::subspaceProject(_eigenvectors, _mean, src.reshape(1,1));
// find 1-nearest neighbor // find 1-nearest neighbor
collector->init((int)_projections.size(), state); collector->init((int)_projections.size());
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->collect(label, dist, state))return; if (!collector->collect(label, dist))return;
} }
} }
......
...@@ -92,7 +92,7 @@ public: ...@@ -92,7 +92,7 @@ public:
void update(InputArrayOfArrays src, InputArray labels); void update(InputArrayOfArrays src, InputArray labels);
// Send all predict results to caller side for custom result handling // Send all predict results to caller side for custom result handling
void predict(InputArray src, Ptr<PredictCollector> collector, const int state = 0) const; void predict(InputArray src, Ptr<PredictCollector> collector) const;
// See FaceRecognizer::load. // See FaceRecognizer::load.
void load(const FileStorage& fs); void load(const FileStorage& fs);
...@@ -383,7 +383,7 @@ void LBPH::train(InputArrayOfArrays _in_src, InputArray _in_labels, bool preserv ...@@ -383,7 +383,7 @@ void LBPH::train(InputArrayOfArrays _in_src, InputArray _in_labels, bool preserv
} }
} }
void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector, const int state) const { void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector) const {
if(_histograms.empty()) { if(_histograms.empty()) {
// throw error if no data (or simply return -1?) // throw error if no data (or simply return -1?)
String error_message = "This LBPH model is not computed yet. Did you call the train method?"; String error_message = "This LBPH model is not computed yet. Did you call the train method?";
...@@ -399,11 +399,11 @@ void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector, const int s ...@@ -399,11 +399,11 @@ void LBPH::predict(InputArray _src, Ptr<PredictCollector> collector, const int s
_grid_y, /* grid size y */ _grid_y, /* grid size y */
true /* normed histograms */); true /* normed histograms */);
// find 1-nearest neighbor // find 1-nearest neighbor
collector->init((int)_histograms.size(), state); collector->init((int)_histograms.size());
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->collect(label, dist, state))return; if (!collector->collect(label, dist))return;
} }
} }
......
/*
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
/*
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
...@@ -42,117 +42,73 @@ or tort (including negligence or otherwise) arising in any way out of ...@@ -42,117 +42,73 @@ 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. the use of this software, even if advised of the possibility of such damage.
*/ */
#include "opencv2/face/predict_collector.hpp" #include "opencv2/face/predict_collector.hpp"
#include "opencv2/core/cvstd.hpp"
namespace cv {
namespace face {
namespace cv {namespace face {
void PredictCollector::init(const int size, const int state) { static std::pair<int, double> toPair(const StandardCollector::PredictResult & val) {
//reserve for some-how usage in descendants return std::make_pair(val.label, val.distance);
_size = size;
_state = state;
} }
CV_WRAP bool PredictCollector::defaultFilter(int * label, double * dist, const int state) static bool pairLess(const std::pair<int, double> & lhs, const std::pair<int, double> & rhs) {
{ return lhs.second < rhs.second;
// 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;
} }
CV_WRAP bool PredictCollector::filter(int* label, double* dist, const int state) //===================================
{
((void)label); StandardCollector::StandardCollector(double threshold_) : threshold(threshold_) {
((void)dist); init(0);
((void)state);
return true; //no custom logic at base level
} }
bool PredictCollector::emit(const int label, const double dist, const int state) { void StandardCollector::init(size_t size) {
((void)label); minRes = PredictResult();
((void)dist); data.clear();
((void)state); data.reserve(size);
return false; // terminate prediction - no any behavior in base PredictCollector
} }
CV_WRAP bool PredictCollector::collect(int label, double dist, const int state) bool StandardCollector::collect(int label, double dist) {
{ if (dist < threshold)
if (defaultFilter(&label, &dist, state) && filter(&label,&dist,state)) { {
return emit(label, dist, state); PredictResult res(label, dist);
if (res.distance < minRes.distance)
minRes = res;
data.push_back(res);
} }
return true; return true;
} }
CV_WRAP int PredictCollector::getSize() int StandardCollector::getMinLabel() const {
{ return minRes.label;
return _size;
} }
CV_WRAP void PredictCollector::setSize(int size) double StandardCollector::getMinDist() const {
{ return minRes.distance;
_size = size;
} }
CV_WRAP int PredictCollector::getState() std::vector< std::pair<int, double> > StandardCollector::getResults(bool sorted) const {
{ std::vector< std::pair<int, double> > res(data.size());
return _state; std::transform(data.begin(), data.end(), res.begin(), &toPair);
} if (sorted)
{
CV_WRAP void PredictCollector::setState(int state) std::sort(res.begin(), res.end(), &pairLess);
{ }
_state = state; return res;
} }
CV_WRAP int PredictCollector::getExcludeLabel() std::map<int, double> StandardCollector::getResultsMap() const {
{ std::map<int, double> res;
return _excludeLabel; for (std::vector<PredictResult>::const_iterator i = data.begin(); i != data.end(); ++i) {
} std::map<int, double>::iterator j = res.find(i->label);
if (j == res.end()) {
CV_WRAP void PredictCollector::setExcludeLabel(int excludeLabel) res.insert(toPair(*i));
{ } else if (i->distance < j->second) {
_excludeLabel = excludeLabel; j->second = i->distance;
} }
}
CV_WRAP double PredictCollector::getDistanceKoef() return res;
{
return _distanceKoef;
}
CV_WRAP void PredictCollector::setDistanceKoef(double distanceKoef)
{
_distanceKoef = distanceKoef;
}
CV_WRAP double PredictCollector::getMinThreshold()
{
return _minthreshold;
} }
CV_WRAP void PredictCollector::setMinThreshold(double minthreshold) Ptr<StandardCollector> StandardCollector::create(double threshold) {
{ return makePtr<StandardCollector>(threshold);
_minthreshold = minthreshold;
} }
} }} // cv::face::
}
\ No newline at end of file
/*
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
/*
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
/*
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
/*
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
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