之前运行haar特征的adaboost算法人脸检测一直出错,加上今天的HOG&SVM行人检测程序,一直报错。

今天总算发现自己犯了多么白痴的错误——是因为外部依赖项lib文件没有添加完整,想一头囊死啊

做程序一定要心如止水!!! 仔细查找!!!

1.人脸识别程序:

  1. #include "cv.h"
  2. #include "highgui.h"
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>
  6. #include <assert.h>
  7. #include <math.h>
  8. #include <float.h>
  9. #include <limits.h>
  10. #include <time.h>
  11. #include <ctype.h>
  12. using namespace std;
  13. static CvMemStorage* storage = 0;
  14. static CvHaarClassifierCascade* cascade = 0;
  15. void detect_and_draw( IplImage* image );
  16. const char* cascade_name =
  17. "G:/OpenCV2.3.1/data/haarcascades/haarcascade_frontalface_alt.xml";
  18. /* "haarcascade_profileface.xml";*/
  19. int main()
  20. {
  21. CvCapture* capture = 0;
  22. cascade = (CvHaarClassifierCascade*)cvLoad( cascade_name, 0, 0, 0 );
  23. if( !cascade )
  24. {
  25. fprintf( stderr, "ERROR: Could not load classifier cascade/n" );
  26. //fprintf( stderr,
  27. //"Usage: facedetect --cascade=/"<cascade_path>"/[filename|camera_index]/n" );
  28. return -1;
  29. }
  30. storage = cvCreateMemStorage(0);
  31. cvNamedWindow( "result", 1 );
  32. const char* filename = "H:/test/face05.jpg";
  33. IplImage* image = cvLoadImage(filename );
  34. if( image )
  35. {
  36. detect_and_draw( image );
  37. cvWaitKey(0);
  38. cvReleaseImage( &image );
  39. }
  40. cvDestroyWindow("result");
  41. cvWaitKey(0);
  42. return 0;
  43. }
  44. void detect_and_draw( IplImage* img )
  45. {
  46. static CvScalar colors[] =
  47. {
  48. {{0,0,255}},
  49. {{0,128,255}},
  50. {{0,255,255}},
  51. {{0,255,0}},
  52. {{255,128,0}},
  53. {{255,255,0}},
  54. {{255,0,0}},
  55. {{255,0,255}}
  56. };
  57. double scale = 1.3;
  58. IplImage* gray = cvCreateImage( cvSize(img->width,img->height), 8, 1 );
  59. IplImage* small_img = cvCreateImage( cvSize( cvRound (img->width/scale),
  60. cvRound (img->height/scale)),
  61. 8, 1 );
  62. int i;
  63. cvCvtColor( img, gray, CV_BGR2GRAY );
  64. cvResize( gray, small_img, CV_INTER_LINEAR );
  65. cvEqualizeHist( small_img, small_img );
  66. cvClearMemStorage( storage );
  67. if( cascade )
  68. {
  69. double t = (double)cvGetTickCount();
  70. CvSeq* faces = cvHaarDetectObjects( small_img, cascade, storage,
  71. 1.1, 2, 0/*CV_HAAR_DO_CANNY_PRUNING*/,
  72. cvSize(30, 30) );
  73. t = (double)cvGetTickCount() - t;
  74. printf( "detection time = %gms/n", t/((double)cvGetTickFrequency()*1000.) );
  75. for( i = 0; i < (faces ? faces->total : 0); i++ )
  76. {
  77. CvRect* r = (CvRect*)cvGetSeqElem( faces, i );
  78. CvPoint center;
  79. int radius;
  80. center.x = cvRound((r->x + r->width*0.5)*scale);
  81. center.y = cvRound((r->y + r->height*0.5)*scale);
  82. radius = cvRound((r->width + r->height)*0.25*scale);
  83. cvCircle( img, center, radius, colors[i%8], 3, 8, 0 );
  84. }
  85. }
  86. cvShowImage( "result", img );
  87. cvReleaseImage( &gray );
  88. cvReleaseImage( &small_img );
  89. }

2.行人检测程序

  1. #include <cv.h>
  2. #include <highgui.h>
  3. #include <string>
  4. #include <iostream>
  5. #include <algorithm>
  6. #include <iterator>
  7. #include <stdio.h>
  8. #include <string.h>
  9. #include <ctype.h>
  10. using namespace cv;
  11. using namespace std;
  12. void help()
  13. {
  14. printf(
  15. "\nDemonstrate the use of the HoG descriptor using\n"
  16. "  HOGDescriptor::hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());\n"
  17. "Usage:\n"
  18. "./peopledetect (<image_filename> | <image_list>.txt)\n\n");
  19. }
  20. int main(int argc, char** argv)
  21. {
  22. Mat img;
  23. FILE* f = 0;
  24. char _filename[1024];
  25. if( argc == 1 )
  26. {
  27. printf("Usage: peopledetect (<image_filename> | <image_list>.txt)\n");
  28. return 0;
  29. }
  30. img = imread(argv[1]);
  31. if( img.data )
  32. {
  33. strcpy(_filename, argv[1]);
  34. }
  35. else
  36. {
  37. f = fopen(argv[1], "rt");
  38. if(!f)
  39. {
  40. fprintf( stderr, "ERROR: the specified file could not be loaded\n");
  41. return -1;
  42. }
  43. }
  44. HOGDescriptor hog;
  45. hog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());//得到检测器
  46. namedWindow("people detector", 1);
  47. for(;;)
  48. {
  49. char* filename = _filename;
  50. if(f)
  51. {
  52. if(!fgets(filename, (int)sizeof(_filename)-2, f))
  53. break;
  54. //while(*filename && isspace(*filename))
  55. //  ++filename;
  56. if(filename[0] == '#')
  57. continue;
  58. int l = strlen(filename);
  59. while(l > 0 && isspace(filename[l-1]))
  60. --l;
  61. filename[l] = '\0';
  62. img = imread(filename);
  63. }
  64. printf("%s:\n", filename);
  65. if(!img.data)
  66. continue;
  67. fflush(stdout);
  68. vector<Rect> found, found_filtered;
  69. double t = (double)getTickCount();
  70. // run the detector with default parameters. to get a higher hit-rate
  71. // (and more false alarms, respectively), decrease the hitThreshold and
  72. // groupThreshold (set groupThreshold to 0 to turn off the grouping completely).
  73. hog.detectMultiScale(img, found, 0, Size(8,8), Size(32,32), 1.05, 2);
  74. t = (double)getTickCount() - t;
  75. printf("tdetection time = %gms\n", t*1000./cv::getTickFrequency());
  76. size_t i, j;
  77. for( i = 0; i < found.size(); i++ )
  78. {
  79. Rect r = found[i];
  80. for( j = 0; j < found.size(); j++ )
  81. if( j != i && (r & found[j]) == r)
  82. break;
  83. if( j == found.size() )
  84. found_filtered.push_back(r);
  85. }
  86. for( i = 0; i < found_filtered.size(); i++ )
  87. {
  88. Rect r = found_filtered[i];
  89. // the HOG detector returns slightly larger rectangles than the real objects.
  90. // so we slightly shrink the rectangles to get a nicer output.
  91. r.x += cvRound(r.width*0.1);
  92. r.width = cvRound(r.width*0.8);
  93. r.y += cvRound(r.height*0.07);
  94. r.height = cvRound(r.height*0.8);
  95. rectangle(img, r.tl(), r.br(), cv::Scalar(0,255,0), 3);
  96. }
  97. imshow("people detector", img);
  98. int c = waitKey(0) & 255;
  99. if( c == 'q' || c == 'Q' || !f)
  100. break;
  101. }
  102. if(f)
  103. fclose(f);
  104. return 0;
  105. }

注意:可能会出现tbb_debug.dll的问题,在G:\OpenCV2.3.1\build\common\tbb\ia32\vc10中找到tbb.dll改名为tbb_debug.dll 加到程序绝对目录下即可

还有其他的解决方式:http://blog.csdn.net/scut1135/article/details/7329398

from: http://blog.csdn.net/yangtrees/article/details/7453987

学习OpenCV——行人检测&人脸检测(总算运行出来了)的更多相关文章

  1. OpenCV例程实现人脸检测

    前段时间看的OpenCV,其实有很多的例子程序,参考代码值得我们学习,对图像特征提取三大法宝:HOG特征,LBP特征,Haar特征有一定了解后. 对本文中的例子程序刚开始没有调通,今晚上调通了,试了试 ...

  2. OpenCV神技——人脸检测,猫脸检测

    简介   OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux.Windows.Android和Mac OS操作系统上.它轻量级而且高效--由一系列 C 函数和少量 ...

  3. OpenCV入门指南----人脸检测

    本篇介绍图像处理与模式识别中最热门的一个领域——人脸检测(人脸识别).人脸检测可以说是学术界的宠儿,在不少EI,SCI高级别论文都能看到它的身影.甚至很多高校学生的毕业设计都会涉及到人脸检测.当然人脸 ...

  4. 基于TensorFlow Object Detection API进行迁移学习训练自己的人脸检测模型(二)

    前言 已完成数据预处理工作,具体参照: 基于TensorFlow Object Detection API进行迁移学习训练自己的人脸检测模型(一) 设置配置文件 新建目录face_faster_rcn ...

  5. OpenCV + python 实现人脸检测(基于照片和视频进行检测)

    OpenCV + python 实现人脸检测(基于照片和视频进行检测) Haar-like 通俗的来讲,就是作为人脸特征即可. Haar特征值反映了图像的灰度变化情况.例如:脸部的一些特征能由矩形特征 ...

  6. opencv 美白磨皮人脸检测<转>

    1. 简介 这学期的计算机视觉课,我们组的课程项目为“照片自动美化”,其中我负责的模块为人脸检测与自动磨皮.功能为:用户上传一张照片,自动检测并定位出照片中的人脸,将照片中所有的人脸进行“磨皮”处理, ...

  7. Android 中使用 dlib+opencv 实现动态人脸检测

    1 概述 完成 Android 相机预览功能以后,在此基础上我使用 dlib 与 opencv 库做了一个关于人脸检测的 demo.该 demo 在相机预览过程中对人脸进行实时检测,并将检测到的人脸用 ...

  8. Android—基于OpenCV+Android实现人脸检测

    导读 OpenCV 是一个开源的跨平台计算机视觉库, 采C++语言编写,实现了图像处理和计算机视觉方面的很多通用算法,同时也提供对Python,Java,Android等的支持,这里利用Android ...

  9. Python学习案例之视频人脸检测识别

    前言 上一篇博文与大家分享了简单的图片人脸识别技术,其实在实际应用中,很多是通过视频流的方式进行识别,比如人脸识别通道门禁考勤系统.人脸动态跟踪识别系统等等. 案例 这里我们还是使用 opencv 中 ...

随机推荐

  1. NOIP 2012 Day2T2 借教室题解

    NOIP 2012 Day2T2 借教室题解 题目传送门:http://codevs.cn/problem/1217/ 题目描述 Description 在大学期间,经常需要租借教室.大到院系举办活动 ...

  2. HDU 4749 Parade Show(贪心+kmp)

    题目链接 题目都看不懂,做毛线...看懂了之后就是kmp出,所有的匹配区间,然后DP可以写,贪心也可以做把,DP应该需要优化一下,直接贪,也应该对的,经典贪心问题. #include<iostr ...

  3. 两种不同png图片的在项目中的运用

    png图片主要分为两种 png-8和png-24. PNG8和PNG24后面的数字则是代表这种PNG格式最多可以索引和存储的颜色值.”8″代表2的8次方也就是256色,而24则代表2的24次方大概有1 ...

  4. 自定义plain 样式的 tableview,模拟器上不显示分割线,真机上却显示分割线.

    一, 经历 1> 自定义plain 样式的 tableview,模拟器上不显示分割线,真机上却显示cell 下面的分割线. 2> 尝试使用表格的separatorStyle属性,尝试失败. ...

  5. Infragistics公司的UltraWebGrid控件在显示的时候报“theForm” 未定义错误的解决。

    在项目中使用了Infragistics公司的UltraWebGrid控件,浏览器中报错,“theForm” 未定义,并且造成客户端js,滚动条,失效.最后查官网论坛找到问题.需要把web.config ...

  6. 基于SVG的JS地图插件

    一:D3(Data-Driven Documents) 官网地址:http://d3js.org/ 功能非常强大(不支持IE8) D3 是最流行的可视化库之一,它被很多其他的表格插件所使用.它允许绑定 ...

  7. C#中WinForm程序退出方法技巧总结(转)

    本文实例总结了C#中WinForm程序退出方法技巧.分享给大家供大家参考.具体分析如下: 在c#中退出WinForm程序包括有很多方法,如:this.Close(); Application.Exit ...

  8. Base64编码简介

      基本概念   Base64这个术语最初是在“MIME内容传输编码规范”中提出的.Base64不是一种加密算法,虽然编码后的字符串看起来有点加密的赶脚.它实际上是一种“二进制到文本”的编码方法,它能 ...

  9. [zt]Singleton和Double-Checked Locking设计模式—UML图及代码实现

    Singleton和Double-Checked Locking设计模式,分别指的是单例模式和双重检查锁模式,它们都可以用于确保某个类只有一个对象实例化. 两个模式的区别在于:Singleton模式用 ...

  10. IO字 节流/字符流 读取/写入文件

    流是指一连串流动的数据信号,以先进,先出的方式发送和接收的通道 流的分类根据方向分为输入流所有接收,获得,读取的操作都是属于输入流所有的输入流名字都带有input或Reader 输出流所有发送,写的操 ...