OpenCV  4.10.0
开源计算机视觉
正在加载...
正在搜索...
无匹配项
静态公有成员函数 | 所有成员列表
cv::face::EigenFaceRecognizer 类参考

#include <opencv2/face/facerec.hpp>

cv::face::EigenFaceRecognizer 协作图

静态公有成员函数

static Ptr< EigenFaceRecognizercreate (int num_components=0, double threshold=DBL_MAX)
 
- 从 cv::Algorithm 继承的静态公有成员函数
template<typename _Tp >
static Ptr< _Tpload (const String &filename, const String &objname=String())
 从文件中加载算法。
 
template<typename _Tp >
static Ptr< _TploadFromString (const String &strModel, const String &objname=String())
 从字符串加载算法。
 
template<typename _Tp >
static Ptr< _Tpread (const FileNode &fn)
 从文件节点读取算法。
 

额外继承的成员

- 从 cv::face::BasicFaceRecognizer 继承的公有成员函数
virtual bool empty () const CV_OVERRIDE
 
cv::Mat getEigenValues () const
 
cv::Mat getEigenVectors () const
 
cv::Mat getLabels () const
 
cv::Mat getMean () const
 
int getNumComponents () const
 
std::vector< cv::MatgetProjections () const
 
double getThreshold () const CV_OVERRIDE
 
virtual void read (const FileNode &fn) CV_OVERRIDE
 
virtual void read (const FileNode &fn) CV_OVERRIDE=0
 
virtual void read (const String &filename)
 加载 FaceRecognizer 及其模型状态。
 
void setNumComponents (int val)
 
void setThreshold (double val) CV_OVERRIDE
 
virtual void write (const String &filename) const
 保存 FaceRecognizer 及其模型状态。
 
virtual void write (FileStorage &fs) const CV_OVERRIDE
 
virtual void write (FileStorage &fs) const CV_OVERRIDE=0
 
- 从 cv::face::FaceRecognizer 继承的公有成员函数
virtual String getLabelInfo (int label) const
 根据标签获取字符串信息。
 
virtual std::vector< int > getLabelsByString (const String &str) const
 根据字符串获取标签向量。
 
int predict (InputArray src) const
 
void predict (InputArray src, int &label, double &confidence) const
 预测给定输入图像的标签和关联置信度(例如距离)。
 
virtual void predict (InputArray src, Ptr< PredictCollector > collector) const =0
 
  • 如果实现 - 将所有预测结果发送到收集器,收集器可用于某种自定义结果处理。

 
virtual void setLabelInfo (int label, const String &strInfo)
 为指定的模型标签设置字符串信息。
 
virtual void train (InputArrayOfArrays src, InputArray labels)=0
 使用给定数据和关联标签训练 FaceRecognizer
 
virtual void update (InputArrayOfArrays src, InputArray labels)
 使用给定数据和关联标签更新 FaceRecognizer
 
- 从 cv::Algorithm 继承的公有成员函数
 算法 ()
 
virtual ~Algorithm ()
 
virtual void clear ()
 清除算法状态。
 
virtual String getDefaultName () const
 
virtual void save (const String &filename) const
 
void write (const Ptr< FileStorage > &fs, const String &name=String()) const
 
void write (FileStorage &fs, const String &name) const
 
- 从 cv::Algorithm 继承的受保护成员函数
void writeFormat (FileStorage &fs) const
 
- 从 cv::face::BasicFaceRecognizer 继承的受保护属性
Mat _eigenvalues
 
Mat _eigenvectors
 
Mat _labels
 
Mat _mean
 
int _num_components
 
std::vector< Mat_projections
 
double _threshold
 
- 从 cv::face::FaceRecognizer 继承的受保护属性
std::map< int, String_labelsInfo
 

成员函数文档

◆ create()

static Ptr< EigenFaceRecognizer > cv::face::EigenFaceRecognizer::create ( int  num_components = 0,
double  threshold = DBL_MAX 
)
static
Python
cv.face.EigenFaceRecognizer.create([, num_components[, threshold]]) -> retval
cv.face.EigenFaceRecognizer_create([, num_components[, threshold]]) -> retval
参数
num_components此主成分分析保留的成分(即特征脸)数量。提示:没有关于为获得良好重建能力应该保留多少成分(即特征脸)的规则。它取决于您的输入数据,因此请尝试不同的数量。保留 80 个成分几乎总是足够。
threshold预测中应用的阈值。

备注

  • 训练和预测必须在灰度图像上进行,请使用 cvtColor 在颜色空间之间进行转换。
  • 特征脸方法假设训练和测试图像的大小相同。(大写,因为我收到了很多询问此问题的邮件)。您必须确保输入数据的形状正确,否则将抛出有意义的异常。请使用 resize 对图像进行调整大小。
  • 此模型不支持更新。

模型内部数据

  • num_components 请参见 EigenFaceRecognizer::create
  • threshold 请参见 EigenFaceRecognizer::create
  • eigenvalues 此主成分分析的特征值(按降序排列)。
  • eigenvectors 此主成分分析的特征向量(按其特征值排序)。
  • mean 从训练数据计算得出的样本均值。
  • projections 训练数据的投影。
  • labels 预测中应用的阈值。如果到最近邻居的距离大于阈值,则此方法返回 -1。

此类的文档是从以下文件生成的