0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何使用質(zhì)心法進(jìn)行目標(biāo)追蹤--文末送書(shū)

OpenCV學(xué)堂 ? 來(lái)源:OpenCV學(xué)堂 ? 2023-10-31 15:47 ? 次閱讀

如今,“圖像分類”、“目標(biāo)檢測(cè)”、“語(yǔ)義分割”、“實(shí)例分割”和“目標(biāo)追蹤”等5大領(lǐng)域是計(jì)算機(jī)視覺(jué)的熱門(mén)應(yīng)用。其中“圖像分類”與“目標(biāo)檢測(cè)”是最基礎(chǔ)的應(yīng)用,在此基礎(chǔ)上,派生出了“語(yǔ)義分割”、“實(shí)例分割”和“目標(biāo)跟蹤”等相對(duì)高級(jí)的應(yīng)用。

、基于目標(biāo)檢測(cè)的追蹤概述

基于目標(biāo)檢測(cè)的目標(biāo)追蹤方法(Tracking By Detecting,簡(jiǎn)稱TBD)一般使用目標(biāo)檢測(cè)模型(如YOLO),在每個(gè)視頻幀上進(jìn)行目標(biāo)檢測(cè),然后將檢測(cè)出來(lái)的目標(biāo)進(jìn)行關(guān)聯(lián),找到每個(gè)目標(biāo)的運(yùn)行軌跡。如圖1所示,先使用目標(biāo)檢測(cè)模型檢測(cè)出7個(gè)目標(biāo),然后通過(guò)算法,將5b7dfc4c-77c1-11ee-939d-92fbcf53809c.png5b91784e-77c1-11ee-939d-92fbcf53809c.png進(jìn)行關(guān)聯(lián),從而追蹤到這兩個(gè)足球的運(yùn)行軌跡。

5b9d6492-77c1-11ee-939d-92fbcf53809c.png

1基于目標(biāo)檢測(cè)的目標(biāo)追蹤方法

TBD方法完整的流程如圖2所示,該方法共有5個(gè)步驟,其中最關(guān)鍵的是“目標(biāo)檢測(cè)”和“目標(biāo)關(guān)聯(lián)”兩個(gè)步驟,“目標(biāo)檢測(cè)”需要一個(gè)訓(xùn)練好的目標(biāo)檢測(cè)模型,用來(lái)發(fā)現(xiàn)圖像中的各個(gè)目標(biāo),“目標(biāo)關(guān)聯(lián)”需要一個(gè)關(guān)聯(lián)算法,用來(lái)進(jìn)行目標(biāo)的配對(duì)。

(1)目標(biāo)檢測(cè),檢測(cè)出要追蹤目標(biāo)的位置坐標(biāo)、目標(biāo)分類等信息,初始化每個(gè)目標(biāo)的軌跡。

2)目標(biāo)關(guān)聯(lián),使用算法,給當(dāng)前幀中的目標(biāo)和前一幀的目標(biāo)進(jìn)行配對(duì)。

3)關(guān)聯(lián)成功,在上一幀中找到了當(dāng)前幀中檢測(cè)到的目標(biāo),配對(duì)成功,記錄目標(biāo)的軌跡。

4)新出現(xiàn)目標(biāo),在上一幀中沒(méi)有找到當(dāng)前幀中檢測(cè)到的目標(biāo),初始化新目標(biāo)的軌跡。

5)目標(biāo)消失,在當(dāng)前幀中沒(méi)有找到上一幀中檢測(cè)出來(lái)的目標(biāo),刪除該目標(biāo)的軌跡。

5bae60b2-77c1-11ee-939d-92fbcf53809c.png

2 基于目標(biāo)檢測(cè)的目標(biāo)追蹤方法(TBD)流程圖

在基于目標(biāo)檢測(cè)的目標(biāo)追蹤方法中,為了實(shí)現(xiàn)目標(biāo)的關(guān)聯(lián),容易想到的方法是“通過(guò)目標(biāo)識(shí)別進(jìn)行目標(biāo)關(guān)聯(lián)”:對(duì)每一幀圖像進(jìn)行目標(biāo)檢測(cè),然后對(duì)每一個(gè)目標(biāo)提取特征,通過(guò)特征識(shí)別出每一個(gè)目標(biāo),從而實(shí)現(xiàn)目標(biāo)關(guān)聯(lián)。

但是,“通過(guò)目標(biāo)識(shí)別進(jìn)行目標(biāo)關(guān)聯(lián)”需要在每一幀圖像中,提取出每一個(gè)目標(biāo)的特征,這需要大量的計(jì)算資源,同時(shí)還需要穩(wěn)定的特征提取器,在實(shí)際場(chǎng)景中很難做到,因此,通常采用其他方法進(jìn)行目標(biāo)的關(guān)聯(lián),如常用的質(zhì)心法。

二、使用質(zhì)心法進(jìn)行目標(biāo)關(guān)聯(lián)

質(zhì)心法是一種基于目標(biāo)檢測(cè)的目標(biāo)追蹤方法,只在目標(biāo)首次出現(xiàn)的時(shí)候,對(duì)目標(biāo)進(jìn)行識(shí)別,在后續(xù)的視頻幀中,通過(guò)歐氏距離將檢測(cè)到的目標(biāo)進(jìn)行關(guān)聯(lián),如圖3所示。

1)目標(biāo)檢測(cè),使用深度學(xué)習(xí)模型,對(duì)視頻幀進(jìn)行目標(biāo)檢測(cè)。

2)計(jì)算質(zhì)心坐標(biāo),使用目標(biāo)預(yù)測(cè)框的中心點(diǎn)作為質(zhì)心坐標(biāo)。

3)計(jì)算質(zhì)心距離,計(jì)算視頻的上一幀和當(dāng)前幀中目標(biāo)之間的歐式距離。

4)目標(biāo)關(guān)聯(lián),距離相近的為同一目標(biāo),如AC是同一目標(biāo),B是新出現(xiàn)目標(biāo)。

(5)目標(biāo)更新,更新已知目標(biāo)的坐標(biāo),生成新目標(biāo)ID,如果有目標(biāo)消失,則注銷(xiāo)消失目標(biāo)ID。

5bb8f0fe-77c1-11ee-939d-92fbcf53809c.png

3 使用質(zhì)心法實(shí)現(xiàn)目標(biāo)關(guān)聯(lián)

三、質(zhì)心法使用示例

質(zhì)心法是目標(biāo)關(guān)聯(lián)算法,在進(jìn)行目標(biāo)追蹤時(shí),還需要配合目標(biāo)檢測(cè)模型使用,下面代碼使用YOLO模型進(jìn)行目標(biāo)檢測(cè)(已經(jīng)在coco數(shù)據(jù)集上訓(xùn)練好的YOLO模型),使用質(zhì)心法進(jìn)行目標(biāo)關(guān)聯(lián),實(shí)現(xiàn)目標(biāo)的追蹤。

在以下代碼中,詳細(xì)介紹了兩幀圖像中的目標(biāo)(足球)的追蹤過(guò)程,在本書(shū)配套的源代碼中,還演示了對(duì)視頻中的目標(biāo)進(jìn)行追蹤的方法。

(1)導(dǎo)入庫(kù)用到的庫(kù)(在配套代碼目錄下的yolo_detect.py文件里,封裝了YOLO模型的使用)

1 import cv2,math
  2 import numpy as np
  3 import IPython.display as display
  4 from yolo_detect import Init_Yolo,Detect,Draw #封裝YOLO模型的檢測(cè)操作
  5 from matplotlib import pyplot as plt
  6 plt.rcParams['font.sans-serif']=['SimHei'] #在統(tǒng)計(jì)圖上顯示中文

2)初始化YOLO模型(模型的初始化方法請(qǐng)查看yolo_detect.py文件中的Init_Yolo函數(shù))。

1 model,labels = Init_Yolo('./models/yolov3-tiny.cfg',
  2                          './models/yolov3-tiny.weights',
3'./models/coco.names')

(3)讀取兩幀圖像,并轉(zhuǎn)換為RGB格式,其中frame_1是上一幀圖像,frame_2是當(dāng)前幀圖像。

 1 frame_1 = cv2.imread('./images/ball_1.png')
  2 frame_1 = cv2.cvtColor(frame_1, cv2.COLOR_BGR2RGB)
  3 frame_2 = cv2.imread('./images/ball_2.png')
4frame_2=cv2.cvtColor(frame_2,cv2.COLOR_BGR2RGB)

4)檢測(cè)兩幀圖像中的足球目標(biāo)(調(diào)用yolo_detect.py文件中的Detect函數(shù))。

1 #使用YOLO檢測(cè)兩幀圖像中的目標(biāo)
  2 b1 = Detect(model,labels,frame_1)
  3 b2 = Detect(model,labels,frame_2)
  4 #只保留足球的檢測(cè)結(jié)果
  5 filter=np.where(b1[:,-1]=='sports ball')
  6 bbox1 = b1[filter]
  7 filter=np.where(b2[:,-1]=='sports ball')
8bbox2=b2[filter]

(5)計(jì)算質(zhì)心坐標(biāo),根據(jù)第4步檢測(cè)結(jié)果bbox1和bbox2,計(jì)算目標(biāo)的質(zhì)心(即綁定框的中心)。

1 A = (int(bbox1[0][0])+int(bbox1[0][2])/2,int(bbox1[0][1])+int(bbox1[0][3])/2)
  2 B = (int(bbox2[0][0])+int(bbox2[0][2])/2,int(bbox2[0][1])+int(bbox2[0][3])/2)
  3 C = (int(bbox2[1][0])+int(bbox2[1][2])/2,int(bbox2[1][1])+int(bbox2[1][3])/2)
4print("第一幀目標(biāo)A",A,"第二幀目標(biāo)B",B,"第二幀目標(biāo)C",C)

使用第4和第5步代碼,在第一幀圖像中檢測(cè)到目標(biāo)A,在第二幀圖像中檢測(cè)到目標(biāo)BC,并分別計(jì)算這3個(gè)目標(biāo)的質(zhì)心。如圖4所示,圖中白色邊框?yàn)闄z測(cè)到的目標(biāo)邊界框,中間的綠點(diǎn)為目標(biāo)的質(zhì)心(即邊界框的中心)。

5bca9980-77c1-11ee-939d-92fbcf53809c.png

4 檢測(cè)到的目標(biāo)與質(zhì)心

6)計(jì)算第一幀中的目標(biāo)和后一幀中目標(biāo)的歐氏距離,根據(jù)最近距離,確定AB是同一目標(biāo)。

 1 AB = math.sqrt(math.pow((A[0]-B[0]),2)+math.pow((A[1]-B[1]),2))
  2 AC = math.sqrt(math.pow((A[0]-C[0]),2)+math.pow((A[1]-C[1]),2))
3print("AB距離",AB,"AC距離",AC,"AB是同一目標(biāo)")

(7)顯示追蹤的結(jié)果,將兩幀圖像合并到一起,用連線表示目標(biāo)的運(yùn)行軌跡,如圖5所示。

 1 mask1 = Draw(frame_1,bbox1)  #繪制在第一幀中檢測(cè)到的目標(biāo)
  2 mask2 = Draw(frame_2,bbox2)  #繪制在第二幀中檢測(cè)到的目標(biāo)
  3 all_img = np.hstack((mask1, mask2)) #將兩幀圖像合并成一幅圖像
  4 #繪制運(yùn)動(dòng)軌跡
  5 H,W = mask1.shape[:2]
  6 cv2.line(all_img,(int(A[0]),int(A[1])),(W+int(C[0]),int(C[1])),(0,255,255),2)
  7 ##顯示追蹤結(jié)果
  8 plt.title('目標(biāo)運(yùn)行軌跡')
9plt.imshow(all_img)

5bd94f5c-77c1-11ee-939d-92fbcf53809c.png

5目標(biāo)的運(yùn)行軌跡


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 模型
    +關(guān)注

    關(guān)注

    1

    文章

    3283

    瀏覽量

    49001
  • 圖像分類
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    11944
  • 目標(biāo)檢測(cè)
    +關(guān)注

    關(guān)注

    0

    文章

    210

    瀏覽量

    15643

原文標(biāo)題:如何使用質(zhì)心法進(jìn)行目標(biāo)追蹤--文末送書(shū)

文章出處:【微信號(hào):CVSCHOOL,微信公眾號(hào):OpenCV學(xué)堂】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    【11月狂歡】PCB充值即現(xiàn)金券,充多多,上不封項(xiàng)!

    為回饋廣大客戶對(duì)華秋的厚愛(ài)2024年11月特惠狂歡火熱開(kāi)啟~PCB充值即現(xiàn)金券!充多多,福利加倍!充值1萬(wàn)元,即300元現(xiàn)金券,相當(dāng)于返3個(gè)點(diǎn)充值3萬(wàn)元,即1200元現(xiàn)金券,相
    的頭像 發(fā)表于 11-08 01:02 ?269次閱讀
    【11月狂歡】PCB充值即<b class='flag-5'>送</b>現(xiàn)金券,充多<b class='flag-5'>送</b>多,上不封項(xiàng)!

    基于光線追蹤的渲染算法實(shí)現(xiàn)

    我們已經(jīng)涵蓋了所有需要說(shuō)的內(nèi)容!我們現(xiàn)在準(zhǔn)備寫(xiě)我們的第一個(gè)光線追蹤器。你現(xiàn)在應(yīng)該能夠猜到光線追蹤算法是如何工作的了。首先,注意到自然界中光的傳播只是從光源發(fā)出無(wú)數(shù)條射線,反彈直到它們撞到我們眼睛的表面。因此,光線追蹤是優(yōu)雅的,因
    的頭像 發(fā)表于 10-30 08:06 ?284次閱讀
    基于光線<b class='flag-5'>追蹤</b>的渲染算法實(shí)現(xiàn)

    鐳神智能激光雷達(dá)低空無(wú)人機(jī)目標(biāo)追蹤光電系統(tǒng):筑牢機(jī)場(chǎng)低空安防屏障

    近日,天津?yàn)I海機(jī)場(chǎng)遭遇無(wú)人機(jī)干擾,導(dǎo)致航班大面積無(wú)法起降,引發(fā)廣泛關(guān)注。這一事件再次凸顯了低空安防領(lǐng)域的重要性,以及高效、精準(zhǔn)的監(jiān)控系統(tǒng)對(duì)于保障航空安全的必要性。鐳神智能推出的激光雷達(dá)低空目標(biāo)追蹤
    的頭像 發(fā)表于 10-01 08:07 ?483次閱讀
    鐳神智能激光雷達(dá)低空無(wú)人機(jī)<b class='flag-5'>目標(biāo)</b><b class='flag-5'>追蹤</b>光電系統(tǒng):筑牢機(jī)場(chǎng)低空安防屏障

    無(wú)線定位器追蹤器跟手機(jī)怎么連接

    無(wú)線定位器追蹤器與手機(jī)的連接方法主要取決于追蹤器的類型和功能。以下是一些常見(jiàn)的連接方式: 一、藍(lán)牙連接 確保兼容性 :首先,確保你的定位器追蹤器支持藍(lán)牙功能,并且手機(jī)的藍(lán)牙也已開(kāi)啟。 進(jìn)行
    的頭像 發(fā)表于 09-29 10:01 ?2w次閱讀

    NVIDIA多攝像頭追蹤工作流的應(yīng)用架構(gòu)

    為提高安全性并優(yōu)化運(yùn)營(yíng),倉(cāng)庫(kù)、工廠、體育場(chǎng)、機(jī)場(chǎng)等大型區(qū)域通常會(huì)有數(shù)百個(gè)攝像頭進(jìn)行監(jiān)控。多攝像頭追蹤指的是通過(guò)這些攝像頭追蹤對(duì)象,并精確測(cè)量其活動(dòng),以此實(shí)現(xiàn)對(duì)空間的有效監(jiān)控和管理。
    的頭像 發(fā)表于 09-06 14:23 ?377次閱讀
    NVIDIA多攝像頭<b class='flag-5'>追蹤</b>工作流的應(yīng)用架構(gòu)

    如何遠(yuǎn)離網(wǎng)絡(luò)追蹤

    ?隨著科技不斷發(fā)展,生活、工作等都離不開(kāi)網(wǎng)絡(luò)。但網(wǎng)絡(luò)追蹤技術(shù)也隨著科技的進(jìn)步不斷發(fā)展,人們?cè)诰W(wǎng)絡(luò)上的在線活動(dòng)越來(lái)越容易被追蹤和監(jiān)控。這會(huì)威脅到個(gè)人隱私、信息泄露、身份盜竊等嚴(yán)重后果。所以,今天我想
    的頭像 發(fā)表于 09-03 16:57 ?495次閱讀
    如何遠(yuǎn)離網(wǎng)絡(luò)<b class='flag-5'>追蹤</b>

    基于迅為RK3588【RKNPU2項(xiàng)目實(shí)戰(zhàn)1】:YOLOV5實(shí)時(shí)目標(biāo)分類

    [/url] 【RKNPU2 人工智能開(kāi)發(fā)】 【AI深度學(xué)習(xí)推理加速器】——RKNPU2 從入門(mén)到實(shí)踐(基于RK3588和RK3568) 【RKNPU2項(xiàng)目實(shí)戰(zhàn)1】:YOLOV5實(shí)時(shí)目標(biāo)分類 【RKNPU2項(xiàng)目實(shí)戰(zhàn)2】:SORT目標(biāo)追蹤
    發(fā)表于 08-15 10:51

    迅為RK3588開(kāi)發(fā)板RKNPU2項(xiàng)目實(shí)戰(zhàn)2SORT目標(biāo)追蹤

    1.介紹和視頻演示 2.在模擬器實(shí)現(xiàn)圖片的目標(biāo)追蹤 3.連板推理和嵌入式部署 4.視頻目標(biāo)追蹤的實(shí)現(xiàn)(python) 5.C++實(shí)現(xiàn)目標(biāo)
    發(fā)表于 07-10 11:08

    如何使用CAN盒測(cè)出目標(biāo)CAN設(shè)備的波特率

    要使用CAN盒測(cè)出目標(biāo)CAN設(shè)備的波特率,可以按照以下步驟進(jìn)行: (1)硬件準(zhǔn)備: 準(zhǔn)備一個(gè)與目標(biāo)CAN設(shè)備兼容的CAN盒。 確保CAN盒的接口與目標(biāo)CAN設(shè)備的CAN通信接口相匹配,
    的頭像 發(fā)表于 06-26 16:41 ?824次閱讀

    激光焊接機(jī):生產(chǎn)中絲機(jī)卡絲該如何解決?

    激光焊接機(jī)在現(xiàn)代化的生產(chǎn)加工中扮演著至關(guān)重要的角色,然而,當(dāng)絲機(jī)出現(xiàn)卡絲故障時(shí),不僅會(huì)影響生產(chǎn)效率,還可能對(duì)產(chǎn)品質(zhì)量造成嚴(yán)重影響。為了解決這個(gè)問(wèn)題,我們需要從多個(gè)角度進(jìn)行分析和處理。以下是紫宸激光
    的頭像 發(fā)表于 05-07 10:53 ?813次閱讀
    激光焊接機(jī):生產(chǎn)中<b class='flag-5'>送</b>絲機(jī)卡絲該如何解決?

    卡爾曼濾波是什么 卡爾曼濾波與目標(biāo)追蹤技術(shù)分析

    卡爾曼濾波以及其擴(kuò)展算法能夠應(yīng)用于目標(biāo)狀態(tài)估計(jì),如果這個(gè)目標(biāo)是行人,那么就是行人狀態(tài)估計(jì)(或者說(shuō)行人追蹤),如果這個(gè)目標(biāo)是自身,那么就是車(chē)輛自身的
    的頭像 發(fā)表于 04-29 09:46 ?1236次閱讀
    卡爾曼濾波是什么 卡爾曼濾波與<b class='flag-5'>目標(biāo)</b><b class='flag-5'>追蹤</b>技術(shù)分析

    追蹤跳線都用哪些場(chǎng)景

    鷹眼追蹤跳線是一種用于機(jī)房管理的工具,可以查詢銅纜和光纜(包括超五類、六類、超六類屏蔽/非屏蔽,單模/多模光纖等)。其應(yīng)用場(chǎng)景包括但不限于: 機(jī)房管理:機(jī)房是網(wǎng)絡(luò)設(shè)備的核心區(qū)域,鷹眼追蹤跳線可用
    的頭像 發(fā)表于 03-21 10:03 ?453次閱讀

    手持激光焊接機(jī)帶絲的價(jià)格是多少?

    標(biāo)題:《手持激光焊接機(jī)帶絲的價(jià)格是多少?》 手持激光焊接機(jī)是一種高效、便捷的焊接設(shè)備,廣泛應(yīng)用于金屬加工、汽車(chē)制造、航空航天、電子電器等領(lǐng)域。帶絲功能的手持激光焊接機(jī)可以實(shí)現(xiàn)自動(dòng)絲,提高焊接
    的頭像 發(fā)表于 03-06 11:54 ?598次閱讀
    手持激光焊接機(jī)帶<b class='flag-5'>送</b>絲的價(jià)格是多少?

    手持激光焊接機(jī)絲機(jī)不自動(dòng)絲?不妨試試這幾個(gè)方法

    標(biāo)題:《手持激光焊接機(jī)絲機(jī)不自動(dòng)絲怎么辦?》 手持激光焊接機(jī)絲機(jī)是激光焊接機(jī)的重要組成部分,它的作用是將焊絲自動(dòng)送給焊接部位,以保證焊接的連續(xù)性和穩(wěn)定性。然而,在使用手持激光焊接機(jī)
    的頭像 發(fā)表于 03-06 11:50 ?1642次閱讀
    手持激光焊接機(jī)<b class='flag-5'>送</b>絲機(jī)不自動(dòng)<b class='flag-5'>送</b>絲?不妨試試這幾個(gè)方法

    在ELF 1 開(kāi)發(fā)板上實(shí)現(xiàn)讀取攝像頭視頻進(jìn)行目標(biāo)檢測(cè)

    當(dāng)前,將AI或深度學(xué)習(xí)算法(如分類、目標(biāo)檢測(cè)和軌跡追蹤)部署到嵌入式設(shè)備,進(jìn)而實(shí)現(xiàn)邊緣計(jì)算,正成為輕量級(jí)深度學(xué)習(xí)算法發(fā)展的一個(gè)重要趨勢(shì)。今天將與各位小伙伴分享一個(gè)實(shí)際案例:在ELF1開(kāi)發(fā)板上成功部署
    的頭像 發(fā)表于 01-24 10:38 ?737次閱讀
    在ELF 1 開(kāi)發(fā)板上實(shí)現(xiàn)讀取攝像頭視頻<b class='flag-5'>進(jìn)行</b><b class='flag-5'>目標(biāo)</b>檢測(cè)