opencv 人脸识别 (一)训练样本的处理

               

本文实现基于eigenface的人脸检测与识别。给定一个图像数据库,进行以下步骤:

  • 进行人脸检测,将检测出的人脸存入数据库2
  • 对数据库2进行人脸建模
  • 在测试集上进行recognition

本篇实现第一步:
  • 进行人脸检测,将检测出的人脸存入数据库2


环境:vs2010+opencv 2.4.6.0

特征:eigenface

Input:一个人脸数据库,15个人,每人20个样本(左右)。

Output:人脸检测,并识别出每张检测到的人脸。

===============================


本文完成第一步,数据预处理:自动检测所有文件夹中每个sample中的人脸,作为训练数据。

Input:一个color文件夹,每个文件夹中有1~N这N个子文件夹,每个子文件夹内有n张包括第n类人的照片,如图。




最终结果:


核心:face detection(detectAndDraw)

辅助:截图并保存部分图片(CutImg),文件夹内图片遍历(read_img),图片转换成相同大小(normalizeone)

括号内分别是函数名,下面分别给出代码及说明。


1. 遍历文件夹:CBrowseDir类和CStatDir类(具体见这篇),三个文件如下:

1.1 BrowseDir.h

#pragma once#include "direct.h"#include "string.h"#include "io.h"#include "stdio.h" #include <vector>#include <iostream>using namespace std;class CBrowseDir{
    protectedchar m_szInitDir[_MAX_PATH];public: CBrowseDir(); bool SetInitDir(const char *dir)bool BeginBrowse(const char *filespec)vector<char*> BeginBrowseFilenames(const char *filespec);protectedbool BrowseDir(const char *dir,const char *filespec)vector<char*> GetDirFilenames(const char *dir,const char *filespec); virtual bool ProcessFile(const char *filename)virtual void ProcessDir(const char *currentdir,const char *parentdir);};


1.2 BrowseDir.cpp

#include "BrowseDir.h"#include "direct.h"#include "string.h"#include "io.h"#include "stdio.h" #include <vector>#include <iostream>using namespace std;CBrowseDir::CBrowseDir(){ getcwd(m_szInitDir,_MAX_PATH); int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\')  strcat(m_szInitDir,"\\");}bool CBrowseDir::SetInitDir(const char *dir){ if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL)  return falseif (_chdir(m_szInitDir) != 0)  return falseint len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\')  strcat(m_szInitDir,"\\"); return true;}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值