【NanoPi2试用体验】简单人脸识别-结项

Nanopi2的试用也要接近尾声啦!

其实还有小半个月,不过过年了就不一定有时间,有心思在好好做当初预设的项目啦,所以最近赶工抓紧做完,剩下的时间里继续学一些自己想学的东西~
这一个半月的时间里自己学到了很多很多东西,在此感谢友善出这么好的产品,以及和 论坛 一起给我们提供试用的机会,向你们诚挚得说一声“谢谢”!!

下面是项目完成情况:
我的题目 名称很诡异,android下的简单人脸识别,然而我的陈述通篇没提android,我的实行也确实照着陈述来,所以就当我这个题目没啥意义好了……

上篇帖子是二维码识别,其实已经和简单人脸识别有点像了(部分手段)
我们主要用了python图像处理库——PIL,还有最最关键的opencv的分类器,此外还有对摄像头使用的一些库。

先说得到图片,肯定就是通过摄像头捕获图片了,我找到了一些方法:

  1. 安装mplayer 
  2. sudo apt-get install mplayer 
  3. 输入命令播放摄像头视频
  4. sudo mplayer tv://
复制代码
这个需要强制把摄像头设置为 /dev/video0
  1. rm /dev/video0
  2. mv /dev/video9 /dev/video0
复制代码
经过我的测试,是可以使用的,然而我并不能保存图片……天寒地冻的,我也不想深究了,反正方法多的。。。

  1. sudo apt-get install fswebcam 
  2. sudo fswebcam --device /dev/video9  a.jpg
复制代码
这种方法也可以,而且能保存图片,所以就用它了~

接下来的主体就交给PIL和opencv了

  1. find / -name opencv
复制代码
查找一下opencv的目录
找到了关键的文件:
  1. /usr/share/opencv/haarcascades/haarcascade_frontalface_alt_tree.xml
复制代码
接下来就比较顺利啦:

identify_face.py
  1. #!/usr/bin/env python
  2. #coding=utf-8
  3. import os
  4. from PIL import Image, ImageDraw
  5. import cv

  6. def detect_object(image):
  7.     grayscale = cv.CreateImage((image.width, image.height), 8, 1)
  8.     cv.CvtColor(image, grayscale, cv.CV_BGR2GRAY)

  9.     cascade = cv.Load("/usr/share/opencv/haarcascades/haarcascade_frontalface_alt_tree.xml")
  10.     rect = cv.HaarDetectObjects(grayscale, cascade, cv.CreateMemStorage(), 1.1, 2,
  11.         cv.CV_HAAR_DO_CANNY_PRUNING, (20,20))

  12.     result = []
  13.     for r in rect:
  14.         result.append((r[0][0], r[0][1], r[0][0]+r[0][2], r[0][1]+r[0][3]))

  15.     return result

  16. def process(infile):
  17.     image = cv.LoadImage(infile);
  18.     if image:
  19.         faces = detect_object(image)

  20.     im = Image.open(infile)
  21.     path = os.path.abspath(infile)
  22.     save_path = os.path.splitext(path)[0]+"_face"
  23.     try:
  24.         os.mkdir(save_path)
  25.     except:
  26.         pass
  27.     if faces:
  28.         draw = ImageDraw.Draw(im)
  29.         count = 0
  30.         for f in faces:
  31.             count += 1
  32.             draw.rectangle(f, outline=(255, 0, 0))
  33.             a = im.crop(f)
  34.             file_name = os.path.join(save_path,str(count)+".jpg")
  35.      #       print file_name
  36.             a.save(file_name)

  37.         drow_save_path = os.path.join(save_path,"out.jpg")
  38.         im.save(drow_save_path, "JPEG", quality=80)
  39.     else:
  40.         print "Error: cannot detect faces on %s" % infile

  41. if __name__ == "__main__":
  42.         os.system("fswebcam --device /dev/video9 /home/fa/Desktop/cc.jpg")
  43.     process("/home/fa/Desktop/cc.jpg")
复制代码


执行:
  1. python identify_face.py
复制代码

控制台效果:
 

拍摄图:
 

效果如下:

 

 


显然也可以本地图片的识别、或者一直对摄像头进行拍照分析等。

以上为所有内容,谢谢各位,同时再次感谢论坛和友善官方的支持!
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
人脸识别是指利用计算机视觉技术对图像或视频中的人脸进行自动识别和分析的过程。人脸识别技术主要包括特征检测和人脸匹配两个部分。 特征检测是指从图像中提取出与人脸有关的特征信息,包括人脸的轮廓、眼睛、鼻子、嘴巴等特征点。在特征检测过程中,通常会使用Haar特征分类器、HOG特征分类器或者深度学习的卷积神经网络等算法来实现。 人脸匹配是指将提取出来的人脸特征与数据库中已有的人脸特征进行比对,以判断该人脸是否已经被识别过或者是否为指定人员。常见的人脸匹配算法包括欧氏距离匹配算法、余弦相似度匹配算法、支持向量机(SVM)等。 关于利用C++实现人脸识别的代码,可以参考开源库OpenCV中的示例代码,该库提供了丰富的图像处理和计算机视觉功能,包括人脸检测和识别等。以下是一个简单的基于OpenCV的人脸检测和识别的代码示例: ```c++ #include <opencv2/opencv.hpp> #include <opencv2/face.hpp> using namespace cv; using namespace std; using namespace cv::face; int main(int argc, char** argv) { // 加载人脸检测器和识别器 CascadeClassifier face_cascade; face_cascade.load("haarcascade_frontalface_alt.xml"); Ptr<LBPHFaceRecognizer> recognizer = LBPHFaceRecognizer::create(); // 加载训练好的模型 recognizer->read("model.xml"); // 打开摄像头 VideoCapture cap(0); if (!cap.isOpened()) { cout << "无法打开摄像头!" << endl; return -1; } while (true) { Mat frame; cap >> frame; // 转换成灰度图像并进行直方图均衡化 Mat gray; cvtColor(frame, gray, COLOR_BGR2GRAY); equalizeHist(gray, gray); // 检测人脸 vector<Rect> faces; face_cascade.detectMultiScale(gray, faces, 1.1, 2, 0 | CASCADE_SCALE_IMAGE, Size(30, 30)); // 对每个检测到的人脸进行识别 for (size_t i = 0; i < faces.size(); i++) { Mat face = gray(faces[i]); resize(face, face, Size(92, 112)); // 将人脸图像缩放到指定大小 int label = -1; double confidence = 0.0; recognizer->predict(face, label, confidence); // 在图像中标注出人脸位置和识别结果 rectangle(frame, faces[i], Scalar(255, 0, 0), 2); putText(frame, format("Person %d", label), Point(faces[i].x, faces[i].y - 5), FONT_HERSHEY_PLAIN, 1.0, Scalar(0, 255, 0), 2); } imshow("Face Recognition", frame); if (waitKey(30) == 'q') break; } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值