999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

非線性化改進的KP-Detector 模型在人體姿態識別中的應用

2022-03-25 04:44:56鵬,逄博,徐欣,韋
軟件導刊 2022年3期
關鍵詞:檢測信息模型

張 鵬,逄 博,徐 欣,韋 博

(杭州電子科技大學通信工程學院,浙江杭州 310018)

0 引言

對人體姿態進行關節點檢測具有重要的現實意義,如對病人的病態進行監護和調理、在自動駕駛技術上對行人的行為進行識別以保證駕駛安全等。早在2008 年,葉蓬等[1]就提出了傳統的基于代數計算的方法,對視頻幀之間簡單運動模式進行指數形式的線性化操作,經過簡化歐式變換的矩陣對線性操作后的數據進行提取和重組,求得表征運動參數,實現對目標姿態的計算;Toshev 等[2]提出的“DeepPose”,將人體姿勢估計研究從經典方法[3]轉變到深度網絡,利用網絡直接回歸關節的x,y 坐標。這種方法比較直接,但最大的缺點是檢測速度慢,檢測效果依賴于標簽數據的完整性;與之不同的是,Tompson 等[4]通過并行運行多個分辨率庫中的圖像,同時捕獲各種比例特征來生成熱圖,將ConvNet 和圖形模型聯合使用,學習關節之間的典型空間關系;Pishchulin 等[5]以類似方法解決這一問題,其中包括如何處理一元分數生成和相鄰關節成對比較問題。

對關節點估計進行連續預測的方法有:Carreira 等[6]研究輸入一組預測,并每次通過網絡完善這些預測。但該方法需要多階段訓練,并且權重在每次迭代中被共享;Ludi等[7]引入一個模塊化仿真框架,針對各種以人為中心的場景算法進行訓練和驗證,描述了如何利用模擬數據訓練人體姿態估計算法來識別城市中不尋常的人類活動,但其檢測速度略有不足;Verma 等[8]提出一種新的連續幀跟蹤算法,通過計算單個身體部位在幀間的集體遍歷,反饋給TNN 進行學習,該方法可有效提高識別速度;Angelini 等[9]給出一種新的基于二維姿態的姿態層次HAR 方法,從人體姿勢中提取低層次和高層次特征,并將其提供給長—短期記憶神經網絡和一維卷積神經網絡進行分類;張劍書等[10]采用YOLO 算法結合AlphaPose 模型從視頻或圖像中提取出人類目標,將目標檢測任務作為回歸問題解決。采用YOLO 算法檢測速度較快,但總體精度偏低;蔡興泉等[11]提出一種少量關鍵序列幀的識別技術,對原有運動序列預選構造出初選關鍵幀序列,利用幀消減獲取關鍵幀序列,然后分別對不同人體姿勢建立隱馬爾科夫模型,得到的結果精度很高但檢測速度不佳;Farrajota 等[12]采用一系列殘差自動編碼器產生多個預測,然后結合起來提供一個身體關節可能性地圖,關注各關節點聯系,可以較好地保證精度;Nguyen 等[13]提出一種基于混合深度學習的手勢識別方法,該方法利用RGB 幀、三維骨骼關節信息和身體部位分割來解決這些問題。

鑒于上述模型存在檢測精度不高、檢測周期過長或檢測模型規模過大等問題,本文提出改進模型,將關節點和肢體分開檢測和識別,引用OpenPose[14]模型中的PAF(Part Affinity Fields)方法,并對該方法進行非線性化改進以提高檢測精度和檢測速度。block 之間使用Dense 連接機制減少模型的復雜度,優化使用6 層模型結構,進一步提高模型精度。本模型相對于其他模型有參數較少、精度較高、檢測周期較短等優勢。

1 相關技術

1.1 Dense 連接機制

傳統模型中,除了DensePose 模型使用全部的Dense 連接機制以外,其他都沒有使用Dense 連接機制,而只是簡單的層之間疊加。這樣通過加深網絡或加寬網絡的方法得到的模型非常容易過擬合,不利于模型表征。本文使用Dense 連接機制而不使用卷積層或者池化層,這是參考Gao 等[15]提出的DenseNet(Densely Connected Convolutional Networks)作出的改進。

Dense 連接層是一種線性運算,如圖1 所示。其中每個輸入都通過權重連接到每個輸出,因此,有n_inputs *n_outputs 個權重(n_inputs 代表輸入維度,n_outputs 代表輸出維度),其后通常跟隨非線性激活函數,這種連接方式可以實現權重和參數共享,前面階段的數據信息可以很方便地被后面階段共享利用。

Fig.1 DenseNet structure圖1 DenseNet 結構

本文的Dense 連接機制對單模型結構進行改進設計,實現了參數共享,簡化了參數的計算過程。連接已經不是殘差塊block 內部的網絡層對象連接,而是每一個分支網絡結構branch 之間的稠密和稀疏連接,如關鍵點定位模塊L(t)和肢體連接模塊A(t)都是block,本文中block 內部的連接仍然保持普通的依序連接。之所以不在block 內部構成連接,是因為在塊與塊之間的信息共享度較塊內部信息共享度高,在使用dense 連接機制后會伴隨計算成本不斷增大。因為這種機制需要維持參數共享,意味著在多層之間的參數需要來回傳遞,這會加大計算機運行消耗。而在塊內部的信息相對于其他塊是獨立的,不需要再將塊內部的信息共享到其他塊中,所以在塊內部的dense 連接機制可以取消。但是block 塊之間的信息大多是共享的,在關鍵點定位模塊中的關鍵點置信度信息需要與后面的肢體匹配模塊共享,同時在更新一輪肢體匹配模塊之后的信息也需要反饋回關鍵點定位模塊,然后對參數進行微調,所以需要使用dense 連接機制共享參數。

1.2 基于PLF的關節點連接技術

傳統的關節點連接技術是根據檢測到的關節點置信度大小最相近的兩個關節點進行連接匹配,這樣的連接方式不具有代表性。假如某一個關節點檢測結果出現了較大問題,那么得到的肢體就會發生較大偏移。為了解決這類問題,本文引用OpenPose 模型中的PLF(Point Line Fields)方法,并對該方法作非線性化改進。

主要改進點:在對肢體上的范圍點進行置信度計算過程中使用指數—對數非線性化表示,以探索更高維度的空間可能存在的關鍵點。找到該關鍵點后進行指數—對數非線性化轉化,增大其權重。之所以這么做,是因為在一條肢體上每一點的權重不應該只是線性的均勻變化,所以本文采用非線性表示,使用log 函數對一條肢體上每一個點的權重作非線性映射,以放大隱藏的關鍵點信息。同樣,對關節點的計算方法也考慮了指數熱度的影響,因為有的節點置信度非常小,可能是錯誤信息,需要使用指數調熱方法避免或減少這種情況對預測結果產生太大影響,即將這些值控制在0~1 之間。

PLFs 計算肢體置信度如圖2 所示。

Fig.2 Limb confidence calculated by PLFs algorithm圖2 PLFs 算法計算肢體置信度

其中,j1和j2分別表示第k 個人的肢體c 上的兩類關節點,每個PLF 是每個肢體的2D 矢量場。對于屬于特定肢體區域中的每個像素,2D 矢量編碼從肢體一個部位指向另一部位的方向,每種肢體都有一個對應的PLF 將兩個相關的身體部位連接在一起。

p(u)代表連接在兩個關節點dj1和dj2之間的肢體置信度:

如果通過對u的等距值進行采樣和求和來近似積分,則如公式(1)得到的積分值是均勻的;而使用log 函數對一條肢體上每一個點的權重作非線性變化,得到的權重就是非線性的,如公式(2)所示。

2 KP-Detector 模型

2.1 模型流程

KP-Detector 模型流程如圖3 所示。

Fig.3 Model flow圖3 模型流程

主要分為3 個部分:①使用ResNet50 預訓練的神經網絡對圖片進行特征提取,從最后一層的featuremap 中定位隱藏的候選關節點,以及給出每個關節點屬于某一類的置信度值;②對得到的關節點定位信息和置信度值按照PLFs算法進行連接,組成合理的肢體信息,得到每一條肢體的置信度值;③每一條隱藏的肢體構成一個最大二分圖,通過構建一棵匈牙利樹,找到合理的最大匹配情況即為最后的肢體連接結果。

2.1.1 關節點檢測

從預訓練好的ResNet50的最后一層提取出關節點的位置信息和類別信息,生成一組輸入特征圖F。在此階段,網絡生成一組部分親和力字段(PLF):

其中,φ1指第一階段對肢體置信度值的初始化。將第一個階段的預測結果與原始圖像特征F 串聯起來作為當前階段的預測值,用于產生精確的預測結果:

其中,φt表示在第t 個階段CNN的推理過程,T 表示總的PLF 階段數。經過T 次迭代后,從最新的PLF 預測開始,重復進行置信度圖檢測:

其中,ρt表示在第t 個階段進行推理的CNN 過程,C 表示置信度映射階段的總數量。這種方法每個階段都細化了PLF 和置信度圖分支,因此每個階段計算量減少了一半,改進的親和力場預測方法可改善置信度圖結果。

置信度圖結果是在早期階段進行預測,估計的結果在后期通過全局推斷逐步完善。在每個階段的末尾應用損失函數,在估計預測值與標簽和字段之間使用L2損失。對損失函數進行空間加權以解決某些數據集不能完全標記所有人的問題。

在階段ti的PLF 分支損失函數和階段tk的置信度圖分支損失函數為:

在評估方程式中的fS訓練過程中,帶關節點注釋的2D關鍵點生成標簽數據可信度圖S*,每個置信度圖都是特定身體部位位于給定像素中信息的2D 表示。理想情況下,如果一個人出現在圖像中,則每個置信度圖中應存在一個峰值;如果圖像中有多個人,則對于每個人k,應該有一個對應于每個可見部分j的峰值。本文首先為每個人k生成個人置信度圖,其中xj,k∈R2代表對應于人k的第j個關節點的標簽值。定義為:

其中,σ為控制峰值的形式,網絡預測的標簽點置信度圖是通過對各個置信度圖進行匯總后得到的最大值。

之所以選擇使用置信度圖中最大的值而不是平均值,是因為實驗結果表明,使用最大值相較于平均值效果更好。

2.1.2 關節點連接

給定一組身體部位檢測結果,組裝它們以形成未知人數的全身姿勢,需要每對身體部位檢測都具有關聯性的置信度,采用方法是檢測每一對可能成為關節點對的兩個點的中點。但是,當人們擠在一起時,這些中點很可能支持虛假的關聯,其原因是由表示方面的局限性引起的:①因為表達信息主要來自于最關鍵的那個點,而未考慮到整個關節點的協調配合,所以肢體的信息表達不完整;②對于關節點而言,它只注重位置信息而忽略了方向隱藏的信息;③因為用于模型訓練的數據單一,所以模型的泛化能力較差。

PLFs 算法非常巧妙地解決了這些限制,保留了肢體支撐區域的位置和方向信息。每個PLF 是每個肢體的2D 矢量場。對于屬于特定肢體的區域中的每個像素,2D 矢量編碼從肢體一個部位指向另一部位的方向,每種肢體都有一個對應的PLF 將其兩個相關的身體部位連接在一起。

考慮單個肢體PLFs 算法,設xj1,k和xj2,k為關節點的標簽位置,其中j1和j2分別表示第k個人肢體c上的兩類關節點,計算關鍵點xj1,k指向xj2,k的單位向量:

其中,lc,k代表肢體長度,如圖1、圖2 所示的寬度,σl代表肢體寬度,如圖2、圖3 所示的高度。如式(11)和式(12)所示,只有限制在肢體范圍內的點p的向量才被算作單位向量v,否則就是0。

這樣,一張圖片中所有人的關節點p所在位置對應的PLF 值為:

式中,nc(p)是一張圖片中k個人中關節點p值非零的個數。

首先對Lc進行采樣,采用式(2)的方式,然后根據式(16)對采樣后的信息進行積分求和,得到肢體的置信度值:

對檢測置信度圖執行非極大值抑制算法,以獲得離散的部分候選位置。由于圖像中存在多個人的關節點信息,所以可能有多個候選對象。這些候選關節點定義了大量可能的候選肢體,使用PLF 上的線積分計算公式對每個候選肢體進行綜合評分,從中找到最佳匹配——K 維匹配。本文使用一個貪婪的松弛方法,該松弛方法不僅能夠持續產生高質量的匹配結果,而且能夠大幅度縮短匹配時間,推測原因是由于PLF 網絡的接收域很大。

2.2 模型結構

KP-Detector 模型內部結構如圖4 所示。

設前一組階段預測關節點置信度圖為L(t),后一組階段預測肢體置信度圖為A(t),每個階段的關節點預測結果與對應圖像特征F 針對每個后續階段進行前后級聯,在每個卷積塊中使用的卷積核大小為3,使用3 個這樣的卷積核串聯組成。連續階段的預測t∈{1,…,T}并在每個階段進行中間監督,相對于其他網絡模型增加了網絡深度。在原始模型中,網絡體系結構基本包括許許多多7×7 卷積層。在當前模型中,通過使用3 個連續的3×3 內核替換7×7的卷積內核,保留了接收場,同時減少了計算量,而操作數前者為97,后者只有51。此外,3 個卷積中每個輸出按照類似于DenseNet的方法將內核串聯在一起,非線性層數量增加了兩倍,網絡可同時保留較低級別和較高級別功能。

Fig.4 Internal structure of KP-Detector model圖4 KP-Detector 模型內部結構

KP-Detector 模型外部結構如圖5 中L(2)、L(3)所示,分別是關節點置信度圖和肢體置信度圖的預測網絡,其中在關節點定位模塊中使用4 塊重結構,在肢體置信度模塊使用2 塊重結構,相比其他結構結果最好。兩種模塊使用類似于DenseNet的連接結構,即每一塊重結構之間都是以Dense 形式連接在一起的,這樣保證后面的重結構可以充分利用到前面重結構的信息,從而使信息共享最大化,即在前面的重結構中將高分辨率數據送入后面的精度解析過程中實現信息之間共享最大化。

Fig.5 External structure of KP-Detector model圖5 KP-Detector 模型外部結構

3 實驗結果與分析

本文在MPII 數據集上評估KP-Detector、CPN、SHN 和DensePose 模型。MPII 數據集由3 844 個訓練和1 758 個測試小組組成,這些小組由高度互動的姿勢(具有14 個身體部位)中的多個相互作用的個體組成。數據集收集了各種場景下的圖像,這些場景包含如擁擠、比例變化、遮擋和接觸等現實世界中的情形,并提供本文模型與Stacked Hourglass Network 和DensePose的運行時間分析比較,以量化系統效率(見圖6)。

3.1 準確度比較分析

如圖7 所示,本文使用4 種模型分別在MPII 數據集上做檢測精度比較實驗,4 種模型分別是本文提出的KP-Detector 模 型、CPN(Cascaded Pyramid Network)模 型、SHN(Stacked Hourglass Networks)模型和DensePose 模型。從圖片曲線可以看出,本文提出的KP-Detector 模型精度指標隨著迭代次數的增多明顯超越其他3 個模型,說明本文模型在精度方面有明顯優勢。

3.2 檢測速度比較分析

使用4 種模型分別在MPII 測試數據集上進行檢測速度比較實驗,實驗結果如圖8 所示。本文提出的KP-Detector 模型的檢測速度指標FPS(每一秒內檢測的圖片張數)在整體上的表現較其他模型要穩定很多,而在后期受圖片數量的影響越來越小,是CPN 模型和DensePose 模型檢測速度的1.25 倍左右。分析原因可能是本文模型是自底向上進行檢測,而從關節點開始檢測定位,然后是肢體檢測,最后是肢體連接,這樣的檢測方式保證了如果在前一個階段檢測失敗或者置信度低于某一個閾值時會被拋棄,保證在后面的階段不會再次出現,大大縮短了檢測周期。同時,使用Dense 連接機制保證了可用參數的共享性,保證了特征信息和關節點信息最大化利用。

Fig.6 Sample results of different models圖6 不同模型樣本結果

Fig.7 Comparison of accuracy on MPII data set圖7 MPII 數據集上的精確度比較結果

Fig.8 Comparison results of detection speed of four models on MPII data set圖8 4 種模型在MPII 數據集上檢測速度的比較結果

3.3 模型參數比較分析

本文對4 種模型大小進行比較。原CPN 模型、SHN 模型和DensePose 模型大小約是本文KP-Detector 模型的12倍。如果在某工程應用或研究項目中,需要將模型遷移到內存大小嚴格限制的ARM 等低存儲設備芯片上,那么模型大小自然是第一個需要考慮的因素。該模型成功被壓縮到只有18M 左右,能滿足大部分存儲設備需求。本模型之所以能夠相較于其他模型小如此多,主要是因為網絡結構中定位模塊與肢體連接模塊是序列進行的,而且使用了Dense 模塊,這樣大大節省了參數空間,并能夠充分共享將近一半的參數量。再看KP-Detector的兩種結構模型,如果在Association 模塊也使用Dense 連接模塊,會使得到的模型規模變大3MB 左右,但是參數量卻減少1 000 左右,這是因為在Association 使用了Dense 連接機制后,每一個階段得到的數據會被其他階段共享,在共享中難免會有很多冗余計算節點,使模型變大,但是模型整體上被共享的參數量卻不一樣,這些多余的參數并不是重新生成,而是被其他階段共享,這樣參數數量反而減少了。所以在這兩種模型結構中,在KP-Detector的Association 模塊中使用Dense連接機制會更利于模型存儲和參數共享。

Table 1 Comparison results of scale of four models表1 4種模型規模比較結果

3.4 模型結構比較分析

對各種模型結構進行試驗,如對{3、4、5、6、7}這5 種階段的結構進行試驗,發現階段數為6 或者7 時最優。在階段數為6 時,對具體的關節點定位模塊和肢體連接模塊中的子模塊數分別進行實驗,評價指標mAP(mean Average Precision)。實驗結果表明,在關節點定位模塊使用4 個子模塊和在肢體連接模塊使用2 個子模塊時效果最好,在這兩種模塊中分別使用Dense 連接結構,保證了模型參數的共享性,模型精度得到提升。所以最后決定使用4 個關節點定位子模塊和2 個肢體連接子模塊,并且都使用Dense 連接機制,如表2 所示。

對KP-Detector 模型中的PAFs 和PLFs 進行比較實驗,最后發現在精度mAP 上比PAFs 略高出0.5 個百分點,在檢測速度FPS 上比PAFs 略快0.4,整體結果說明改進后的PLFs 相比于PAFs 效果要好一些。說明對一條肢體上的每一個點的權重不應是均勻線性變化的,增加其非線性效果會更好,如表3 所示。

Table 2 Experimental comparison results of KP-Detector model structure with different stages表2 KP-Detector 模型結構取用不同階段實驗比較結果(%)

Table 3 Comparative experiments using PAFs and PLFs表3 使用PAFs 和PLFs 比較實驗

4 結語

實時多人關節點檢測估計是機器能夠以視覺方式理解和解釋人及其互動的關鍵要素。本文做了以下工作:①提出關鍵點關聯的顯式非參數表示形式,對人類四肢的位置和方向進行編碼;②設計了一種可以共同學習零件檢測和關聯的架構;③證明了貪婪的解析算法足以產生高質量的人體姿勢解析;④證明了PLF 細化遠比PAF 和身體部位位置細化相結合更為重要,從而大大提高了運行性能和準確性;⑤將身體和腳部估計結合到一個模型中可以提高每個組件的準確性,并減少運行時間;⑥證明在模型中適當使用Dense 連接機制可以提高參數的共享性,減輕模型的梯度消失問題,使用匈牙利算法做肢體的最大二分圖匹配是一個非常好的方法。本文設計是一個用于身體、腳、手和面部關鍵點檢測的實時系統,該系統可以廣泛應用于涉及人類分析的許多研究主題,如人類的重新識別、重新定位和人機交互等。該研究對人體姿態識別技術的應用和優化有一定的參考作用。

本文還有需改進的地方:①增加更多關節點優良數據集,使用無監督學習方法或者其他方法增加這種優質數據集,使模型的表現力更強;②利用生成模型生成一些數據集,或者是一些沒有標記出來的關節點,這樣數據集會更豐富,非常有利于模型訓練;③不斷優化模型,以達到識別非真人的人形雕塑目標,使模型識別能力更強。

猜你喜歡
檢測信息模型
一半模型
“不等式”檢測題
“一元一次不等式”檢測題
“一元一次不等式組”檢測題
重要模型『一線三等角』
重尾非線性自回歸模型自加權M-估計的漸近分布
訂閱信息
中華手工(2017年2期)2017-06-06 23:00:31
3D打印中的模型分割與打包
小波變換在PCB缺陷檢測中的應用
展會信息
中外會展(2014年4期)2014-11-27 07:46:46
主站蜘蛛池模板: a色毛片免费视频| 超清无码熟妇人妻AV在线绿巨人| 在线视频亚洲色图| 香蕉久久国产超碰青草| 国产精品一区二区无码免费看片| 亚洲日韩精品欧美中文字幕| 视频一本大道香蕉久在线播放| 久久国产V一级毛多内射| 欧美日韩第二页| 人妻无码一区二区视频| 欧美精品高清| 欧美亚洲中文精品三区| 国产成人艳妇AA视频在线| 亚洲天堂.com| 成人第一页| 激情爆乳一区二区| 丰满的少妇人妻无码区| 无码精油按摩潮喷在线播放| 日韩a级片视频| 欧美日韩综合网| 久久美女精品| 中国精品自拍| 伊人激情综合| 99久久精品免费看国产免费软件| 五月丁香伊人啪啪手机免费观看| 久久黄色视频影| 色欲国产一区二区日韩欧美| 国内精自视频品线一二区| 日韩在线观看网站| 999精品在线视频| 92精品国产自产在线观看| 国产嫩草在线观看| 一本无码在线观看| 蜜芽一区二区国产精品| 免费看的一级毛片| 亚洲成年人网| 日本不卡在线| 九色在线视频导航91| 国产精品视频3p| 国产自产视频一区二区三区| 国内精品视频在线| 国产乱子精品一区二区在线观看| 亚洲最猛黑人xxxx黑人猛交| 国产精品欧美激情| 久久精品这里只有国产中文精品| 日韩在线播放中文字幕| 伊人五月丁香综合AⅤ| 九九九久久国产精品| 亚洲国产一成久久精品国产成人综合| 日本91在线| 五月婷婷激情四射| 中文字幕久久精品波多野结| 国产成人三级| 香港一级毛片免费看| 久久天天躁狠狠躁夜夜2020一| 国产一区二区三区夜色| 欧洲日本亚洲中文字幕| 无码免费的亚洲视频| 国产成人啪视频一区二区三区| 999精品视频在线| 国产日本欧美亚洲精品视| 亚洲精品第五页| 亚洲无码高清免费视频亚洲| 久久99国产视频| 亚洲精品制服丝袜二区| 蜜芽国产尤物av尤物在线看| 激情综合五月网| 日韩精品无码一级毛片免费| 国产综合无码一区二区色蜜蜜| 国产办公室秘书无码精品| 丁香综合在线| 伊人色在线视频| 成人久久精品一区二区三区| 亚洲第一区欧美国产综合 | 国产极品粉嫩小泬免费看| 亚洲综合天堂网| 免费国产黄线在线观看| 日本精品中文字幕在线不卡| 97在线观看视频免费| 久久久受www免费人成| 欧美a在线看| 亚洲系列无码专区偷窥无码|