本發(fā)明涉及無人艇應(yīng)用技術(shù)領(lǐng)域,具體地說是一種基于無人艇應(yīng)用的目標長時間穩(wěn)定跟蹤方法。
背景技術(shù):
無人艇,是一種無人操作的水面艦艇,可以在各種環(huán)境中使用,尤其便于在不適合有人船只和較為危險的環(huán)境中使用,不管是在軍用領(lǐng)域還是民用領(lǐng)域,我國對無人艇的需求都在逐漸增強。在無人艇的自主航行中,目標的穩(wěn)定跟蹤是無人艇自動避障的技術(shù)基礎(chǔ)。目前常用的目標跟蹤方法主要有以下兩種:
(1)基于關(guān)鍵點匹配的目標跟蹤方法
基于關(guān)鍵點匹配的目標跟蹤方法通常在目標所在區(qū)域提取具有不變性特征的關(guān)鍵點,將目標模板視作一些關(guān)鍵點的集合,在以后的各幀中提取關(guān)鍵點并與模板的關(guān)鍵點比較,然后估計幾何變換參數(shù),求得當前幀目標位置相對于初始模板位置的幾何變換關(guān)系。
(2)基于目標檢測的目標跟蹤方法
基于目標檢測的跟蹤方法通常利用一個在線訓(xùn)練的分類器將目標從周圍背景中區(qū)分出來。在跟蹤的過程中,在上一幀目標所在位置周圍以滑動窗口形式提取一定數(shù)量的候選框,通過在線訓(xùn)練的分類器預(yù)測目標所在位置。有了目標的預(yù)估位置以后,可以生成一個帶標簽的訓(xùn)練樣本集合,用這個訓(xùn)練樣本集在線訓(xùn)練更新分類器模型參數(shù)。
基于關(guān)鍵點匹配的方法的成功與關(guān)鍵點的檢測方法密切相關(guān),關(guān)鍵點太多會影響算法執(zhí)行效率,關(guān)鍵點太少會影響算法的準確性,并且,當目標的外觀發(fā)生劇烈變化,或者背景較復(fù)雜,與目標區(qū)分度不大時,這種算法就會跟丟目標,導(dǎo)致跟蹤失敗。而基于目標檢測的跟蹤方法雖然能夠很好的解決目標的形變、旋轉(zhuǎn)等問題,但是算法復(fù)雜度較高,難以做到實時,限制此類方法的實際應(yīng)用范圍。
盡管目前已存在許多目標跟蹤的方法,但是在無人艇的自主航行問題中,待跟蹤的目標類型眾多(例如游輪、帆船、漂浮物、礁石等),可能很大也可能很小,并且經(jīng)常伴隨目標的尺度變化以及目標之間的遮擋,在保證實時性的前提下,目前的目標跟蹤方法不能很好的適應(yīng)真實的自然場景。
綜上所述,盡管目前存在很多目標跟蹤相關(guān)方法,但由于算法的魯棒性以及實時性等原因,很難將其應(yīng)用到無人艇的自動避障中。
技術(shù)實現(xiàn)要素:
本發(fā)明要解決的技術(shù)問題是提供一種基于無人艇應(yīng)用的水面目標跟蹤方法,能夠長時間穩(wěn)定地進行跟蹤。
為了解決上述技術(shù)問題,本發(fā)明采取以下技術(shù)方案:
一種基于無人艇應(yīng)用的目標跟蹤方法,包括以下步驟:
s1,獲取目標的圖像序列,在以上一幀目標所在位置為搜索中心的設(shè)定范圍內(nèi),利用預(yù)設(shè)濾波器f(z)=wtz,z為樣本的特征向量,w為權(quán)重向量,搜索到最大響應(yīng)位置,該最大響應(yīng)位置作為目標在當前幀的候選位置中心;
s2,在候選位置中心的周圍采用多尺度滑動窗口采樣得到若干候選框,利用結(jié)構(gòu)化svm分類器對所有候選框計算得分,得分最大的候選框作為當前幀目標的預(yù)測結(jié)果;
s3,判斷目標是否被遮擋;
s4,若目標被遮擋,則不進行在線學(xué)習(xí),不更新預(yù)設(shè)濾波器參數(shù)和結(jié)構(gòu)化svm分類器參數(shù);若目標未被遮擋,更新預(yù)設(shè)濾波器參數(shù),轉(zhuǎn)入步驟s5;
s5,更新結(jié)構(gòu)化svm分類器參數(shù);
s6,重復(fù)步驟s1-s5,直到圖像序列的最后一幀。
所述步驟s4中更新預(yù)設(shè)濾波器參數(shù)具體包括以下子步驟:
s4.1,構(gòu)造循環(huán)樣本矩陣,以步驟s2得到的預(yù)測結(jié)果所在位置作為中心,設(shè)置一個基本樣本,該基本樣本的大小為目標的n倍,n為大于1的實數(shù),將該基本樣本進行上下左右的循環(huán)偏移,得到若干訓(xùn)練樣本,所有訓(xùn)練樣本構(gòu)成循環(huán)樣本矩陣;
s4.2,對預(yù)設(shè)濾波器f(z)=wtz中的參數(shù)w進行更新,設(shè)定訓(xùn)練樣本及其回歸值為{(x1,y1),(x2,y2),...,(xi,yi),...},根據(jù)目標函數(shù):
所述步驟s4.2中,對于閉式解w=(xtx+λi)-1xty,其中存在逆運算(xhx+λi)-1,在樣本量很多時直接求解逆運算會很耗時,為了提高運算效率,對該閉式解進行離散傅立葉變換。
所述步驟s5具體包括以下子步驟:
s5.1,以預(yù)測結(jié)果所在位置為中心,在設(shè)定搜索半徑的區(qū)域內(nèi),均勻采集訓(xùn)練樣本,得到支持向量,該支持向量由正訓(xùn)練樣本和負訓(xùn)練樣本構(gòu)成,更新結(jié)構(gòu)化svm分類器參數(shù);
s5.2,設(shè)定支持向量的數(shù)量上限,當支持向量的數(shù)量達到閾值時,去除對結(jié)構(gòu)化svm分類器影響最小的支持向量。
所述步驟s3中判斷目標是否被遮擋具體為:
s3.1,將步驟s2中得分最大的候選框所對應(yīng)的得分值與歷史最大得分值進行比較,得分值最大的候選框為當前的跟蹤結(jié)果;
s3.2,若當前的候選框的得分小于maxscore-derta_1*maxscore,則目標被遮擋,當前跟蹤結(jié)果維持上一幀目標位置不變,并在下一幀尋找目標時擴大搜索范圍;
s3.3,若當前的候選框的得分大于maxscore-derta_1*maxscore并且小于maxscore-derta_2*maxscore,則當前跟蹤結(jié)果是目標,目標的一部分被遮擋,此時更新目標位置,但是不更新預(yù)設(shè)濾波器和結(jié)構(gòu)化svm分類器參數(shù);
s3.4,如果當前的候選框的得分值大于maxscore-derta_2*maxscore,則既更新目標位置也更新預(yù)設(shè)濾波器參數(shù)和結(jié)構(gòu)化svm分類器參數(shù);
其中,maxscore為歷史最大得分值,derta_1和derta_2為常數(shù),并且derta_2小于derta_1。
所述步驟s1具體包括以下子步驟:
s1.1,獲取目標的圖像序列后,對其中的圖像進行預(yù)處理,將圖像轉(zhuǎn)換為灰度圖,在該灰度圖上進行特征提取取,得到特征圖;
s1.2,特征圖上每一個像素位置對應(yīng)有一個特征向量zij,計算特征圖上每個像素位置的響應(yīng)值f(z)=wtzij,得到熱圖,取該熱圖中最大響應(yīng)位置為當前幀目標候選位置的中心。
本發(fā)明能夠長時間穩(wěn)定跟蹤無人艇自主航行中遇到的各種障礙物以及需要被跟蹤的目標。通過及時處理無人艇上相機拍攝得到的圖片,結(jié)合預(yù)設(shè)濾波器和結(jié)構(gòu)化輸出的跟蹤方法,實時感知周圍環(huán)境,穩(wěn)定跟蹤感興趣目標。在保證實時性的前提下,本發(fā)明相比于現(xiàn)有的其他跟蹤方法,無論是在處理跟蹤過程中目標遮擋、尺度變化等問題,還是目標自身發(fā)生形變或者環(huán)境背景光照變化等問題上,都有很大的提升,對無人艇的自動避障具有重要的指導(dǎo)意義。
附圖說明
附圖1為本發(fā)明流程示意圖;
附圖2為本發(fā)明中判斷目標是否被遮擋的流程示意圖;
附圖3為本發(fā)明預(yù)設(shè)濾波器更新參數(shù)的流程示意圖;
附圖4為本發(fā)明結(jié)構(gòu)化svm分類器更新參數(shù)的流程示意圖;
附圖5為本發(fā)明跟蹤實施例的示意圖。
具體實施方式
為了便于本領(lǐng)域技術(shù)人員的理解,下面結(jié)合附圖對本發(fā)明作進一步的描述。
如附圖1所示,本發(fā)明揭示了一種基于無人艇應(yīng)用的水面目標跟蹤方法,包括以下步驟:
s1,獲取目標的圖像序列,在以上一幀目標所在位置為搜索中心的設(shè)定范圍內(nèi),利用預(yù)設(shè)濾波器f(z)=wtz,z為樣本的特征向量,w為權(quán)重向量,搜索到最大響應(yīng)位置,該最大響應(yīng)位置作為目標在當前幀的候選位置中心。
s2,在候選位置中心的周圍采用多尺度滑動窗口采樣得到若干候選框,利用結(jié)構(gòu)化svm分類器對所有候選框計算得分,得分最大的候選框作為當前幀目標的預(yù)測結(jié)果。
s3,判斷目標是否被遮擋。
s4,若目標被遮擋,則不進行在線學(xué)習(xí),不更新預(yù)設(shè)濾波器參數(shù)和結(jié)構(gòu)化svm分類器參數(shù),即使目標的表現(xiàn)模型發(fā)生改變時也能準確找得到目標;若目標未被遮擋,更新預(yù)設(shè)濾波器參數(shù),轉(zhuǎn)入步驟s5。
s5,更新結(jié)構(gòu)化svm分類器參數(shù)。
s6,重復(fù)步驟s1-s5,直到圖像序列的最后一幀,從而得到較為準確的跟蹤結(jié)果。
對于步驟s1具體包括以下子步驟:
s1.1,獲取目標的圖像序列后,對其中的圖像進行預(yù)處理,將圖像轉(zhuǎn)換為灰度圖,在該灰度圖上進行特征提取,得到特征圖。如果目標圖像的面積大于閾值smax,降低其分辨率為原來的0.5倍,避免因跟蹤器處理的圖像過大而降低算法效率,在本發(fā)明實施例中取smax=50*50。如果是彩色圖,還需要將其轉(zhuǎn)換為灰度圖,特征提取只在灰度圖上進行。對于圖像特征的選擇,選擇處理速度比較快速并且效果也比較好的hog特征,將梯度方向分為9個bin,cell大小為lcell*lcell,lcell=4,每個cell的特征維度是31,計算搜索區(qū)域?qū)?yīng)的特征圖,如果搜索區(qū)域的大小為wf*hf,特征圖的大小為
s1.2,特征圖上每一個像素位置對應(yīng)有一個特征向量zij,計算特征圖上每個像素位置的響應(yīng)值f(z)=wtzij,得到熱圖,取該熱圖中最大響應(yīng)位置為當前幀目標候選位置的中心。特征圖上每個像素位置都有一個特征向量zij,
在步驟s2中,根據(jù)步驟1得到當前幀的候選位置中心,若目標長和寬分別為wt、ht,則搜索區(qū)域的長和寬為wt+12、ht+12。在搜索區(qū)域內(nèi)以5個尺度(1.0,0.9,1.05,1.1,1.15)進行滑動窗口密集采樣,得到目標候選框。
選用6種haar特征模板,將每個候選框分為4*4的網(wǎng)格,在2個尺度上對每個候選框所在區(qū)域的圖像計算得到192維haar特征。為了提高算法的計算效率,在特征提取前,首先計算輸入圖像的積分圖。利用結(jié)構(gòu)化svm分類器對每個候選框計算得分。取得分最大的候選框作為目標新的位置。
如附圖2所示,步驟s3中判斷目標是否被遮擋具體為:
s3.1,將步驟s2中得分最大的候選框所對應(yīng)的得分值與歷史最大得分值進行比較,得分值最大的候選框為當前的跟蹤結(jié)果;
s3.2,若當前的候選框的得分小于maxscore-derta_1*maxscore,則目標被遮擋,當前跟蹤結(jié)果維持上一幀目標位置不變,并在下一幀尋找目標時擴大搜索范圍;
s3.3,若當前的候選框的得分大于maxscore-derta_1*maxscore并且小于maxscore-derta_2*maxscore,則當前跟蹤結(jié)果是目標,目標的一部分被遮擋,此時更新目標位置,但是不更新預(yù)設(shè)濾波器和結(jié)構(gòu)化svm分類器參數(shù);
s3.4,如果當前的候選框的得分值大于maxscore-derta_2*maxscore,則既更新目標位置也更新預(yù)設(shè)濾波器參數(shù)和結(jié)構(gòu)化svm分類器參數(shù);
其中,maxscore為歷史最大得分,derta_1和derta_2為常數(shù),并且derta_2小于derta_1。在本實施例中,derta_1、derta_2的值分別是0.65和0.35。
通過判斷目標是否被遮擋,并且執(zhí)行相關(guān)操作,有效防止預(yù)設(shè)濾波器和結(jié)構(gòu)化svm分類器發(fā)生錯誤更新,導(dǎo)致跟蹤結(jié)果出現(xiàn)漂移甚至跟丟目標的情況。
此外,如附圖3所示,所述步驟s4中更新預(yù)設(shè)濾波器參數(shù)具體包括以下子步驟:
s4.1,構(gòu)造循環(huán)樣本矩陣,以步驟s2得到的預(yù)測結(jié)果所在位置作為中心,設(shè)置一個基本樣本,該基本樣本的大小為目標的n倍,n為大于1的實數(shù),將該基本樣本進行上下左右的循環(huán)偏移,得到若干訓(xùn)練樣本,所有訓(xùn)練樣本構(gòu)成循環(huán)樣本矩陣。比如,將基本樣本的大小設(shè)為目標大小的3倍。以目標為中心,將基本樣本做出相應(yīng)的上下左右循環(huán)偏移,可以得到數(shù)量很多的訓(xùn)練樣本,對于新構(gòu)造的訓(xùn)練樣本,根據(jù)它里面目標中心與基本樣本目標中心的距離,分配一個總體呈高斯分布的回歸值,方差為0.4、0.3或者其他數(shù)值,該方差的取值與目標大小有關(guān),上述列舉并非是限定,具體表現(xiàn)為方差
另外,通過循環(huán)偏移得到的圖像在邊界處不是很平滑,通過對基準圖像乘以一個漢寧窗來降低邊緣圖像的權(quán)重。
s4.2,對預(yù)設(shè)濾波器f(z)=wtz中的參數(shù)w進行更新,設(shè)定訓(xùn)練樣本及其回歸值為{(x1,y1),(x2,y2),...,(xi,yi),...},根據(jù)目標函數(shù):
上述的訓(xùn)練樣本的訓(xùn)練過程實際上是求解一個嶺回歸問題,或者叫做正則化最小二乘問題。比如,一個復(fù)數(shù)情況下的求解結(jié)果w*=(xhx+λi)-1xhy,其中xh是x的共軛轉(zhuǎn)置,w*是w的共軛。在這個閉式解中出現(xiàn)了求逆運算(xhx+λi)-1,將上面的閉式解進行離散傅立葉變換,可以避開矩陣求逆運算,減少算法執(zhí)行時間,極大提高目標跟蹤算法的實時性。最終得到
如附圖4所示,所述步驟s5具體包括以下子步驟:
s5.1,以預(yù)測結(jié)果所在位置為中心,在設(shè)定搜索半徑的區(qū)域內(nèi),均勻采集訓(xùn)練樣本,得到支持向量,該支持向量由正訓(xùn)練樣本和負訓(xùn)練樣本構(gòu)成,更新結(jié)構(gòu)化svm分類器參數(shù)。
通過學(xué)習(xí)一個預(yù)測函數(shù)f:x→y去直接預(yù)測幀間的目標位置轉(zhuǎn)換關(guān)系,而不是學(xué)習(xí)一個分類器。輸出空間是轉(zhuǎn)換關(guān)系y而不是二值標簽0或者1。在該方法中,一個帶標簽的樣本是一對(x,y),y是目標位置的轉(zhuǎn)換關(guān)系(比如位移、旋轉(zhuǎn)),在結(jié)構(gòu)化輸出svm框架下學(xué)習(xí)f,將f應(yīng)用于下式中進行下一幀目標位置的預(yù)測:
判別函數(shù)f為更準確的包含目標的樣本打高分。其中pt-1為t-1幀目標所在位置,
其中yi代表第i幀對應(yīng)的跟蹤器的輸出結(jié)果,εi為svm中的松弛變量,(
使用標準的拉格朗日對偶技術(shù),目標函數(shù)被轉(zhuǎn)化為以下的相等對偶形式
在上述對偶形式中,
其中
s5.2,設(shè)定支持向量的數(shù)量上限,當支持向量的數(shù)量達到閾值時,去除對結(jié)構(gòu)化svm分類器影響最小的支持向量。
根據(jù)步驟s5.1,如果一個支持模式只有兩個支持向量,那么這兩個都會被移除。將向量(xr,y)移除后對權(quán)重向量的影響可以按下式計算:
(xr,yr)為正的支持向量,(xr,y)為去掉的支持向量,
如附圖5所示,為按照本發(fā)明方法進行水面目標跟蹤的一個實施例示意圖,能夠長時間穩(wěn)定的跟蹤目標。
本領(lǐng)域的技術(shù)人員容易理解,以上所述僅為本發(fā)明的較佳實施例而已,并不用以限制本發(fā)明,凡在本發(fā)明的精神和原則之內(nèi)所作的任何修改、等同替換和改進等,均應(yīng)包含在本發(fā)明的保護范圍之內(nèi)。