进击的YOLOv3,目标检测网络的巅峰之作 | 内附实景大片
作者丨浩克匠心
研究方向丨基于深度學習的實時目標檢測
知乎專欄丨計算視覺與深度學習的小屋
YOLOv3的前世今生
2015 年,R-CNN 橫空出世,目標檢測 DL 世代大幕拉開。
各路豪杰快速迭代,陸續有了 SPP,fast,faster 版本,至 R-FCN,速度與精度齊飛,區域推薦類網絡大放異彩。
奈何,未達實時檢測之基準,難獲工業應用之青睞。
此時,憑速度之長,網格類檢測異軍突起,先有 YOLO,繼而 SSD,更是摘實時檢測之桂冠,與區域推薦類二分天下。然準確率卻時遭世人詬病。
遂有 JR 一鼓作氣,并 coco,推 v2,增加輸出類別,成就 9000。此后一年,作者隱遁江湖,逍遙 twitter。偶獲靈感,終推 v3,橫掃武林!
準確率不再是短板
自從 YOLO 誕生之日起,它就被貼上了兩個標簽:
速度很快
不擅長檢測小物體
而后者,成為了很多人對它望而卻步的原因。
由于原理上的限制,YOLO 僅檢測最后一層卷積輸出層,小物體像素少,經過層層卷積,在這一層上的信息幾乎體現不出來,導致難以識別。
YOLOv3 在這部分提升明顯,先看看小物體的識別。
▲?YOLOv3的識別結果
直觀地看下和 YOLOv2 的對比圖如下。可以看出,對于小物體的識別,提高非常明顯。
無論是傳統的模式識別圖像檢測,還是基于 CNN 的視覺檢測,對于緊湊密集或者高度重疊目標的檢測通常是非常困難的。比如對合影的人群檢測在 YOLOv2 上的結果:
而下面是 v3 的結果
一次檢測到圖中 90% 的人,還增加了 tie(領帶)這個新類別,非常驚艷!
再看看模型的泛化能力如何:
骷髏并不在訓練數據集中,但是通過訓練模型強大的泛化能力,自動將其歸類到了人類(也算是最為合理的近似處理了)。
這在 YOLOv2 中是檢測不到的。
那么,模型泛化能力很強的副作用,就是分類結果跑偏,比如下面這張 coser 的識別圖,最左側的人識別成了馬:
訓練和檢測都很快
論文中做了詳盡的對比。?
和前輩們比,YOLO 的速度非常快,比 R-CNN 快 1000 倍,比 Fast R-CNN 快 100 倍。?
和同輩們比,YOLOv3-608 檢測準確率比 DSSD 更高,接近 FPN,但是檢測時間卻只用了后面兩者的三分之一不到。?
原因如論文中所說,它在測試時觀察整張圖像,預測會由圖像中的全局上下文(global context)引導。它還通過單一網絡評估做出預測,而不像 R-CNN 這種系統,一張圖就需要成千上萬次預測。
用了哪些黑科技?
1. 多級預測
終于為 YOLO 增加了 top down 的多級預測,解決了 YOLO 顆粒度粗,對小目標無力的問題。
v2 只有一個 detection,v3 一下變成了 3 個,分別是一個下采樣的,feature map 為 13*13,還有 2 個上采樣的 eltwise sum,feature map 為 26*26,52*52,也就是說 v3 的 416 版本已經用到了 52 的 feature map,而 v2 把多尺度考慮到訓練的 data 采樣上,最后也只是用到了 13 的 feature map,這應該是對小目標影響最大的地方。
在論文中從單層預測五種 boundingbox 變成每層 3 種 boundongbox。
2.?loss不同
作者 v3 替換了 v2 的 softmax loss 變成 logistic loss,由于每個點所對應的 bounding box 少并且差異大,每個 bounding 與 ground truth 的 matching 策略變成了 1 對 1。
當預測的目標類別很復雜的時候,采用 logistic regression 進行分類是更有效的,比如在 Open Images Dataset 數據集進行分類。
在這個數據集中,會有很多重疊的標簽,比如女人、人,如果使用 softmax 則意味著每個候選框只對應著一個類別,但是實際上并不總是這樣。復合標簽的方法能對數據進行更好的建模。
3. 加深網絡
采用簡化的 residual block 取代了原來 1×1 和 3×3 的 block(其實就是加了一個 shortcut,也是網絡加深必然所要采取的手段)。
這和上一點是有關系的,v2 的 darknet-19 變成了 v3 的 darknet-53,為啥呢?就是需要上采樣啊,卷積層的數量自然就多了,另外作者還是用了一連串的 3*3、1*1 卷積,3*3 的卷積增加 channel,而 1*1 的卷積在于壓縮 3*3 卷積后的特征表示。
4. Router
由于 top down 的多級預測,進而改變了 router(或者說 concatenate)時的方式,將原來詭異的 reorg 改成了 upsample。
下一代YOLO長啥樣?
1. mAP 會繼續提高:隨著模型訓練越來越高效,神經網絡層級的不斷加深,信息抽象能力的不斷提高,以及一些小的修修補補,未來的目標檢測應用mAP會不斷提升。?
2. 實時檢測會成為標配:目前所謂的“實時”,工業界是不認可的。為什么呢,因為學術圈的人,驗證模型都是建立在 TitanX 或者 Tesla 這類強大的獨立顯卡上,而實際的潛在應用場景中,例如無人機/掃地/服務機器人/視頻監控等,是不會配備這些“重型裝備”的。所以,在嵌入式設備中,如 FPGA,輕量級 CPU 上,能達到的實時,才是貨真價實的。?
3. 模型小型化成為重要分支:類似于 tiny YOLO 的模型分支會受到更多關注。模型的小型化是應用到嵌入式設備的重要前提。而物聯網機器人無人機等領域還是以嵌入式設備為主的。模型剪枝/二值化/權值共享等手段會更廣泛的使用。
說點題外話
YOLO 讓人聯想到龍珠里的沙魯(cell),不斷吸收同化對手,進化自己,提升戰斗力:YOLOv1 吸收了 SSD 的長處(加了 BN 層,擴大輸入維度,使用了 Anchor,訓練的時候數據增強),進化到了 YOLOv2;?
吸收 DSSD 和 FPN 的長處,仿 ResNet 的 Darknet-53,仿 SqueezeNet 的縱橫交叉網絡,又進化到 YOLO 第三形態。?
但是,我相信這一定不是最終形態。讓我們拭目以待吧!
YOLOv3實景大片兒
這周忙里偷閑,把 darknet 的代碼擼了一遍,里面有趣的東西很多。
能看出來作者是有野心的,YOLO 不只是一個目標檢測應用,它還是一個完全基于 C 語言的通用神經網絡架構,以及很多以此為基礎的深度學習應用,比如基于 RNN 的莎士比亞戲劇劇本自動生成器:
基于策略網絡的 darknet 版阿法狗(DarkGo):
基于 GAN 的 darknet 版 Deep Dream(Nightmare):
挑戰 SqueezeNet 的壓縮網絡 TinyYOLO(Redmon 號稱后者比前者更快、小、準)等等。
當然,做得最好的還是目標檢測。darknet 自帶有視頻檢測,及網絡攝像頭實時視頻檢測。?
但是,目前網上介紹的 YOLO 的文章多是用的論文和 Github 工程自帶的 sample 圖片(dog,kite…),其實這不太公平。?
在源代碼基礎上加了一點保存視頻的代碼(代碼鏈接在文尾),生成了如下的視頻,看看當 Mr Bean 遇到 YOLO 會產生什么樣的化學反應!?
▲?YOLOv3效果展示
查看高清版視頻
https://zhuanlan.zhihu.com/p/36478097
注:本視頻基于 coco 數據集,YOLOv3 cfg 和 weights。檢測視頻沒有聲音,音軌是后加的。
存在一些識別錯誤,但是整體來說,亮點很多。
截取幾個瞬間
▲?性能提升最大的是小物體或者遠處的物體識別
▲?重疊遮擋物體的識別
▲?運動模糊物體的識別
▲?高密度汽車的識別
▲?密集人群識別
相關鏈接
[1].?論文
https://pjreddie.com/media/files/papers/YOLOv3.pdf
[2]. 翻譯
https://zhuanlan.zhihu.com/p/34945787
[3]. 代碼
https://github.com/pjreddie/darknet
[4]. 官網
https://pjreddie.com/darknet/yolo/
[5]. YouTube
https://www.youtube.com/watch?v=MPU2HistivI
[6]. 舊版
https://pjreddie.com/darknet/yolov2/
https://pjreddie.com/darknet/yolov1/
[7]. 源碼分享
https://github.com/muyiguangda/darknet
[8]. YOLOv3在Windows下的配置(無GPU)
https://blog.csdn.net/baidu_36669549/article/details/79798587
點擊以下標題查看其他文章:?
自適應注意力機制在Image Caption中的應用
CVPR 2018值得一看的25篇論文,都在這里了
視覺跟蹤之端到端的光流相關濾波
Wasserstein距離在生成模型中的應用
深度學習在CTR預估中的應用
▲?戳我查看招募詳情
#作 者 招 募#
讓你的文字被很多很多人看到,喜歡我們不如加入我們
關于PaperWeekly
PaperWeekly 是一個推薦、解讀、討論、報道人工智能前沿論文成果的學術平臺。如果你研究或從事 AI 領域,歡迎在公眾號后臺點擊「交流群」,小助手將把你帶入 PaperWeekly 的交流群里。
▽ 點擊 |?閱讀原文?| 進入作者知乎專欄
總結
以上是生活随笔為你收集整理的进击的YOLOv3,目标检测网络的巅峰之作 | 内附实景大片的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 线下报名 | NVIDIA JETSON
- 下一篇: 等你Battle!——11万个真实场景配