请选择 进入手机版 | 继续访问电脑版

【D1V1网】防未病大数据

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 活动 交友

社区广播台

查看: 22|回复: 0

opencv人脸识别源代码分享

[复制链接]
发表于 2018-5-11 05:52:52 | 显示全部楼层 |阅读模式


电子发烧友网
熊掌号

收听电子行业动态,抢先知晓半导体行业






  对人类来说,人脸识别很容易仅仅是才三天的婴儿已经可以区分周围熟悉的人脸了。那么对于计算机来说,到底有多难?其实,迄今为止,我们对于人类自己为何可以区分不同的人所知甚少。是人脸内部特征(眼睛、鼻子、嘴巴)还是外部特征(头型、发际线)对于人类识别更有效?
  自动人脸识别就是如何从一幅图像中提取有意义的特征,把它们放入一种有用的表示方式,然后对他们进行一些分类。基于几何特征的人脸的人脸识别可能是最直观的方法来识别人脸。
  人脸识别的第一步,就是人脸检测。把人的脸部从一张照片中用计算机自动识别出来,作为下一步人脸识别的基础。
  在opencv中,库中自带了一个利用harr特征的人脸检测训练及检测函数:cvHaarDetectObjects。它利用训练好的检测器,在图片中间检测你想要的物体,如人脸。opencv自带了很多检测器,在%opencv%data/haarcascades目录下,你可以随意取用。或者你也可以自己用图片训练自己的检测器,之后拿来使用。
  如何来用OpenCV来实现能。  下面给出OpenCV实现人脸检测的一般步骤:
  1.加载人脸检测器
  2.开启摄像头
  3.对图片进行灰度处理(其实可以不处理,上图中原图的标题栏就是未进行灰度处理进行的检测,这里的灰度是为下节人脸识别打基础)
  4.对图片进行直方图均衡化(其实可以不处理,上图中原图的标题栏就是未进行灰度处理进行的检测和灰度图是为进行均衡化识别,这里的均衡化是为下节人脸识别打基础)
  5.人脸检测
  总结下,如果单单只要人脸检测,可以的步骤是1,2,5
  程序截图如下:
   2755783-1G204141G3P7.jpg

  下面是完整的代码,本代码还有大量注释,在此不再具体说明哪个函数有什么用。
  [cpp] view plain copy#include 《opencv.hpp》
  #include 《opencv2/core/core.hpp》
  #include 《iostream》
  using namespace cv;
  void Pic2Gray(Mat camerFrame,Mat &gray)
  {
  //普通台式机3通道BGR,移动设备为4通道
  if (camerFrame.channels() == 3)
  {
  cvtColor(camerFrame, gray, CV_BGR2GRAY);
  }
  else if (camerFrame.channels() == 4)
  {
  cvtColor(camerFrame, gray, CV_BGRA2GRAY);
  }
  else
  gray = camerFrame;
  }
  int main()
  {
  //加载Haar或LBP对象或人脸检测器
  CascadeClassifier faceDetector;
  std::string faceCascadeFilename = “haarcascade_frontalface_default.xml”;
  //友好错误信息提示
  try{
  faceDetector.load(faceCascadeFilename);
  }
  catch (cv::Exception e){}
  if (faceDetector.empty())
  {
  std::cerr 《《 “脸部检测器不能加载 (”;
  std::cerr 《《 faceCascadeFilename 《《 “)!” 《《 std::endl;
  exit(1);
  }
  //打开摄像头
  VideoCapture camera(0);
  while (true)
  {
  Mat camerFrame;
  camera 》》 camerFrame;
  if (camerFrame.empty())
  {
  std::cerr 《《 “无法获取摄像头图像” 《《 std::endl;
  getchar();
  exit(1);
  }
  Mat displayedFrame(camerFrame.size(),CV_8UC3);
  //人脸检测只试用于灰度图像
  Mat gray;
  Pic2Gray(camerFrame, gray);
  //直方图均匀化(改善图像的对比度和亮度)
  Mat equalizedImg;
  equalizeHist(gray, equalizedImg);
  //人脸检测用Cascade Classifier::detectMultiScale来进行人脸检测
  int flags = CASCADE_FIND_BIGGEST_OBJECT|CASCADE_DO_ROUGH_SEARCH; //只检测脸最大的人
  //int flags = CASCADE_SCALE_IMAGE; //检测多个人
  Size minFeatureSize(30, 30);
  float searchScaleFactor = 1.1f;
  int minNeighbors = 4;
  std::vector《Rect》 faces;
  faceDetector.detectMultiScale(equalizedImg, faces, searchScaleFactor, minNeighbors, flags, minFeatureSize);
  //画矩形框
  cv::Mat face;
  cv::Point text_lb;
  for (size_t i = 0; i 《 faces.size(); i++)
  {
  if (faces[i].height 》 0 && faces[i].width 》 0)
  {
  face = gray(faces[i]);
  text_lb = cv::Point(faces[i].x, faces[i].y);
  cv::rectangle(equalizedImg, faces[i], cv::Scalar(255, 0, 0), 1, 8, 0);
  cv::rectangle(gray, faces[i], cv::Scalar(255, 0, 0), 1, 8, 0);
  cv::rectangle(camerFrame, faces[i], cv::Scalar(255, 0, 0), 1, 8, 0);
  }
  }
  imshow(“直方图均匀化”, equalizedImg);
  imshow(“灰度化”, gray);
  imshow(“原图”, camerFrame);
  waitKey(20);
  }
  getchar();
  return 0;
  }


您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表