最全【OpenCV】 人脸识别_opencv人脸识别(1),2024年最新4年小C C++的心路历程

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

    //调用级联分类器进行模型匹配并进行框选识别 使用模型去进行每一个像素点的遍历
    vector<Rect>faces;
    //使用CV_HAAR_SCALE_IMAGE算法 图像甄别
    cascade.detectMultiScale(smalling,faces,1.1,2,0|CV_HAAR_SCALE_IMAGE,Size(30,30));

    //绘制矩形
    vector<Rect>::const_iterator iter;
    //使用到容器迭代器进行遍历
    for(iter=faces.begin();iter!=faces.end();iter++)
    {
        rectangle(frame,
                  cvPoint(cvRound(iter->x*scale),cvRound(iter->y*scale)),//左上
                  cvPoint(cvRound((iter->x+iter->width)*scale),cvRound((iter->y+iter->height)*scale)),//右下
                  Scalar(0,255,0),2,8//颜色 像素位
                    );
    }
    imshow("frame",frame);

人脸识别案例 源码分享

#include <iostream>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;

//人脸识别
void datectFace(Mat &frame,CascadeClassifier cascade,double scale)
{
    //灰度化处理 节省内存
    Mat gray;
    cvtColor(frame,gray,CV_RGB2GRAY);

    //级联分类器比帧差法还更慢,因此,需要再将灰度图大小压缩一半左右 行列压缩
    Mat smalling(cvRound(frame.rows/scale),cvRound(frame.cols/scale),CV_8UC1);
    //按存储大小计算  压缩方式采用线性压缩
    resize(gray,smalling,smalling.size(),0,0,INTER_LINEAR);

    //直方图均值化 让灰度图经过直方图函数处理 黑白分明
    equalizeHist(smalling,smalling);
    //imshow("smalling",smalling);

    //调用级联分类器进行模型匹配并进行框选识别 使用模型去进行每一个像素点的遍历
    vector<Rect>faces;
    //使用CV_HAAR_SCALE_IMAGE算法 图像甄别
    cascade.detectMultiScale(smalling,faces,1.1,2,0|CV_HAAR_SCALE_IMAGE,Size(30,30));

    //绘制矩形
    vector<Rect>::const_iterator iter;
    //使用到容器迭代器进行遍历
    for(iter=faces.begin();iter!=faces.end();iter++)
    {
        rectangle(frame,
                  cvPoint(cvRound(iter->x*scale),cvRound(iter->y*scale)),//左上
                  cvPoint(cvRound((iter->x+iter->width)*scale),cvRound((iter->y+iter->height)*scale)),//右下
                  Scalar(0,255,0),2,8//颜色 像素位
                    );
    }
    imshow("frame",frame);
}

int main(int argc, char *argv[])
{
    //级联分类器对象
    CascadeClassifier cascade;
    //读取级联分类器
    cascade.load("D:/00000cars-face/face.xml");

    Mat frame;
    //视频路径的获取
    VideoCapture cap(0);
    while (cap.read(frame))
    {
        //将读到的帧进行显示
        imshow("frame",frame);
        //检测识别 图像 级联分类器 比例
        datectFace(frame,cascade,2);
        waitKey(3);
    }
    return 0;
}

结果测试:可对人脸框选识别

三:车辆识别案例 级联分类器 具体实现

如果对于上述的人脸识别案例 理解透彻 那么车辆识别也是一样的实现方法 只不过就是换了一个级联分类器 图像数据读取 罢了。

这边就直接给出 车辆识别案例 完整代码

#include <iostream>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;

//车辆识别案例
void datectCarDaw(Mat &frame,CascadeClassifier cascade,double scale)
{
    //灰度化处理 节省内存
    Mat gray;
    cvtColor(frame,gray,CV_RGB2GRAY);

    //级联分类器比帧差法还更慢,因此,需要再将灰度图大小压缩一半左右 行列压缩
    Mat smalling(cvRound(frame.rows/scale),cvRound(frame.cols/scale),CV_8UC1);
    //按存储大小计算  压缩方式采用线性压缩
    resize(gray,smalling,smalling.size(),0,0,INTER_LINEAR);

    //直方图均值化 让灰度图经过直方图函数处理 黑白分明
    equalizeHist(smalling,smalling);
    //imshow("smalling",smalling);

    //调用级联分类器进行模型匹配并进行框选识别 使用模型去进行每一个像素点的遍历
    vector<Rect>cars;
    //使用CV_HAAR_SCALE_IMAGE算法 图像甄别
    cascade.detectMultiScale(smalling,cars,1.1,2,0|CV_HAAR_SCALE_IMAGE,Size(30,30));

    //绘制矩形
    vector<Rect>::const_iterator iter;
    //使用到容器迭代器进行遍历
    for(iter=cars.begin();iter!=cars.end();iter++)
    {
        rectangle(frame,
                  cvPoint(cvRound(iter->x*scale),cvRound(iter->y*scale)),//左上
                  cvPoint(cvRound((iter->x+iter->width)*scale),cvRound((iter->y+iter->height)*scale)),//右下
                  Scalar(0,255,0),2,8//颜色 像素位
                    );
    }
    imshow("frame",frame);
}

int main(int argc, char *argv[])
{
    //级联分类器对象
    CascadeClassifier cascade;
    //读取级联分类器
    cascade.load("D:/00000cars-face/cars.xml");

    Mat frame;
    //视频路径的获取
    VideoCapture cap("D:/00000000000003jieduanshipincailliao/carMove.mp4");
    while (cap.read(frame))
    {
        //将读到的帧进行显示
        imshow("frame",frame);
        //检测识别 图像 级联分类器 比例
        datectCarDaw(frame,cascade,2);
        waitKey(3);
    }
    return 0;
}

结果测试:

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值