91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python基于HOG+SVM/RF/DT等模型怎么實現目標人行檢測功能

發布時間:2022-06-02 12:38:53 來源:億速云 閱讀:338 作者:iii 欄目:開發技術

本篇內容主要講解“Python基于HOG+SVM/RF/DT等模型怎么實現目標人行檢測功能”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Python基于HOG+SVM/RF/DT等模型怎么實現目標人行檢測功能”吧!

首先看下數據集,數據集主要分為兩個類別,一個類別是包含行人的,另一個類別是不包含行人的,首先看下不包含行人的:

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等模型怎么實現目標人行檢測功能”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

莫力| 绵竹市| 合作市| 瓦房店市| 离岛区| 交城县| 利川市| 银川市| 无锡市| 阿巴嘎旗| 漯河市| 荣昌县| 云南省| 迭部县| 石棉县| 滨海县| 恭城| 象山县| 元谋县| 屯留县| 鱼台县| 廊坊市| 义乌市| 宁津县| 潍坊市| 汶上县| 灌云县| 莆田市| 信阳市| 始兴县| 祁门县| 庐江县| 健康| 六枝特区| 石门县| 孝感市| 浑源县| 防城港市| 星子县| 堆龙德庆县| 德惠市|