(二)基于keras的多目标人脸识别之人脸收集

例行美图

github地址:https://github.com/haoxinl/face_detect/tree/master/data_script

博客地址:http://haoxinl.club/2018/02/19/face-detect-2/

前言

本文重点介绍数据收集的几种方法,包括了收集包含人脸的照片或视频以及从照片或视频中分离人脸两部分。详情还请见我的github:https://github.com/haoxinl/face_detect

正文

数据收集

如果你手机中存的照片多的话(至少也需要200张左右吧),可以直接跳过这一步骤~~

收集包含人脸的照片

主要依赖于cv2库

import cv2

cap = cv2.VideoCapture(0)
i=0
while(1):
    # get a frame
    ret, frame = cap.read()
    # show a frame
    cv2.imshow("capture", frame)
    i += 1
    if cv2.waitKey(1) & 0xFF == ord('q'):
        cv2.imwrite("C:\pylearning\ml&dl\\face_detect\\test_img\\"+str(i)+'.jpg', frame)
        continue
cap.release()
cv2.destroyAllWindows()

使用的是摄像头自带的摄像头,不断按q键即可快速截图

收集包含人脸的视频

主要依赖于cv2库

import cv2

cap = cv2.VideoCapture(0)

fourcc = cv2.VideoWriter_fourcc(*'MP4V')
out = cv2.VideoWriter('output3.mp4',fourcc, 20.0, (640,480))

while(cap.isOpened()):
    ret, frame = cap.read()
    if ret==True:
        out.write(frame)

        cv2.imshow('frame',frame)
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    else:
        break
cap.release()
out.release()
cv2.destroyAllWindows()

因为手动截图确实还是有不少麻烦,所以这里直接使用录视频的方式,之后再进行处理。

人脸分离

通过以上步骤我们已经得到了包含人脸的照片与视频,接下来将分别对其进行人脸分离

其实重点是cv2.CascadeClassifier库的应用,相关文件在我的github中config文件夹中

从照片中分离


def get_face(Path,objectPath,num):
    face_cascade = cv2.CascadeClassifier('C:\pylearning\ml&dl\\face_detect_v0\config\haarcascade_frontalface_default.xml')
    im = cv2.imread(Path)
    faces = face_cascade.detectMultiScale(im, 1.3, 5)
    for x, y, w, h in faces:
        f = cv2.resize(im[y:(y + h), x:(x + w)], (128, 128))
        cv2.imwrite(objectPath+'\\' + str(num) +'.jpg', f)

以上通过detectMultiScale操作检测到人脸区域,然后在原始图片上截取相关区域并进行存储。

从视频中分离

def get_img(video_path,face_path):
    face_cascade = cv2.CascadeClassifier('C:\pylearning\ml&dl\\face_detect_v0\config\haarcascade_frontalface_default.xml')
    vc = cv2.VideoCapture(video_path)  # 读入视频文件
    c = 1
    if vc.isOpened():  # 判断是否正常打开
        rval, frame = vc.read()
    else:
        rval = False
    timeF = 5  # 视频帧计数间隔频率
    while rval:  # 循环读取视频帧
        rval, frame = vc.read()
        if (c % timeF == 0):
            faces = face_cascade.detectMultiScale(frame, 1.3, 5)
            # 每隔timeF帧进行存储操作
            for x, y, w, h in faces:
                f = cv2.resize(frame[y:(y + h), x:(x + w)], (128, 128))
                cv2.imwrite(face_path+'\\'+str(int(c/timeF)) + '.jpg', f)
        c+=1# 存储为图像
        cv2.waitKey(1)
    vc.release()

原理与从照片中分离大同小异。。。

结语

我们通过上述步骤已经得到了训练所需的素材,下面就开始正式训练^^

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 最近每周的作业,都在纠结该写什么。 翻阅了几遍有道云笔记上的收藏夹,找到了适合自己的有关如何积累写作话题和素材的方...
    Bill何咏标阅读 744评论 1 51
  • 喜欢他,从2013年的快男海选那个吃个不停的愣头男,到说起父母就会流泪的小孩,从《无字歌》到《我》到《POCKER...
    凡思澄_FansCheng阅读 442评论 0 0
  • 乌篷船 乌篷船不喜好大海 或者说不喜好大海的风雨 和难以到达的岸边 落日都是一样的 即使是这条窄窄浅浅的河 也同样...
    瓦尔登野人阅读 315评论 0 1
  • 看夕阳微洒水面 看姹紫嫣红开遍 却一盏茶起落间,满眼絮花飞落 一切只是刹那 一个刹那未曾端详 又一个刹那已成过往 ...
    掬手留香阅读 325评论 12 3
  • 生活,倒也简单,早上九点上班,下午两点至四点吃饭、休息片刻,晚上九点下班。而稍有趣的,便是下班后的时光。 跑步、仰...
    昉之阅读 368评论 27 5