zoukankan      html  css  js  c++  java
  • Python+OpenCV图像处理之人脸检测

    利用OpenCV自带的xml文件,可以实时检测摄像头中人脸

    Haar特征、LBP特征都是常用的特征,描述不同的局部信息

    Haar描述的是图像在局部范围内像素值明暗变换信息

    LBP描述的是图像在局部范围内对应的纹理信息

    HAAR与LBP区别: 
    ① HAAR特征是浮点数计算,LBP特征是整数计算; 
    ② LBP训练需要的样本数量比HAAR大; 
    ③ LBP的速度一般比HAAR快; 
    ④ 同样的样本HAAR训练出来的检测结果要比LBP准确; 
    ⑤ 扩大LBP的样本数据可达到HAAR的训练效果

    静态图像中检测人脸python实现

    def face_detect_demo(image):
        gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
        face_detector = cv2.CascadeClassifier("data/haarcascade_frontalface_default.xml")  # 创建检测人脸的对象
        faces = face_detector.detectMultiScale(gray, 1.02, 5)  # 进行人脸检测
        """
           faces = face_detector.detectMultiScale(img, scaleFactor, minNeighbors)
           参数:img: 识别的原图
                 scaleFactor: 迭代时图像的压缩率
                 minNeighbors: 每个人脸矩形保留近邻数目的最小值
           返回值:一个列表,列表里边每一项是一个框起人脸的矩形(x, y, w, h)
        """
        for x, y, w, h in faces:
            cv2.rectangle(image, (x, y), (x+w, y+h), (0, 0, 255), 2)
        cv2.imshow("face_detect_demo", image)

    结果

    视频中检测人脸python实现

    def detect():
        # 创建人脸检测的对象
        face_cascade = cv2.CascadeClassifier("../data/haarcascade_frontalface_default.xml")
        # 创建眼睛检测的q对象
        eye_cascade = cv2.CascadeClassifier("../data/haarcascade_eye.xml")
        # 创建微笑检测的q对象
        smile_cascade = cv2.CascadeClassifier("../data/haarcascade_smile.xml")
        # 连接摄像头的对象 0表示摄像头的编号
        camera = cv2.VideoCapture(0)
    
        while True:
            # 读取当前帧
            ret, frame = camera.read()
            # 转为灰度图像
            gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
            # 检测人脸 返回列表 每个元素都是(x, y, w, h)表示矩形的左上角和宽高
            faces = face_cascade.detectMultiScale(gray, 1.3, 5)
            # 画出人脸的矩形
            for (x, y, w, h) in faces:
                # 画矩形 在frame图片上画, 传入左上角和右下角坐标 矩形颜色 和线条宽度
                img = cv2.rectangle(frame, (x, y), (x+w, y+h), (255, 0, 0), 2)
                # 把脸单独拿出来
                roi_gray = gray[y: y+h, x: x+w]
                # 在脸上检测眼睛   (40, 40)是设置最小尺寸,再小的部分会不检测
                eyes = eye_cascade.detectMultiScale(roi_gray, 1.03, 5, 0, (40, 40))
                # 把眼睛画出来
                for(ex, ey, ew, eh) in eyes:
                    cv2.rectangle(img, (x+ex, y+ey), (x+ex+ew, y+ey+eh), (0, 255, 0), 2)
    
            cv2.imshow("camera", frame)
            if cv2.waitKey(5) & 0xff == ord("q"):
                break
    
        camera.release()
        cv2.destroyAllWindows()
  • 相关阅读:
    数据结构考研--线性表例2-4
    2011 BENELLI TRE1130K所有系统诊断:OBDSTAR MS80或OBDSTAR MS50?
    BMW E60可以通过Autel IM508和XP400 Pro读取数据并学习密钥吗?
    Launch X431 V V4.0 2021最新升级:32GB存储+ 30特殊功能
    Autel IM608 Pro为BMW 2010 535i添加新钥匙
    Xhorse VVDI Prog V5.0.0软件免费下载
    使用XP400 Pro通过Autel IM508读取Benz W207 EIS数据
    由CGDI Prog BMW与GODIAG GT100进行的BMW FEM / BDC密钥编程
    BMW CAS4 / CAS4 +编程测试平台购买建议
    2021 GODIAG GT100 ECU接线盒评测:出色的诊断和节省维修成本的设备
  • 原文地址:https://www.cnblogs.com/qianxia/p/11112645.html
Copyright © 2011-2022 走看看