人脸识别(通过照片库区别人物)

来源:互联网 发布:c语言入门算法 编辑:程序博客网 时间:2024/04/30 15:03
/*
人脸的学习性识别,学习网址:


http://docs.opencv.org/2.4/modules/contrib/doc/facerec/facerec_api.html#facerecognizer-train


*/


#include<iostream>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\opencv.hpp>
using namespace std;
using namespace cv;
void main()
{




// holds images and labels
vector<Mat> images;
vector<int> labels;
// images for first person
images.push_back(imread("person0/0.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(0);
images.push_back(imread("person0/1.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(0);
images.push_back(imread("person0/2.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(0);
// images for second person
images.push_back(imread("person1/0.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(1);
images.push_back(imread("person1/1.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(1);
images.push_back(imread("person1/2.jpg", CV_LOAD_IMAGE_GRAYSCALE)); labels.push_back(1);




Ptr<FaceRecognizer> model = createFisherFaceRecognizer();
model->train(images, labels);


Mat person0 = imread("person1/3.jpg", CV_LOAD_IMAGE_GRAYSCALE);


int predicted_label = -1;
double predicted_confidence = 0.0;
// Get the prediction and associated confidence from the model
model->predict(person0, predicted_label, predicted_confidence);

cout << predicted_label << endl;


system("pause");


}
0 0
原创粉丝点击