Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

作者:Together_CZ 时间:2021-07-12 01:54:50 

当下基本所有的目标检测类的任务都会选择基于深度学习的方式,诸如:YOLO、SSD、RCNN等等,这一领域不乏有很多出色的模型,而且还在持续地推陈出新,模型的迭代速度很快,其实最早实现检测的时候还是基于机器学习去做的,HOG+SVM就是非常经典有效的一套框架,今天这里并不是说要做出怎样的效果,而是基于HOG+SVM来实践机器学习检测的流程。

这里为了方便处理,我是从网上找的一个数据集,主要是行人检测方向的,当然了这个用车辆检测、火焰检测等等的数据集都是可以的,本质都是一样的。

首先看下数据集,数据集主要分为两个类别,一个类别是包含行人的,另一个类别是不包含行人的,首先看下不包含行人的:

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

接下来看下包含行人的:

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

看到这里,其实就不难理解,这里的SVM扮演的主要作用就是二分类模型了。

接下来我们需要对原始图像的数据集进行特征提取计算,这里是基于HOG的方式实现的,可以自行实现HOG特征向量提取方法,也可以直接使用skimage提供的HOG提取器来一步实现,这里为了方便,我是直接使用的skimage提供的HOG方法,核心实现如下:

def img2Feature(dataDir="data/",save_path="feature.json"):
   """
   特征提取计算
   """
   feature=[]
   for one_label in os.listdir(dataDir):
       print("one_label: ", one_label)
       oneDir=dataDir+one_label+'/'
       for one_pic in os.listdir(oneDir):
           one_path=oneDir+one_pic
           print("one_path: ", one_path)
           #加载图像
           one_img = imread(one_path, as_gray=True)
           one_vec = hog(one_img, orientations=orientations, pixels_per_cell=pixels_per_cell, cells_per_block=cells_per_block,
                       visualize=visualize, block_norm=normalize)
           one_vec=one_vec.tolist()
           one_vec.append(one_label)
           feature.append(one_vec)
   print("feature_length: ", len(feature))
   with open(save_path,"w") as f:
       f.write(json.dumps(feature))

HOG提取得到的向量维度很大,这里就不进行展示了。

之后就可以训练模型了,核心实现如下:

resDir = "results/"
if not os.path.exists(resDir):
   os.makedirs(resDir)
data = "feature.json"
dict1 = DTModel(data=data, rationum=0.25, model_path=resDir + "DT.model")
dict2 = RFModel(data=data, rationum=0.25, model_path=resDir + "RF.model")
dict3 = SVMModel(data=data, rationum=0.25, model_path=resDir + "SVM.model")
res_dict = {}
res_dict["DT"], res_dict["RF"], res_dict["SVM"] = dict1, dict2, dict3
with open(resDir + "res_dict.json", "w") as f:
   f.write(json.dumps(res_dict))
comparePloter(dict1, dict2, dict3, save_path=resDir + "comparePloter.jpg")

这里,我是同时使用了决策树DT、随机森林RF、支持向量机SVM三种模型来进行分类和对比可视化,对比结果如下:

{
"DT": {
"precision": 0.7573482282561567,
"recall": 0.7597846737437716,
"F1": 0.7584933696379963,
"accuracy": 0.7584933696379963
},
"RF": {
"precision": 0.9156160607479066,
"recall": 0.8801773928046967,
"F1": 0.893107332148193,
"accuracy": 0.893107332148193
},
"SVM": {
"precision": 0.9281402443868877,
"recall": 0.9272928963585789,
"F1": 0.9277128372009962,
"accuracy": 0.9277128372009962
}
}

为了直观展示,这里对三种模型的性能进行可视化展示,如下所示:

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

        接下来我们对训练好的模型调用进行测试,查看具体的效果,随机选取了几张网上的图像,测试结果如下:

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

Python基于HOG+SVM/RF/DT等模型实现目标人行检测功能

整体看下来,效果表现一般,不过这个也只是主要以实践流程为目的,并不是实际做项目的,而且各个环节都有优化提升的空间,模型的参数也都没有调过。

来源:https://blog.csdn.net/Together_CZ/article/details/125079040

标签:Python,目标检测,行人检测
0
投稿

猜你喜欢

  • Python2与Python3的区别点整理

    2022-02-23 07:44:46
  • ASP+JavaScript的完整的日历使用

    2008-10-11 12:16:00
  • 使用MHTML 解决 data URI scheme 的浏览器兼容问题

    2009-05-11 12:30:00
  • Python subprocess库的使用详解

    2021-10-25 04:59:32
  • AJAX在GET中文的时候解决乱码的方法

    2007-11-04 13:04:00
  • sql数据库批量处理脚本

    2011-11-03 17:23:19
  • SQLserver 数据库危险存储过程删除与恢复方法

    2011-09-30 11:33:54
  • python使用wxpy实现微信消息防撤回脚本

    2023-08-22 21:21:58
  • Gregarius中文日期格式问题解决办法

    2023-11-18 09:51:00
  • django解决跨域请求的问题

    2021-09-01 05:43:23
  • SQL Server用触发器强制执行业务规则

    2009-01-20 16:05:00
  • 高效的MySQL分页

    2011-01-04 20:01:00
  • rs.open sql,conn,1,1全接触

    2007-11-01 22:46:00
  • 如何批量消除网页超级链接上的“虚线框”

    2008-10-15 12:55:00
  • Python调用Tkinter示例浅析

    2022-04-30 02:53:32
  • 利用Python在一个文件的头部插入数据的实例

    2023-02-06 13:04:33
  • 利用XMLHTTP批量生成静态页的函数

    2008-09-10 11:07:00
  • Pycharm中import torch报错的快速解决方法

    2022-03-11 05:23:26
  • css布局自适应高度方法

    2007-05-11 17:03:00
  • 对python中xlsx,csv以及json文件的相互转化方法详解

    2021-01-28 23:24:34
  • asp之家 网络编程 m.aspxhome.com