亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

凌海市| 阳江市| 托克托县| 湄潭县| 天等县| 尤溪县| 凌源市| 罗山县| 岗巴县| 四子王旗| 峨眉山市| 洮南市| 云林县| 太原市| 云安县| 东兰县| 凯里市| 晴隆县| 营山县| 崇州市| 三亚市| 花垣县| 安溪县| 新和县| 邻水| 德兴市| 运城市| 阜平县| 弥渡县| 延津县| 星座| 达州市| 宁海县| 吴堡县| 浮梁县| 德江县| 九龙城区| 保康县| 墨玉县| 交口县| 金乡县|