精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

FPGA做圖像處理關鍵優勢是:能進行實時流水線運算

FPGA開源工作室 ? 來源:陳年麗 ? 2019-07-19 09:47 ? 次閱讀

本人有過多年用FPGA做圖像處理的經驗,在此也談一下自己的看法。用FPGA做圖像處理最關鍵的一點優勢就是:FPGA能進行實時流水線運算,能達到最高的實時性。因此在一些對實時性要求非常高的應用領域,做圖像處理基本就只能用FPGA。例如在一些分選設備中圖像處理基本上用的都是FPGA,因為在其中相機從看到物料圖像到給出執行指令之間的延時大概只有幾毫秒,這就要求圖像處理必須很快且延時固定,只有FPGA進行的實時流水線運算才能滿足這一要求。

圖1 FPGA實現圖像的流水處理

所以要了解FPGA進行圖像處理的優勢就必須理解FPGA所能進行的實時流水線運算和DSPGPU等進行的圖像處理運算有何不同。DSP,GPU,CPU對圖像的處理基本是以幀為單位的,從相機采集的圖像數據會先存在內存中,然后GPU會讀取內存中的圖像數據進行處理。假如采集圖像的幀率是30幀,那么DSP,GPU要是能在1/30秒內完成一幀圖像的處理,那基本上就能算是實時處理。

FPGA對圖像進行實時流水線運算是以行為單位的。FPGA可以直接和圖像傳感器芯片連接獲得圖像數據流,如果是RAW格式的則還可以進行插值以獲得RGB圖像數據。FPGA能進行實時流水線處理的關鍵是它可以用其內部的Block Ram緩存若干行的圖像數據。這個Block Ram可以說是類似于CPU里面的Cache,但Cache不是你能完全控制的,但Block Ram是完全可控的,可以用它實現各種靈活的運算處理。這樣FPGA通過緩存若干行圖像數據就可以對圖像進行實時處理,數據就這樣一邊流過就一邊處理好了,不需要送入DDR緩存了之后再讀出來處理。

這樣的數據流處理顯然是順序讀取數據的,那么也就只能實現那些順序讀取數據的算法,也就是圖像處理中那一大類用3x3到NxN的算子進行的濾波、取邊緣、膨脹腐蝕等算法。可能大家會覺得這些運算似乎都是最基本的圖像處理運算,只是個前端的預處理,似乎用處不大。但問題是只有FPGA做這樣的運算才是速度最快效率最高的,比如用CPU做一個取邊緣的算法根本就達不到實時。另外別小看了這種NxN算子法,它可以有各種組合和玩法,可以實現分選多種顏色,甚至分辨簡單形狀等功能。FPGA進行的這種算子法處理是并行流水線算法,其延時是固定的,比如用3x3的算子進行處理其給出結果的延時是兩行圖像的時間。還有這個算子法和現在卷積神經網絡中最前面的卷積層運算是類似的。

圖2 FPGA對圖像做n行緩存輸出

FPGA中的Block Ram是重要和稀缺資源,能緩存的圖像數據行數是有限的,所以這個NxN的算子中的N不能特別大。當然FPGA也可以接DDR把圖像緩存到其中再讀出來進行處理,但這種處理模式就和CPU差不多了,達不到最高的實時性。其實有些我們認為需要隨機讀取數據的圖像處理算法也是可以并行流水線化的,比如連通域識別。《FPGA實現的連通域識別算法升級》這是我的一篇文章。

現在貌似神經網絡也可以用FPGA來實現,并且據說效率比較高。我暫時還沒玩過這個,但知道為什么FPGA在進行某些運算的時候效率會比較高。因為在密集運算中,耽誤時間和消耗功耗的操作往往不是運算本身,而是把數據從內存中搬來搬去。GPU,CPU在進行運算時要把數據從內存中取出來,算好了在放回去。這樣內存帶寬往往成了運算速度的瓶頸,數據搬運過程中的功耗占的比重也不會小。FPGA則可以通過堆很多計算硬件的方法把要做的運算都展開,然后數據從中流過,完成一個階段的運算之后就直接流入第二個階段,不需要把一個計算階段完成后的數據再送回內存中,再讀出來交給下一個階段的運算。這樣就會節省很多時間和功耗。現在用FPGA做圖像處理就是這樣干的,比如先用一個3x3的算子進行濾波,再用一個3x3的算子進行取邊緣,在FPGA流水線算法中,濾波處理完了數據立即就會進行取邊緣處理,是不需要像CPU那樣存回內存再讀出來的。

圖3 簡單的神經網絡

綜上所述,我覺得用FPGA進行圖像處理的前景還是挺廣闊的,越來越多的工業應用場合都要求更高的實時性,而這正是FPGA所適合的。還有機器學習領域,神經網絡這種層狀的,不需要很隨機的讀取數據的運算是比較適合用FPGA來做的。不過FPGA不擅長浮點運算,如果能整出不需要浮點運算的神經網絡,那么FPGA在這方面的應用將會更大。

FPGA圖像處理視頻欣賞

可能制約FPGA在這些方面應用的關鍵還是人才的缺乏。大家不知道FPGA擅長什么,想用卻又不知道怎么用。網上很多傳說都說這個FPGA編程很底層,很不好用。這些說法也對也不對。剛開始學的時候是會有一些困惑。關鍵是這其中要經歷一個思維方式的轉變,從CPU編程思維到硬件編程思維的轉變。轉變過來了之后就會發現,其實FPGA還是很單純很靈活很好用的,硬件描述語言沒有高級語言那么復雜。

圖4 FPGA圖像處理辦法的多樣化

總結:近年來隨著半導體的工藝不斷提升,FPGA自身的各種資源容量在不斷地提升的同時也出現了一些異構架構的FPGA豐富了FPGA圖像處理的方法。

HLS的出現使FPGA開發走向高級語言,也變的更為簡單。有一些公司用新的技術快速開發出有圖像識別功能的設備。由于FPGA開發慢、成本高、可重復配置、有點門檻等等特點,它能夠在DSP、單片機ASIC之間分一杯羹。應用領域主要在量不大、可定制、可升級、成本不敏感的地方,比如軍工、醫療、安防。單位主要是科研院所、醫療設備公司、安防設備、視頻傳輸拼接設備公司。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 傳感器芯片
    +關注

    關注

    6

    文章

    205

    瀏覽量

    23778
  • 流水線
    +關注

    關注

    0

    文章

    119

    瀏覽量

    25619

原文標題:FPGA圖像處理的前景如何?

文章出處:【微信號:leezym0317,微信公眾號:FPGA開源工作室】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    FPGA設計經驗之圖像處理

    優勢關鍵的就是:FPGA能進行實時流水線運算,能達
    發表于 06-12 16:26

    FPGA圖像處理領域的優勢有哪些?

    等協同工作,實現高效的圖像處理。這種多接口支持使得FPGA在構建復雜的圖像處理系統時具有更大的靈活性。 七、
    發表于 10-09 14:36

    FPGA中的流水線設計

    `流水線設計前言:本文從四部分對流水線設計進行分析,具體如下:第一部分什么是流水線第二部分什么時候用流水線設計第三部分使用
    發表于 10-26 14:38

    薦讀:FPGA設計經驗之圖像處理

    的可以參考一下,歡迎一起交流學習。話不多說,上貨。 使用FPGA圖像處理優勢關鍵
    發表于 06-08 15:55

    FPGA重要設計思想及工程應用之流水線

    FPGA重要設計思想及工程應用之流水線流水線設計是高速電路設計中的一 個常用設計手段。如果某個設計的處理流程分為若干步驟,而且整個數據處理
    發表于 02-09 11:02 ?52次下載

    什么是流水線技術

    什么是流水線技術 流水線技術
    發表于 02-04 10:21 ?3916次閱讀

    如何快速地創建圖像處理流水線實時檢測運動物體

    這段視頻中,我們將向您演示如何快速地創建一個簡單的圖像處理流水線實時檢測運動物體。把運動物體邊緣勾勒并實時地插入到視頻流中,視頻幀速是10
    的頭像 發表于 11-27 06:07 ?2597次閱讀

    關于利用FPGA圖像處理的相關知識盤點

    FPGA圖像處理關鍵的一點優勢就是:FPGA
    發表于 02-14 14:33 ?1308次閱讀

    FPGA進行圖像處理的前景廣闊 應用將會越來越大

    FPGA圖像處理關鍵的一點優勢就是:FPGA
    發表于 03-20 16:28 ?2327次閱讀

    FPGA流水線練習5:設計思路

    流水線的工作方式就象工業生產上的裝配流水線。在CPU中由5—6個不同功能的電路單元組成一條指令處理流水線,然后將一條X86指令分成5—6步后再由這些電路單元分別執行,這樣就能實現在一個
    的頭像 發表于 11-29 07:06 ?2563次閱讀

    FPGA之為什么要進行流水線的設計

    流水線又稱為裝配線,一種工業上的生產方式,指每一個生產單位只專注處理某一個片段的工作。以提高工作效率及產量;按照流水線的輸送方式大體可以分為:皮帶流水裝配線、板鏈線、倍速鏈、插件線、網
    的頭像 發表于 11-28 07:04 ?3587次閱讀

    各種流水線特點及常見流水線設計方式

    按照流水線的輸送方式大體可以分為:皮帶流水裝配線、板鏈線、倍速鏈、插件線、網帶線、懸掛線及滾筒流水線這七類流水線
    的頭像 發表于 07-05 11:12 ?7252次閱讀
    各種<b class='flag-5'>流水線</b>特點及常見<b class='flag-5'>流水線</b>設計方式

    嵌入式_流水線

    流水線一、定義流水線是指在程序執行時多條指令重疊進行操作的一種準并行處理實現技術。各種部件同時處理是針對不同指令而言的,他們可同時為多條指令
    發表于 10-20 20:51 ?6次下載
    嵌入式_<b class='flag-5'>流水線</b>

    FPGA流水線的原因和方式

    本文解釋了流水線及其對 FPGA 的影響,即延遲、吞吐量、工作頻率的變化和資源利用率。
    的頭像 發表于 05-07 16:51 ?5976次閱讀
    <b class='flag-5'>FPGA</b>中<b class='flag-5'>流水線</b>的原因和方式

    什么是流水線 Jenkins的流水線詳解

    jenkins 有 2 種流水線分為聲明式流水線與腳本化流水線,腳本化流水線是 jenkins 舊版本使用的流水線腳本,新版本 Jenkin
    發表于 05-17 16:57 ?1049次閱讀