一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

稀疏光流跟蹤(KLT)算法詳解

OpenCV學(xué)堂 ? 來源:OpenCV學(xué)堂 ? 作者:gloomyfish ? 2022-09-02 10:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

稀疏光流跟蹤(KLT)詳解

視頻移動對象跟蹤中,稀疏光流跟蹤是一種經(jīng)典的對象跟蹤算法,可以繪制運動對象的跟蹤軌跡與運行方向,是一種簡單、實時高效的跟蹤算法,這個算法最早是有Bruce D. Lucas and Takeo Kanade兩位作者提出來的,所以又被稱為KLT。KLT算法工作有三個假設(shè)前提條件:

亮度恒定

短距離移動

空間一致性

亮度恒定

對象中任意像素點p(x,y)亮度值,在t-1時候的值,在t時刻移動(u, v)之后亮度值保持不變

2aa9dd0a-2a03-11ed-ba43-dac502259ad0.jpg


空間一致性

假設(shè)對像素點p(x, y)來說,周圍的像素點都保持相同的移動距離(u, v) 假設(shè)窗口大小為5x5,則對于25個窗口內(nèi)的像素點來說,就會如下等式成立:

2ac6159c-2a03-11ed-ba43-dac502259ad0.jpg


得到下面的過約束等式,根據(jù)最小二乘可以求解(u, v):

2b0ca192-2a03-11ed-ba43-dac502259ad0.jpg


這樣我們就得到了KLT光流等式與該窗口的的Hessian矩陣

2b21ef5c-2a03-11ed-ba43-dac502259ad0.png

2b38436a-2a03-11ed-ba43-dac502259ad0.jpg

空間尺度不變性

通過建立每一幀的圖像金字塔,實現(xiàn)尺度空間窗口目標(biāo)對象搜索

2b5a444c-2a03-11ed-ba43-dac502259ad0.jpg


OpenCV中KLT演示代碼實現(xiàn)

OpenCV中KLT算法API及其參數(shù)解釋如下:

voidcv::calcOpticalFlowPyrLK(
InputArrayprevImg,//前一幀圖像
InputArraynextImg,//后一幀圖像
InputArrayprevPts,//前一幀的稀疏光流點
InputOutputArraynextPts,//后一幀光流點
OutputArraystatus,//輸出狀態(tài),1表示正常該點保留,否則丟棄
OutputArrayerr,//表示錯誤
SizewinSize=Size(21,21),//光流法對象窗口大小
intmaxLevel=3,//金字塔層數(shù),0表示只檢測當(dāng)前圖像,不構(gòu)建金字塔圖像
TermCriteriacriteria=TermCriteria(TermCriteria::EPS,30,0.01),//窗口搜索時候停止條件
intflags=0,//操作標(biāo)志
doubleminEigThreshold=1e-4//最小特征值響應(yīng),低于最小值不做處理
)

特征點檢測與繪制的代碼實現(xiàn)如下:

//detectfirstframeandfindcornersinit
Matold_frame,old_gray;
capture.read(old_frame);
cvtColor(old_frame,old_gray,COLOR_BGR2GRAY);
goodFeaturesToTrack(old_gray,featurePoints,maxCorners,qualityLevel,minDistance,Mat(),blockSize,useHarrisDetector,k);

特征點繪制

voiddraw_goodFeatures(Mat&image,vectorgoodFeatures){
for(size_tt=0;t

KLT跟蹤代碼如下

TermCriteriacriteria=TermCriteria(TermCriteria::COUNT+TermCriteria::EPS,30,0.01);
doublederivlambda=0.5;
intflags=0;

boolret=capture.read(frame);
if(!ret)break;
imshow("frame",frame);
roi.x=0;
frame.copyTo(result(roi));
cvtColor(frame,gray,COLOR_BGR2GRAY);

//calculateopticalflow
calcOpticalFlowPyrLK(old_gray,gray,pts[0],pts[1],status,err,Size(31,31),3,criteria,derivlambda,flags);

特征點狀態(tài)檢查與匹配的代碼如下

size_ti,k;
for(i=k=0;i2){
pts[0][k]=pts[0][i];
initPoints[k]=initPoints[i];
pts[1][k++]=pts[1][i];
circle(frame,pts[1][i],3,Scalar(0,255,0),-1,8);
}
}
//resize有用特征點
pts[1].resize(k);
pts[0].resize(k);
initPoints.resize(k);

繪制跟蹤軌跡的代碼如下

//繪制跟蹤軌跡
draw_lines(frame,initPoints,pts[1]);

該方法實現(xiàn)如下:

voiddraw_lines(Mat&image,vectorpt1,vectorpt2){
if(color_lut.size()

運行效果:

左側(cè)是視頻的原始每一幀、右側(cè)視頻是每一幀中KLT算法實時軌跡繪制

車輛運行軌跡跟蹤

2b7754b0-2a03-11ed-ba43-dac502259ad0.jpg



審核編輯:劉清

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

    關(guān)注

    0

    文章

    41

    瀏覽量

    13147
  • OpenCV
    +關(guān)注

    關(guān)注

    32

    文章

    642

    瀏覽量

    42640
  • KLT
    KLT
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    7511

原文標(biāo)題:干貨 | OpenCV中KLT光流跟蹤原理詳解與代碼演示

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    同步電機在位置隨動系統(tǒng)中跟蹤誤差的分析與研究

    跟蹤最終位置過程的不確定性和傳統(tǒng)PID控制器超調(diào)量大,調(diào)節(jié)時間長的缺點,設(shè)計了Fuzzy-LQR-PD控制算法來提高位置跟蹤精度,通過Matlab軟件對該算法進(jìn)行仿真,并由STEP7編
    發(fā)表于 06-23 07:07

    SVPWM的原理及法則推導(dǎo)和控制算法詳解

    ,而且使直流母線電壓的利用率有了很大提高,且更易于實現(xiàn)數(shù)字化。下面將對該算法進(jìn)行詳細(xì)分析闡述。 文章過長,請點擊下方可查閱*附件:SVPWM的原理及法則推導(dǎo)和控制算法詳解.pdf
    發(fā)表于 03-14 14:51

    OpenVINO? Toolkit中如何保持模型稀疏性?

    OpenVINO? Toolkit 中支持的優(yōu)化方法,保持模型稀疏性。
    發(fā)表于 03-06 06:47

    SM73201 DC-ARC-EVAL伏電弧檢測的具體算法是什么?

    SM73201 DC-ARC-EVAL伏電弧檢測的具體算法是什么?求大神指教!
    發(fā)表于 02-08 06:14

    伏無人機巡檢系統(tǒng)功能詳解

    伏無人機巡檢系統(tǒng)功能詳解 隨著伏能源在全球范圍內(nèi)的廣泛應(yīng)用,確保伏電站的高效運行和長期穩(wěn)定輸出變得至關(guān)重要。傳統(tǒng)的人工巡檢方式不僅效率低下、成本高昂,而且難以覆蓋大面積的
    的頭像 發(fā)表于 01-16 17:10 ?425次閱讀
    <b class='flag-5'>光</b>伏無人機巡檢系統(tǒng)功能<b class='flag-5'>詳解</b>

    DAC1280 TDATA引腳輸入的比特,怎么產(chǎn)生這個比特,算法是什么?

    我想請問下關(guān)于DAC1280的TDATA引腳輸入的比特的問題: 1,怎么產(chǎn)生這個比特算法是什么? 2,怎么控制輸出信號的頻率? 對您的回答感激不盡,謝謝。
    發(fā)表于 01-06 06:21

    天合跟蹤受邀參加2024伏行業(yè)年度大會

    近日,由中國光伏行業(yè)協(xié)會舉辦的 2024伏行業(yè)年度大會在四川宜賓盛大開幕。會議邀請行業(yè)主管部門,行業(yè)組織、專家、伏企業(yè)領(lǐng)袖等一同就行業(yè)發(fā)展熱點問題進(jìn)行深度探討解析,天合跟蹤智能控制系統(tǒng)研發(fā)負(fù)責(zé)人孫凱博士應(yīng)邀出席
    的頭像 發(fā)表于 12-12 11:04 ?508次閱讀

    天合跟蹤AI賦能老電站新活力

    能帶來3.24%的發(fā)電量增益,按照該電站0.98元/千瓦時的含補貼上網(wǎng)電價計算,智能控制系統(tǒng)的技改可為項目帶來每年4.45萬元/兆瓦的額外收益。通過智能控制技術(shù),跟蹤支架對提升伏電站發(fā)電量的提升方式
    的頭像 發(fā)表于 12-05 09:26 ?631次閱讀

    Hi7200 高精度同步切降壓 LED 恒驅(qū)動器

    Hi7200 是一款外圍電路簡潔的同步降壓 LED 恒驅(qū)動器,適用于 6V-65V 輸入電壓范圍的 LED 恒照明領(lǐng)域,調(diào)光深度深,低輝負(fù)載調(diào)整率和一致性好。 Hi7200 采用我司專利算法
    發(fā)表于 11-25 16:32

    視頻目標(biāo)跟蹤從0到1,概念與方法

    導(dǎo)讀從目標(biāo)跟蹤的應(yīng)用場景,底層模型,組件,類型和具體算法幾個方面對目標(biāo)跟蹤做了全方面的介紹,非常好的入門文章。在今天的文章中,我們將深入研究視頻目標(biāo)跟蹤。我們從基礎(chǔ)開始,了解目標(biāo)
    的頭像 發(fā)表于 11-20 01:06 ?880次閱讀
    視頻目標(biāo)<b class='flag-5'>跟蹤</b>從0到1,概念與方法

    高抗噪性 電壓跟蹤

    電壓跟蹤
    jf_30741036
    發(fā)布于 :2024年09月29日 19:26:44

    抖動跟蹤不丟失 慧視圖像跟蹤板和自研算法強勢升級

    成都慧視開發(fā)的Viztra-HE030圖像處理板是采用了瑞芯微旗艦級高性能芯片RK3588,能夠憑借八核處理核心輸出至高6.0TOPS的算力,在算法的強力輔助下,能夠?qū)崿F(xiàn)對目標(biāo)的穩(wěn)定鎖定跟蹤。隨著
    的頭像 發(fā)表于 09-04 08:05 ?990次閱讀
    抖動<b class='flag-5'>跟蹤</b>不丟失 慧視圖像<b class='flag-5'>跟蹤</b>板和自研<b class='flag-5'>算法</b>強勢升級

    過零雙向可控硅驅(qū)動KLT304X&KLT306X&KLT308X 產(chǎn)品規(guī)格書

    KLT304X&KLT306X&KLT308XDIP4過零雙向可控硅驅(qū)動耦1.產(chǎn)品特點Productfeatures?無鹵素(溴
    發(fā)表于 08-20 15:47 ?0次下載

    隨機相位可控硅驅(qū)動KLT302X&KLT305X 產(chǎn)品規(guī)格書

    KLT302X&KLT305XDIP4隨機相位雙向可控硅驅(qū)動耦1.產(chǎn)品特點Productfeatures?無鹵素(溴
    發(fā)表于 08-20 15:45 ?0次下載

    激光跟蹤儀全面評估機器人定位算法的性能 #機器人性能 #激光跟蹤儀 #高精度定位

    激光跟蹤
    中圖儀器
    發(fā)布于 :2024年07月29日 10:13:56