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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深度學習改變的五大計算機視覺技術

新機器視覺 ? 來源:YXQ ? 2019-07-05 09:51 ? 次閱讀

摘要:本文主要介紹計算機視覺中主要的五大技術,分別為圖像分類、目標檢測、目標跟蹤、語義分割以及實例分割。針對每項技術都給出了基本概念及相應的典型方法,簡單通俗、適合閱讀。

計算機視覺是當前最熱門的研究之一,是一門多學科交叉的研究,涵蓋計算機科學(圖形學、算法、理論研究等)、數(shù)學(信息檢索、機器學習)、工程(機器人、NLP等)、生物學(神經(jīng)系統(tǒng)科學)和心理學(認知科學)。由于計算機視覺表示對視覺環(huán)境及背景的相對理解,很多科學家相信,這一領域的研究將為人工智能行業(yè)的發(fā)展奠定基礎。

那么,什么是計算機視覺呢?下面是一些公認的定義:

1.從圖像中清晰地、有意義地描述物理對象的結構(Ballard & Brown,1982);

2.由一個或多個數(shù)字圖像計算立體世界的性質(Trucco & Verri,1998);

3.基于遙感圖像對真實物體和場景做出有用的決定(Sockman & Shapiro,2001);

那么,為什么研究計算機視覺呢?答案很明顯,從該領域可以衍生出一系列的應用程序,比如:

1.人臉識別:人臉檢測算法,能夠從照片中認出某人的身份;

2.圖像檢索:類似于谷歌圖像使用基于內容的查詢來搜索相關圖像,算法返回與3.查詢內容最佳匹配的圖像。

4.游戲和控制:體感游戲;

5.監(jiān)控:公共場所隨處可見的監(jiān)控攝像機,用來監(jiān)視可疑行為;

6.生物識別技術:指紋、虹膜和人臉匹配是生物特征識別中常用的方法;

7.智能汽車:視覺仍然是觀察交通標志、信號燈及其它視覺特征的主要信息來源;

正如斯坦福大學公開課CS231所言,計算機視覺任務大多是基于卷積神經(jīng)網(wǎng)絡完成。比如圖像分類、定位和檢測等。那么,對于計算機視覺而言,有哪些任務是占據(jù)主要地位并對世界有所影響的呢?本篇文章將分享給讀者5種重要的計算機視覺技術,以及其相關的深度學習模型和應用程序。相信這5種技術能夠改變你對世界的看法。

1.圖像分類

圖像分類這一任務在我們的日常生活中經(jīng)常發(fā)生,我們習慣了于此便不以為然。每天早上洗漱刷牙需要拿牙刷、毛巾等生活用品,如何準確的拿到這些用品便是一個圖像分類任務。官方定義為:給定一組圖像集,其中每張圖像都被標記了對應的類別。之后為一組新的測試圖像集預測其標簽類別,并測量預測準確性。

如何編寫一個可以將圖像分類的算法呢?計算機視覺研究人員已經(jīng)提出了一種數(shù)據(jù)驅動的方法來解決這個問題。研究人員在代碼中不再關心圖像如何表達,而是為計算機提供許多很多圖像(包含每個類別),之后開發(fā)學習算法,讓計算機自己學習這些圖像的特征,之后根據(jù)學到的特征對圖像進行分類。

鑒于此,完整的圖像分類步驟一般形式如下:

1.首先,輸入一組訓練圖像數(shù)據(jù)集;

2.然后,使用該訓練集訓練一個分類器,該分類器能夠學習每個類別的特征;

3.最后,使用測試集來評估分類器的性能,即將預測出的結果與真實類別標記進行比較;

對于圖像分類而言,最受歡迎的方法是卷積神經(jīng)網(wǎng)絡(CNN)。CNN是深度學習中的一種常用方法,其性能遠超一般的機器學習算法。CNN網(wǎng)絡結構基本是由卷積層、池化層以及全連接層組成,其中,卷積層被認為是提取圖像特征的主要部件,它類似于一個“掃描儀”,通過卷積核與圖像像素矩陣進行卷積運算,每次只“掃描”卷積核大小的尺寸,之后滑動到下一個區(qū)域進行相關的運算,這種計算叫作滑動窗口。

從圖中可以看到,輸入圖像送入卷積神經(jīng)網(wǎng)絡中,通過卷積層進行特征提取,之后通過池化層過濾細節(jié)(一般采用最大值池化、平均池化),最后在全連接層進行特征展開,送入相應的分類器得到其分類結果。

大多數(shù)圖像分類算法都是在ImageNet數(shù)據(jù)集上訓練的,該數(shù)據(jù)集由120萬張的圖像組成,涵蓋1000個類別,該數(shù)據(jù)集也可以稱作改變人工智能和世界的數(shù)據(jù)集。ImagNet 數(shù)據(jù)集讓人們意識到,構建優(yōu)良數(shù)據(jù)集的工作是 AI 研究的核心,數(shù)據(jù)和算法一樣至關重要。為此,世界組織也舉辦了針對該數(shù)據(jù)集的挑戰(zhàn)賽——ImageNet挑戰(zhàn)賽。

第一屆ImageNet挑戰(zhàn)賽的第一名是由Alex Krizhevsky(NIPS 2012)獲得,采用的方法是深層卷積神經(jīng)網(wǎng)絡,網(wǎng)絡結構如下圖所示。在該模型中,采用了一些技巧,比如最大值池化、線性修正單元激活函數(shù)ReLU以及使用GPU仿真計算等,AlexNet模型拉開了深度學習研究的序幕。

自從AlexNet網(wǎng)絡模型贏得比賽之后,有很多基于CNN的算法也在ImageNet上取得了特別好的成績,比如ZFNet(2013)、GoogleNet(2014)、VGGNet(2014)、ResNet(2015)以及DenseNet(2016)等。

2.目標檢測

目標檢測通常是從圖像中輸出單個目標的Bounding Box(邊框)以及標簽。比如,在汽車檢測中,必須使用邊框檢測出給定圖像中的所有車輛。

之前在圖像分類任務中大放光彩的CNN同樣也可以應用于此。第一個高效模型是R-CNN(基于區(qū)域的卷積神經(jīng)網(wǎng)絡),如下圖所示。在該網(wǎng)絡中,首先掃描圖像并使用搜索算法生成可能區(qū)域,之后對每個可能區(qū)域運行CNN,最后將每個CNN網(wǎng)絡的輸出送入SVM分類器中來對區(qū)域進行分類和線性回歸,并用邊框標注目標。

本質上,是將物體檢測轉換成圖像分類問題。但該方法存在一些問題,比如訓練速度慢,耗費內存、預測時間長等。

為了解決上述這些問題,Ross Girshickyou提出Fast R-CNN算法,從兩個方面提升了檢測速度:

1)在給出建議區(qū)域之前執(zhí)行特征提取,從而只需在整幅圖像上運行一次CNN;2)使用Softmax分類器代替SVM分類器;

雖然Fast R-CNN在速度方面有所提升,然而,選擇搜索算法仍然需要大量的時間來生成建議區(qū)域。為此又提出了Faster R-CNN算法,該模型提出了候選區(qū)域生成網(wǎng)絡(RPN),用來代替選擇搜索算法,將所有內容整合在一個網(wǎng)絡中,大大提高了檢測速度和精度。

近年來,目標檢測研究趨勢主要向更快、更有效的檢測系統(tǒng)發(fā)展。目前已經(jīng)有一些其它的方法可供使用,比如YOLO、SSD以及R-FCN等。

3.目標跟蹤

目標跟蹤是指在給定場景中跟蹤感興趣的具體對象或多個對象的過程。簡單來說,給出目標在跟蹤視頻第一幀中的初始狀態(tài)(如位置、尺寸),自動估計目標物體在后續(xù)幀中的狀態(tài)。該技術對自動駕駛汽車等領域顯得至關重要。

根據(jù)觀察模型,目標跟蹤可以分為兩類:產(chǎn)生式(generative method)和判別式(discriminative method)。其中,產(chǎn)生式方法主要運用生成模型描述目標的表觀特征,之后通過搜索候選目標來最小化重構誤差。常用的算法有稀疏編碼(sparse coding)、主成分分析(PCA)等。與之相對的,判別式方法通過訓練分類器來區(qū)分目標和背景,其性能更為穩(wěn)定,逐漸成為目標跟蹤這一領域的主要研究方法。常用的算法有堆棧自動編碼器(SAE)、卷積神經(jīng)網(wǎng)絡(CNN)等。

使用SAE方法進行目標跟蹤的最經(jīng)典深層網(wǎng)絡是Deep Learning Tracker(DLT),提出了離線預訓練和在線微調。該方法的主要步驟如下:

1.先使用棧式自動編碼器(SDAE)在大規(guī)模自然圖像數(shù)據(jù)集上進行無監(jiān)督離線預訓練來獲得通用的物體表征能力。

2.將預訓練網(wǎng)絡的編碼部分與分類器相結合組成分類網(wǎng)絡,然后利用從初始幀獲得的正、負樣本對網(wǎng)絡進行微調,使其可以區(qū)分當前對象和背景。在跟蹤過程中,選擇分類網(wǎng)絡輸出得分最大的patch作為最終預測目標。

3.模型更新策略采用限定閾值的方法。

基于CNN完成目標跟蹤的典型算法是FCNT和MD Net。

FCNT的亮點之一在于對ImageNet上預訓練得到的CNN特征在目標跟蹤任務上的性能做了深入的分析:

1.CNN的特征圖可以用來做跟蹤目標的定位;

2.CNN的許多特征圖存在噪聲或者和物體跟蹤區(qū)分目標和背景的任務關聯(lián)較小;

3.CNN不同層提取的特征不一樣。高層特征更加抽象,擅長區(qū)分不同類別的物體,而低層特征更加關注目標的局部細節(jié)。

基于以上觀察,F(xiàn)CNT最終提出了如下圖所示的模型結構:

1.對于Conv4-3和Con5-3采用VGG網(wǎng)絡的結構,選出和當前跟蹤目標最相關的特征圖通道;

2.為了避免過擬合,對篩選出的Conv5-3和Conv4-3特征分別構建捕捉類別信息GNet和SNet;

3.在第一幀中使用給出的邊框生成熱度圖(heap map)回歸訓練SNet和GNet;

4.對于每一幀,其預測結果為中心裁剪區(qū)域,將其分別輸入GNet和SNet中,得到兩個預測的熱圖,并根據(jù)是否有干擾來決定使用哪個熱圖。

區(qū)別與FCNT,MD Net使用視頻中所有序列來跟蹤它們的運動。但序列訓練也存在問題,即不同跟蹤序列與跟蹤目標完全不一樣。最終MD Net提出多域的訓練思想,網(wǎng)絡結構如下圖所示,該網(wǎng)絡分為兩個部分:共享層和分類層。網(wǎng)絡結構部分用于提取特征,最后分類層區(qū)分不同的類別。

4.語義分割

計算機視覺的核心是分割過程,它將整個圖像分成像素組,然后對其進行標記和分類。語言分割試圖在語義上理解圖像中每個像素的角色(例如,汽車、摩托車等)。

CNN同樣在此項任務中展現(xiàn)了其優(yōu)異的性能。典型的方法是FCN,結構如下圖所示。FCN模型輸入一幅圖像后直接在輸出端得到密度預測,即每個像素所屬的類別,從而得到一個端到端的方法來實現(xiàn)圖像語義分割。

與FCN上采樣不同,SegNet將最大池化轉移至解碼器中,改善了分割分辨率。提升了內存的使用效率。

還有一些其他的方法,比如全卷積網(wǎng)絡、擴展卷積,DeepLab以及RefineNet等。

5.實例分割

除了語義分割之外,實例分割還分割了不同的類實例,例如用5種不同顏色標記5輛汽車。在分類中,通常有一個以一個物體為焦點的圖像,任務是說出這個圖像是什么。但是為了分割實例,我們需要執(zhí)行更復雜的任務。我們看到復雜的景象,有多個重疊的物體和日常背景,我們不僅對這些日常物體進行分類,而且還確定它們的邊界、差異和彼此之間的關系。

到目前為止,我們已經(jīng)看到了如何以許多有趣的方式使用CNN功能來在帶有邊界框的圖像中有效地定位日常用品。我們可以擴展這些技術來定位每個對象的精確像素,而不僅僅是邊界框嗎?

CNN在此項任務中同樣表現(xiàn)優(yōu)異,典型算法是Mask R-CNN。Mask R-CNN在Faster R-CNN的基礎上添加了一個分支以輸出二元掩膜。該分支與現(xiàn)有的分類和邊框回歸并行,如下圖所示:

Faster-RCNN在實例分割任務中表現(xiàn)不好,為了修正其缺點,Mask R-CNN提出了RolAlign層,通過調整Rolpool來提升精度。從本質上講,RolAlign使用雙線性插值避免了取整誤差,該誤差導致檢測和分割不準確。

一旦掩膜被生成,Mask R-CNN結合分類器和邊框就能產(chǎn)生非常精準的分割:

結論

以上五種計算機視覺技術可以幫助計算機從單個或一系列圖像中提取、分析和理解有用信息。此外,還有很多其它的先進技術等待我們的探索,比如風格轉換、動作識別等。希望本文能夠引導你改變看待這個世界的方式。

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

    關注

    8

    文章

    1685

    瀏覽量

    45811
  • 深度學習
    +關注

    關注

    73

    文章

    5422

    瀏覽量

    120587

原文標題:一文看懂深度學習改變的五大計算機視覺技術

文章出處:【微信號:vision263com,微信公眾號:新機器視覺】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    計算機視覺有哪些優(yōu)缺點

    計算機視覺作為人工智能領域的一個重要分支,旨在使計算機能夠像人類一樣理解和解釋圖像和視頻中的信息。這一技術的發(fā)展不僅推動了多個行業(yè)的變革,也帶來了諸多優(yōu)勢,但同時也伴隨著一些挑戰(zhàn)和局限
    的頭像 發(fā)表于 08-14 09:49 ?281次閱讀

    計算機視覺技術的AI算法模型

    計算機視覺技術作為人工智能領域的一個重要分支,旨在使計算機能夠像人類一樣理解和解釋圖像及視頻中的信息。為了實現(xiàn)這一目標,計算機
    的頭像 發(fā)表于 07-24 12:46 ?355次閱讀

    機器視覺計算機視覺有什么區(qū)別

    機器視覺計算機視覺是兩個密切相關但又有所區(qū)別的概念。 一、定義 機器視覺 機器視覺,又稱為計算機
    的頭像 發(fā)表于 07-16 10:23 ?280次閱讀

    計算機視覺五大技術

    計算機視覺作為深度學習領域最熱門的研究方向之一,其技術涵蓋了多個方面,為人工智能的發(fā)展開拓了廣闊的道路。以下是對
    的頭像 發(fā)表于 07-10 18:26 ?901次閱讀

    計算機視覺的工作原理和應用

    圖像和視頻中提取有用信息,進而進行決策和行動。自1960年代第一批學術論文問世以來,計算機視覺技術已經(jīng)取得了長足的發(fā)展,并在多個領域展現(xiàn)出巨大的應用潛力和價值。
    的頭像 發(fā)表于 07-10 18:24 ?1058次閱讀

    計算機視覺與人工智能的關系是什么

    引言 計算機視覺是一門研究如何使計算機能夠理解和解釋視覺信息的學科。它涉及到圖像處理、模式識別、機器學習等多個領域的知識。人工智能則是研究如
    的頭像 發(fā)表于 07-09 09:25 ?306次閱讀

    計算機視覺與智能感知是干嘛的

    引言 計算機視覺(Computer Vision)是一門研究如何使計算機能夠理解和解釋視覺信息的學科。它涉及到圖像處理、模式識別、機器學習
    的頭像 發(fā)表于 07-09 09:23 ?348次閱讀

    計算機視覺和機器視覺區(qū)別在哪

    計算機視覺和機器視覺是兩個密切相關但又有明顯區(qū)別的領域。 一、定義 計算機視覺 計算機
    的頭像 發(fā)表于 07-09 09:22 ?289次閱讀

    計算機視覺屬于人工智能嗎

    屬于,計算機視覺是人工智能領域的一個重要分支。 引言 計算機視覺是一門研究如何使計算機具有視覺
    的頭像 發(fā)表于 07-09 09:11 ?544次閱讀

    深度學習計算機視覺領域的應用

    隨著人工智能技術的飛速發(fā)展,深度學習作為其中的核心技術之一,已經(jīng)在計算機視覺領域取得了顯著的成果
    的頭像 發(fā)表于 07-01 11:38 ?426次閱讀

    計算機視覺的主要研究方向

    計算機視覺(Computer Vision, CV)作為人工智能領域的一個重要分支,致力于使計算機能夠像人眼一樣理解和解釋圖像和視頻中的信息。隨著深度
    的頭像 發(fā)表于 06-06 17:17 ?516次閱讀

    計算機視覺的十大算法

    視覺技術的發(fā)展起到了重要的推動作用。一、圖像分割算法圖像分割算法是計算機視覺領域的基礎算法之一,它的主要任務是將圖像分割成不同的區(qū)域或對象。常見的圖像分割算法包括基
    的頭像 發(fā)表于 02-19 13:26 ?1045次閱讀
    <b class='flag-5'>計算機</b><b class='flag-5'>視覺</b>的十大算法

    什么是計算機視覺?計算機視覺的三種方法

    計算機視覺是指通過為計算機賦予人類視覺這一技術目標,從而賦能裝配線檢查到駕駛輔助和機器人等應用。計算機
    的頭像 發(fā)表于 11-16 16:38 ?4159次閱讀
    什么是<b class='flag-5'>計算機</b><b class='flag-5'>視覺</b>?<b class='flag-5'>計算機</b><b class='flag-5'>視覺</b>的三種方法

    最適合AI應用的計算機視覺類型是什么?

    計算機視覺是指為計算機賦予人類視覺這一技術目標,從而賦能裝配線檢查到駕駛輔助和機器人等應用。計算機
    的頭像 發(fā)表于 11-15 16:38 ?344次閱讀
    最適合AI應用的<b class='flag-5'>計算機</b><b class='flag-5'>視覺</b>類型是什么?

    用于計算機視覺的經(jīng)典機器學習應用分析

    深度學習是指在大部分未處理或“原始”數(shù)據(jù)上運行的非常大的神經(jīng)網(wǎng)絡模型。深度學習通過將特征提取操作拉入模型本身,對計算機
    發(fā)表于 11-07 10:11 ?337次閱讀
    用于<b class='flag-5'>計算機</b><b class='flag-5'>視覺</b>的經(jīng)典機器<b class='flag-5'>學習</b>應用分析