Linux下python与C++使用dlib实现人脸检测


Posted in Python onJune 29, 2018

python 与 C++ dlib人脸检测结果对比,供大家参考,具体内容如下

说明:

由于项目需求发现Linux下c++使用dlib进行人脸检测和python使用dlib检测,得到的结果出入比较大,于是写了测试用例,发现影响结果的原因有但不限于:

1.dlib版本不同(影响不大,几个像素的差别)
2.dlib 人脸检测中detector()第二个参数的设置测试结果如下:

Linux下python与C++使用dlib实现人脸检测

python

PDlib.py:

# -*- coding: utf-8 -*-

import sys
import cv2 
import dlib

from skimage import io
detector = dlib.get_frontal_face_detector()
win = dlib.image_window()

for f in sys.argv[1:]: 
  img = io.imread(f)

  dets = detector(img,1) #使用detector进行人脸检测

  for i, d in enumerate(dets):
    x = d.left()
    y = d.top()
    w = d.right()
    h = d.bottom()   
    cv2.rectangle(img, (x, y), (w, h), (0, 255, 0))
    print("({},{},{},{})".format( x, y, (w-x), (h-y)))

  win.set_image(img)
  io.imsave('./P_Dlib_test.jpg',img)

  #等待点击
  dlib.hit_enter_to_continue()

C++

CDlib.cpp:

#include <dlib/image_processing/frontal_face_detector.h>
#include <dlib/opencv.h>
#include "opencv2/opencv.hpp"
#include <iostream>

using namespace dlib;
using namespace std;

cv::Rect Detect(cv::Mat im)
{
  cv::Rect R;
  frontal_face_detector detector = get_frontal_face_detector();
  array2d<bgr_pixel> img; 
  assign_image(img, cv_image<uchar>(im));
  std::vector<rectangle> dets = detector(img);//检测人脸

  //查找最大脸
  if (dets.size() != 0)
  {
    int Max = 0;
    int area = 0;
    for (unsigned long t = 0; t < dets.size(); ++t)
    {      
      if (area < dets[t].width()*dets[t].height())
      {
        area = dets[t].width()*dets[t].height();
        Max = t;
      }
    }

    R.x = dets[Max].left();
    R.y = dets[Max].top();
    R.width = dets[Max].width();
    R.height = dets[Max].height();
    cout<<"("<<R.x<<","<<R.y<<","<<R.width<<","<<R.height<<")"<<endl;
  }
  return R;
}

int main(int argc, char** argv)
{
  if (argc != 2) {
    fprintf(stderr, "请输入正确参数\n");
    return 1;
  }  
  string path = argv[1];
  try
  {    
    cv::Mat src, dec;
    src = cv::imread(path);
    src.copyTo(dec);
    cv::cvtColor(dec, dec, CV_BGR2GRAY);
    cv::Rect box;
    box = Detect(dec);
    cv::rectangle(src, box, cv::Scalar(0, 0, 255), 1, 1, 0);    
    cv::imshow("frame", src);
    cv::imwrite("./C_Dlib_test.jpg", src);
    cv::waitKey(0);//等待建入 
  }
  catch (exception& e)
  {
    cout << e.what() << endl;
  }
}

项目编译及运行

python

运行脚本 python PDlib.py G:\DlibTest\data\bush.jpg

C++

  • 创建编译文件夹 mkdir cbuild
  • 切换到编译目录 cd cbuild
  • 生成makefile文件 cmake ..
  • 编译项目 make
  • 运行可执行文件 ./DlibTest G:\DlibTest\data\bush.jpg

Demo:点击下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现的文本编辑器功能示例
Jun 30 Python
Django查询数据库的性能优化示例代码
Sep 24 Python
Python将多个excel表格合并为一个表格
Feb 22 Python
python+matplotlib实现动态绘制图片实例代码(交互式绘图)
Jan 20 Python
Python获取指定文件夹下的文件名的方法
Feb 06 Python
python中的闭包函数
Feb 09 Python
Python装饰器的执行过程实例分析
Jun 04 Python
对TensorFlow中的variables_to_restore函数详解
Jul 30 Python
Python基于Tkinter模块实现的弹球小游戏
Dec 27 Python
python 将大文件切分为多个小文件的实例
Jan 14 Python
pygame实现打字游戏
Feb 19 Python
PyQt5实现简单的计算器
May 30 Python
对python中两种列表元素去重函数性能的比较方法
Jun 29 #Python
Python数据持久化shelve模块用法分析
Jun 29 #Python
python 统计列表中不同元素的数量方法
Jun 29 #Python
python计算两个数的百分比方法
Jun 29 #Python
python统计字母、空格、数字等字符个数的实例
Jun 29 #Python
python中计算一个列表中连续相同的元素个数方法
Jun 29 #Python
Python使用ConfigParser模块操作配置文件的方法
Jun 29 #Python
You might like
基于mysql的bbs设计(四)
2006/10/09 PHP
获取php页面执行时间,数据库读写次数,函数调用次数等(THINKphp)
2013/06/03 PHP
使用PHP会话(Session)实现用户登陆功能
2013/06/29 PHP
php输出指定时间以前时间格式的方法
2015/03/21 PHP
php实现的一段简单概率相关代码
2016/05/30 PHP
解决出现SoapFault (looks like we got no XML document)的问题
2017/06/24 PHP
Javascript 圆角div的实现代码
2009/10/15 Javascript
跟着Jquery API学Jquery之一 选择器
2010/04/07 Javascript
Javascript Function对象扩展之延时执行函数
2010/07/06 Javascript
javascript中input中readonly和disabled区别介绍
2012/10/23 Javascript
js对字符串进行编码的方法总结(推荐)
2016/11/10 Javascript
解决前端跨域问题方案汇总
2016/11/20 Javascript
如何防止INPUT按回车自动提交表单FORM
2016/12/06 Javascript
使用原生的javascript来实现轮播图
2017/02/24 Javascript
js如何获取图片url的Blob值并预览示例代码
2019/03/07 Javascript
Vue批量图片显示时遇到的路径被解析问题
2019/03/28 Javascript
微信小程序实现一个简单swiper代码实例
2019/12/30 Javascript
详解Vue.js 响应接口
2020/07/04 Javascript
vue-quill-editor插入图片路径太长问题解决方法
2021/01/08 Vue.js
JavaScript实现跟随鼠标移动的盒子
2021/01/28 Javascript
[01:18]PWL开团时刻DAY4——圣剑与抢盾
2020/11/03 DOTA
深入讲解Java编程中类的生命周期
2016/02/05 Python
详解Python中最难理解的点-装饰器
2017/04/03 Python
Python快速转换numpy数组中Nan和Inf的方法实例说明
2019/02/21 Python
Django项目主urls导入应用中views的红线问题解决
2019/08/10 Python
从零实现一个自定义html5播放器的示例代码
2017/08/01 HTML / CSS
美国眼镜网站:EyeBuyDirect
2017/04/13 全球购物
德国领先的大尺码和超大尺码男装在线零售商:Bigtex
2019/06/22 全球购物
管理学专业个人求职信范文
2013/09/21 职场文书
汽车电子与维修专业大学生求职信
2013/09/28 职场文书
税务干部鉴定材料
2014/02/11 职场文书
关于安全演讲稿
2014/05/09 职场文书
给市场的环保建议书
2014/05/14 职场文书
青春励志演讲稿范文
2014/08/25 职场文书
倡议书格式
2014/08/30 职场文书
医院党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书