OpenCV使用Yolov3進(jìn)行預(yù)測(cè)

源代碼來(lái)自小賽的文章儡遮,他的解釋更加詳細(xì)蹬挤,這里我做記錄用讶坯。

import numpyas np

import cv2as cv

import os

import time

yolo_dir ='/home/hessesummer/github/NTS-Net-my/yolov3'  # YOLO文件路徑

weightsPath = os.path.join(yolo_dir, 'yolov3.weights')# 權(quán)重文件

configPath = os.path.join(yolo_dir, 'yolov3.cfg')# 配置文件

labelsPath = os.path.join(yolo_dir, 'coco.names')# label名稱

imgPath = os.path.join(yolo_dir, 'test.jpg')# 測(cè)試圖像

CONFIDENCE =0.5  # 過濾弱檢測(cè)的最小概率

THRESHOLD =0.4  # 非最大值抑制閾值

# 加載網(wǎng)絡(luò)休建、配置權(quán)重

net = cv.dnn.readNetFromDarknet(configPath, weightsPath)# #  利用下載的文件

print("[INFO] loading YOLO from disk...")# # 可以打印下信息

# 加載圖片、轉(zhuǎn)為blob格式聚谁、送入網(wǎng)絡(luò)輸入層

img = cv.imread(imgPath)

blobImg = cv.dnn.blobFromImage(img, 1.0/255.0, (416, 416), None, True, False)# # net需要的輸入是blob格式的母剥,用blobFromImage這個(gè)函數(shù)來(lái)轉(zhuǎn)格式

net.setInput(blobImg)# # 調(diào)用setInput函數(shù)將圖片送入輸入層

# 獲取網(wǎng)絡(luò)輸出層信息(所有輸出層的名字),設(shè)定并前向傳播

outInfo = net.getUnconnectedOutLayersNames()# # 前面的yolov3架構(gòu)也講了形导,yolo在每個(gè)scale都有輸出环疼,outInfo是每個(gè)scale的名字信息,供net.forward使用

start = time.time()

layerOutputs = net.forward(outInfo)# 得到各個(gè)輸出層的骤宣、各個(gè)檢測(cè)框等信息秦爆,是二維結(jié)構(gòu)。

end = time.time()

print("[INFO] YOLO took {:.6f} seconds".format(end - start))# # 可以打印下信息

# 拿到圖片尺寸

(H, W) = img.shape[:2]

# 過濾layerOutputs

# layerOutputs的第1維的元素內(nèi)容: [center_x, center_y, width, height, objectness, N-class score data]

# 過濾后的結(jié)果放入:

boxes = []# 所有邊界框(各層結(jié)果放一起)

confidences = []# 所有置信度

classIDs = []# 所有分類ID

# # 1)過濾掉置信度低的框框

for outin layerOutputs:# 各個(gè)輸出層

    for detectionin out:# 各個(gè)框框

# 拿到置信度

        scores = detection[5:]# 各個(gè)類別的置信度

        classID = np.argmax(scores)# 最高置信度的id即為分類id

        confidence = scores[classID]# 拿到置信度

# 根據(jù)置信度篩查

        if confidence > CONFIDENCE:

box = detection[0:4] * np.array([W, H, W, H])# 將邊界框放會(huì)圖片尺寸

            (centerX, centerY, width, height) = box.astype("int")

x =int(centerX - (width /2))

y =int(centerY - (height /2))

boxes.append([x, y, int(width), int(height)])

confidences.append(float(confidence))

classIDs.append(classID)

# # 2)應(yīng)用非最大值抑制(non-maxima suppression憔披,nms)進(jìn)一步篩掉

idxs = cv.dnn.NMSBoxes(boxes, confidences, CONFIDENCE, THRESHOLD)# boxes中等限,保留的box的索引index存入idxs

# 得到labels列表

with open(labelsPath, 'rt')as f:

labels = f.read().rstrip('\n').split('\n')

# 應(yīng)用檢測(cè)結(jié)果

np.random.seed(42)

COLORS = np.random.randint(0, 255, size=(len(labels), 3), dtype="uint8")# 框框顯示顏色,每一類有不同的顏色芬膝,每種顏色都是由RGB三個(gè)值組成的望门,所以size為(len(labels), 3)

if len(idxs) >0:

for iin idxs.flatten():# indxs是二維的,第0維是輸出層锰霜,所以這里把它展平成1維

        (x, y) = (boxes[i][0], boxes[i][1])

(w, h) = (boxes[i][2], boxes[i][3])

color = [int(c)for cin COLORS[classIDs[i]]]

cv.rectangle(img, (x, y), (x+w, y+h), color, 2)# 線條粗細(xì)為2px

        text ="{}: {:.4f}".format(labels[classIDs[i]], confidences[i])

cv.putText(img, text, (x, y-5), cv.FONT_HERSHEY_SIMPLEX, 0.5, color, 2)# cv.FONT_HERSHEY_SIMPLEX字體風(fēng)格筹误、0.5字體大小、粗細(xì)2px

cv.imshow('detected image', img)

cv.waitKey(0)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末癣缅,一起剝皮案震驚了整個(gè)濱河市厨剪,隨后出現(xiàn)的幾起案子哄酝,更是在濱河造成了極大的恐慌,老刑警劉巖祷膳,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件陶衅,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡直晨,警方通過查閱死者的電腦和手機(jī)搀军,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)勇皇,“玉大人罩句,你說(shuō)我怎么就攤上這事×舱” “怎么了门烂?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)兄淫。 經(jīng)常有香客問我诅福,道長(zhǎng),這世上最難降的妖魔是什么拖叙? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮赂乐,結(jié)果婚禮上薯鳍,老公的妹妹穿的比我還像新娘。我一直安慰自己挨措,他們只是感情好挖滤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著浅役,像睡著了一般斩松。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上觉既,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天惧盹,我揣著相機(jī)與錄音,去河邊找鬼瞪讼。 笑死钧椰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的符欠。 我是一名探鬼主播嫡霞,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼希柿!你這毒婦竟也來(lái)了诊沪?” 一聲冷哼從身側(cè)響起养筒,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎端姚,沒想到半個(gè)月后晕粪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡寄锐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年兵多,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片橄仆。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡剩膘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出盆顾,到底是詐尸還是另有隱情怠褐,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布您宪,位于F島的核電站奈懒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏宪巨。R本人自食惡果不足惜磷杏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望捏卓。 院中可真熱鬧极祸,春花似錦、人聲如沸怠晴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蒜田。三九已至稿械,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間冲粤,已是汗流浹背美莫。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留色解,地道東北人茂嗓。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像科阎,于是被迫代替她去往敵國(guó)和親述吸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355