opencv联合dlib人脸检测例子

arvik arvik     2023-02-24     406

关键词:

源码比较简洁,杂余信息全部去掉,源码中已经做了中文注释。本例子是用opencv加载图像,然后调用dlib进行人脸检测,得到人脸所在区域以及特征点,最后还是用opencv描绘人脸特征点。

例子源码以及解释:

#include <dlib/image_processing/frontal_face_detector.h>
#include <dlib/image_processing/render_face_detections.h>
#include <dlib/image_processing.h>
#include <dlib/gui_widgets.h>
#include <dlib/image_io.h>
#include <iostream>
#include <dlib/opencv.h>
#include "opencv2/opencv.hpp"
#include <vector>
#include <ctime>

//由于dlib和opencv中有相当一部分类同名,故不能同时对它们使用using namespace,否则会出现一些莫名其妙的问题
//using namespace dlib;
using namespace std;
//using namespace cv;

void line_one_face_detections(cv::Mat img, std::vector<dlib::full_object_detection> fs)

    int i, j;
    for(j=0; j<fs.size(); j++)
    
        cv::Point p1, p2;
        for(i = 0; i<67; i++)
        
            // 下巴到脸颊 0 ~ 16
            //左边眉毛 17 ~ 21
            //右边眉毛 21 ~ 26
            //鼻梁     27 ~ 30
            //鼻孔        31 ~ 35
            //左眼        36 ~ 41
            //右眼        42 ~ 47
            //嘴唇外圈  48 ~ 59
            //嘴唇内圈  59 ~ 67
            switch(i)
            
                case 16:
                case 21:
                case 26:
                case 30:
                case 35:
                case 41:
                case 47:
                case 59:
                    i++;
                    break;
                default:
                    break;
            

            p1.x = fs[j].part(i).x();
            p1.y = fs[j].part(i).y();
            p2.x = fs[j].part(i+1).x();
            p2.y = fs[j].part(i+1).y();
            cv::line(img, p1, p2, cv::Scalar(0,0,255), 2, 4, 0);
        
    



int main(int argc, char *argv[])

    if(argc != 2)
    
        std::cout<< "you should specified a picture!"<<std::endl;
        return 0;
    

    cv::Mat frame = cv::imread(argv[1]);
    cv::Mat dst;

    //提取灰度图
    cv::cvtColor(frame, dst, CV_BGR2GRAY);

    //加载dlib的人脸识别器
    dlib::frontal_face_detector detector = dlib::get_frontal_face_detector();

    //加载人脸形状探测器
    dlib::shape_predictor sp;
    dlib::deserialize("./shape_predictor_68_face_landmarks.dat") >> sp;

    //Mat转化为dlib的matrix
    dlib::array2d<dlib::bgr_pixel> dimg;
    dlib::assign_image(dimg, dlib::cv_image<uchar>(dst)); 

    //获取一系列人脸所在区域
    std::vector<dlib::rectangle> dets = detector(dimg);
    std::cout << "Number of faces detected: " << dets.size() << std::endl;

    if (dets.size() == 0)
        return 0;

    //获取人脸特征点分布
    std::vector<dlib::full_object_detection> shapes;
    int i = 0;
    for(i = 0; i < dets.size(); i++)
    
        dlib::full_object_detection shape = sp(dimg, dets[i]); //获取指定一个区域的人脸形状
        shapes.push_back(shape); 
       

    //指出每个检测到的人脸的位置
    for(i=0; i<dets.size(); i++)
    
        //画出人脸所在区域
        cv::Rect r;
        r.x = dets[i].left();
        r.y = dets[i].top();
        r.width = dets[i].width();
        r.height = dets[i].height();
        cv::rectangle(frame, r, cv::Scalar(0, 0, 255), 1, 1, 0); 
    

    line_one_face_detections(frame, shapes);

    cv::imshow("frame", frame);
    cv::waitKey(0);
    return 0;

效果:

opencv联合dlib人脸检测例子二(加快检测)(代码片段)

本篇博客是在opencv联合dlib人脸检测例子的基础上改进了下,加快检测流程观察了下,opencv利用haar级联分类器检测人脸区域的速度要稍快于dlib的frontal_face_detector检测人脸区域的速度。所以这篇博客是利用opencv先检测出人... 查看详情

opencv联合dlib人脸检测例子

...息全部去掉,源码中已经做了中文注释。本例子是用opencv加载图像,然后调用dlib进行人脸检测,得到人脸所在区域以及特征点,最后还是用opencv描绘人脸特征点。例子源码以及解释:#include<dlib/image_processing/... 查看详情

opencv联合dlib视频人脸识别例子(代码片段)

本篇文章是在上一篇文章opencv联合dlib人脸识别例子的基础上做了一个实时视频人脸识别功能。原理是利用opencv实时提取视频中的视频流,然后进入人脸检测步骤,步骤类似上篇文章。本篇文章中的程序是在VMware虚拟机下... 查看详情

opencv联合dlib人脸识别例子(代码片段)

本篇文章是在上一篇文章opencv联合dlib人脸检测例子二(加快检测)的基础上做了一个人脸识别功能。本文章中的代码实现了人脸识别功能。检测目标图片中的人脸是不是库中的某张图片中的人脸,按照以下操作步骤... 查看详情

opencv联合dlib人脸识别例子(代码片段)

本篇文章是在上一篇文章opencv联合dlib人脸检测例子二(加快检测)的基础上做了一个人脸识别功能。本文章中的代码实现了人脸识别功能。检测目标图片中的人脸是不是库中的某张图片中的人脸,按照以下操作步骤... 查看详情

opencv联合dlib视频人脸识别例子(代码片段)

本篇文章是在上一篇文章opencv联合dlib人脸识别例子的基础上做了一个实时视频人脸识别功能。原理是利用opencv实时提取视频中的视频流,然后进入人脸检测步骤,步骤类似上篇文章。本篇文章中的程序是在VMware虚拟机下... 查看详情

dlib库包的介绍与使用,opencv+dlib检测人脸框opencv+dlib进行人脸68关键点检测,opencv+dlib实现人脸识别,dlib进行人脸特征聚类dlib视频目标跟踪(代码片段)

...lib人脸检测:绘制出人脸检测框2.1dlib人脸检测源码2.2opencv+dlib人脸检测2.3dlib人脸检测总结3dlib人脸关键点检测:并绘制检测框、关键点、不同区域关键点连线3.1dlib人脸关键点检测源码3.2opencv+dlib进行人脸关键点检测... 查看详情

图片人脸检测——dlib版

上几篇给大家讲了OpenCV的图片人脸检测,而本文给大家带来的是比OpenCV更加精准的图片人脸检测Dlib库。点击查看往期:《图片人脸检测——OpenCV版(二)》《视频人脸检测——OpenCV版(三)》dlib与OpenCV对比识别精准... 查看详情

视频人脸检测——dlib版(代码片段)

往期目录视频人脸检测——Dlib版(六)OpenCV添加中文(五)图片人脸检测——Dlib版(四)视频人脸检测——OpenCV版(三)图片人脸检测——OpenCV版(二)OpenCV环境搭建(一)更多更新,欢迎访问我的github:https://github.com/vipstone/... 查看详情

将 OpenCV Rect 转换为 dlib 矩形?

】将OpenCVRect转换为dlib矩形?【英文标题】:ConvertOpenCV\'sRecttodlib\'srectangle?【发布时间】:2016-04-2415:04:42【问题描述】:由于速度慢,我使用OpenCV的人脸检测器和C++进行dlib的人脸对齐,而不是dlib的检测器。要使用dlib的人脸对齐... 查看详情

OpenCV,dlib 地标旋转

】OpenCV,dlib地标旋转【英文标题】:OpenCV,dliblandmarksrotation【发布时间】:2017-12-2923:27:16【问题描述】:我是OpenCV和dlib的新手,我不确定我的设计是否正确。我想为android手机编写C++人脸检测器,它应该检测具有不同手机方向和... 查看详情

dlib+opencv库实现疲劳检测(代码片段)

文章目录1.关键点检测2.算法实现的核心点3.算法实现(1)人脸的关键点集合(2)加载人脸检测库和人脸关键点检测库(3)绘制人脸检测的框(4)对检测之后的人脸关键点坐标进行转换(5)... 查看详情

dlib实现人脸的68点检测

Dlib实现68点标定效果图展示:主要是通过68点的模型进行提取脸部的68点的特征值。(相应细节都已经注释)//设置人脸的标记点#include<dlibopencv.h>#include<opencv2opencv.hpp>#include<dlibimage_processingfrontal_face_detector.h>#include< 查看详情

dlib+opencv深度学习人脸识别

目录(?)[+]DlibOpenCV深度学习人脸识别前言人脸数据库导入人脸检测人脸识别异常处理  Dlib+OpenCV深度学习人脸识别   前言人脸识别在LWF(LabeledFacesintheWild)数据集上人脸识别率现在已经99.7%以上,这个识别率确实非... 查看详情

Dlib 人脸检测在 C++ 上的糟糕表现,在 python 中很好,为啥?

...描述】:我正在尝试编写一个简单的人脸检测算法,使用OpenCV进行相机捕捉,使用Dlib进行人脸检测(使用定向梯度直 查看详情

人脸检测进阶:使用dlibopencv和python检测面部标记(代码片段)

使用dlib、OpenCV和Python检测面部标记今天,我们将使用dlib和OpenCV来检测图像中的面部标记。dlib的安装教程:https://wanghao.blog.csdn.net/article/details/121470556人脸检测器模型:https://download.csdn.net/download/hhhhhhhhhhwwwwwwwwww/50939290... 查看详情

人脸检测——dlib学习face_detector_example(代码片段)

...翻译a. 这个例子展示了如何在一个图像中找到正面的人脸。具体来说,它显示了如何从命令行获取图像列表,并在屏幕上显示每个带有红框的人脸。 b. Face_detector采用了HOG特征,结合了线性分类器、图像金字塔和滑动... 查看详情

Dlib 人脸检测不适用于灰度图像

】Dlib人脸检测不适用于灰度图像【英文标题】:Dlibfacedetectiondoesn\'tworkwithgrayscaleimages【发布时间】:2019-02-2020:06:31【问题描述】:你知道为什么dlib人脸检测不适用于灰度图像(python对灰度图像效果很好)吗?我的代码:mFaceDetec... 查看详情