<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Xilinx FPGA/Zynq設(shè)計(jì)中使用HLS實(shí)現(xiàn)OpenCV的開發(fā)流程

          Xilinx FPGA/Zynq設(shè)計(jì)中使用HLS實(shí)現(xiàn)OpenCV的開發(fā)流程

          作者:郭豐收 時(shí)間:2014-02-26 來源:電子產(chǎn)品世界 收藏

            開源計(jì)算機(jī)視覺 () 被廣泛用于開發(fā)計(jì)算機(jī)視覺應(yīng)用,它包含2500多個(gè)優(yōu)化的視頻函數(shù)的函數(shù)庫并且專門針對臺式機(jī)處理器和GPU進(jìn)行優(yōu)化。Xilinx 高層次綜合工具能夠使用C/C++ 編寫的代碼直接創(chuàng)建RTL硬件,顯著提高設(shè)計(jì)生產(chǎn)力,同時(shí),Xilinx Zynq全可編程SoC系列器件嵌入雙核ARM Cortex-A9處理器將軟件可編程能力與FPGA的硬件可編程能力實(shí)現(xiàn)完美結(jié)合,以低功耗和低成本等系統(tǒng)優(yōu)勢實(shí)現(xiàn)單芯片高的系統(tǒng)性能、靈活性、可擴(kuò)展性,加速圖形處理產(chǎn)品設(shè)計(jì)上市時(shí)間。擁有成千上萬的用戶,而且的設(shè)計(jì)無需修改即可在Zynq器件的ARM處理器上運(yùn)行,但是利用OpenCV實(shí)現(xiàn)的高清處理經(jīng)常受外部存儲(chǔ)器的限制,尤其是存儲(chǔ)帶寬會(huì)成為性能瓶頸,存儲(chǔ)訪問也限制了功耗效率。使用Xilinx公司的高級語言綜合工具,可以輕松實(shí)現(xiàn)OpenCV C++視頻處理設(shè)計(jì)到RTL代碼的轉(zhuǎn)換,輸出Zynq的硬件加速器或者直接在FPGA上實(shí)現(xiàn)實(shí)時(shí)硬件視頻處理功能。同時(shí),Xilinx公司的Zynq All-programmable SoC是實(shí)現(xiàn)嵌入式計(jì)算機(jī)視覺應(yīng)用的好方法,解決了在單一處理器上實(shí)現(xiàn)視頻處理性能低功耗高的限制,Zynq高性能可編程邏輯和嵌入式ARM內(nèi)核,是一款性能功耗優(yōu)化的圖像處理集成式解決方案。

          本文引用地址:http://www.ex-cimer.com/article/233872.htm

            1 OpenCV中圖像IplImage, CvMat, Mat 類型的關(guān)系和中圖像hls::Mat類型

            OpenCV中常見的與圖像操作有關(guān)的數(shù)據(jù)容器有Mat,CvMat和IplImage,這三種類型都可以代表和顯示圖像,但是,Mat類型側(cè)重于計(jì)算,數(shù)學(xué)性較高。而CvMat和IplImage類型更側(cè)重于“圖像”,OpenCV對其中的圖像操作(縮放、單通道提取、圖像閾值操作等)進(jìn)行了優(yōu)化。

            1.1 OpenCV中的Mat矩陣類型

            在OpenCV中,Mat是一個(gè)多維的密集數(shù)據(jù)數(shù)組??梢杂脕硖幚硐蛄亢途仃?、圖像、直方圖等等常見的多維數(shù)據(jù)。

            Mat類型較CvMat與IplImage類型來說,有更強(qiáng)的矩陣運(yùn)算能力,支持常見的矩陣運(yùn)算。在計(jì)算密集型的應(yīng)用當(dāng)中,將CvMat與IplImage類型轉(zhuǎn)化為Mat類型將大大減少計(jì)算時(shí)間花費(fèi)。

            1.2 OpenCV中的CvMat與IplImage類型

            在openCV中,CvMat和IplImage類型更側(cè)重于“圖像”,尤其是對其中的圖像操作進(jìn)行一定程度的優(yōu)化。OpenCV沒有向量(vector)的數(shù)據(jù)結(jié)構(gòu),但當(dāng)我們要表示向量時(shí),需要用矩陣數(shù)據(jù)表示。但是,CvMat更抽象,它的元素?cái)?shù)據(jù)類型并不僅限于基礎(chǔ)數(shù)據(jù)類型,而且可以是任意的預(yù)定義數(shù)據(jù)類型,比如RGB或者別的多通道數(shù)據(jù)。

            在OpenCV類型關(guān)系上,我們可以說IplImage類型繼承自CvMat類型,當(dāng)然還包括其他的變量將之解析成圖像數(shù)據(jù)。IplImage類型較之CvMat多了很多參數(shù),比如depth和nChannels。IplImage對圖像的另一種優(yōu)化是變量origin原點(diǎn),為了彌補(bǔ)這一點(diǎn),OpenCV允許用戶定義自己的原點(diǎn)設(shè)置。

            1.3 VivadoHLS中圖像數(shù)據(jù)類型hls::Mat<>

            VivadoHLS視頻處理函數(shù)庫使用hls::Mat<>數(shù)據(jù)類型,這種類型用于模型化視頻像素流處理,實(shí)質(zhì)等同于hls::steam<>流的類型,而不是OpenCV中在外部memory中存儲(chǔ)的matrix矩陣類型。因此,在用VivadoHLS實(shí)現(xiàn)OpenCV的設(shè)計(jì)中,需要將輸入和輸出HLS可綜合的視頻設(shè)計(jì)接口,修改為Video stream接口,也就是采用HLS提供的video接口可綜合函數(shù),實(shí)現(xiàn)AXI4 video stream到VivadoHLS中hls::Mat<>類型的轉(zhuǎn)換。

            2 使用VivadoHLS實(shí)現(xiàn)OpenCV到RTL代碼轉(zhuǎn)換的流程

            2.1 OpenCV設(shè)計(jì)中的權(quán)衡

            OpenCV圖像處理是基于存儲(chǔ)器幀緩存而構(gòu)建的,它總是假設(shè)視頻frame數(shù)據(jù)存放在外部DDR 存儲(chǔ)器中,因此,OpenCV對于訪問局部圖像性能較差,因?yàn)樘幚砥鞯男∪萘扛咚倬彺嫘阅懿蛔阋酝瓿蛇@個(gè)任務(wù)。而且出于性能考慮,基于OpenCV設(shè)計(jì)的架構(gòu)比較復(fù)雜,功耗更高。在對分辨率或幀速率要求低,或者在更大的圖像中對需要的特征或區(qū)域進(jìn)行處理時(shí),OpenCV似乎足以滿足很多應(yīng)用的要求,但對于高分辨率高幀率實(shí)時(shí)處理的場景下,OpenCV很難滿足高性能和低功耗的需求。

            基于視頻流的架構(gòu)能提供高性能和低功耗,鏈條化的圖像處理函數(shù)減少了外部存儲(chǔ)器訪問,針對視頻優(yōu)化的行緩存和窗口緩存比處理器高速緩存更簡單高效,更易于使用VivadoHLS在FPGA部件中采用數(shù)據(jù)流優(yōu)化來實(shí)現(xiàn)。

            VivadoHLS對OpenCV的支持,不是指可以將OpenCV的函數(shù)庫直接綜合成RTL代碼,而是需要將代碼轉(zhuǎn)換為可綜合的代碼,這些可綜合的視頻庫稱為HLS視頻庫,由VivadoHLS提供。

            OpenCV函數(shù)不能直接通過HLS進(jìn)行綜合,因?yàn)镺penCV函數(shù)一般都包含動(dòng)態(tài)的內(nèi)存分配、浮點(diǎn)以及假設(shè)圖像在外部存儲(chǔ)器中存放或者修改。

            VivadoHLS視頻庫用于替換很多基本的OpenCV函數(shù),它與OpenCV具有相似的接口和算法,主要針對在FPGA架構(gòu)中實(shí)現(xiàn)的圖像處理函數(shù),包含了專門面向FPGA的優(yōu)化,比如定點(diǎn)運(yùn)算而非浮點(diǎn)運(yùn)算(不必精確到比特位),片上的行緩存(line buffer)和窗口緩存(window buffer)。圖2.1展示了在Xilinx Zynq AP SoC器件上實(shí)現(xiàn)視頻處理的系統(tǒng)結(jié)構(gòu)。

            2.2 在FPGA/Zynq開發(fā)中使用VivadoHLS實(shí)現(xiàn)OpenCV的設(shè)計(jì)流程

            設(shè)計(jì)開發(fā)流程主要有如圖2.2三個(gè)步驟。

            1. 在計(jì)算機(jī)上開發(fā)OpenCV應(yīng)用,由于是開源的設(shè)計(jì),采用C++的編譯器對其進(jìn)行編譯、仿真和debug,最后產(chǎn)生可執(zhí)行文件。這些設(shè)計(jì)無需修改即可在 ARM內(nèi)核上運(yùn)行OpenCV應(yīng)用。

            2.使用I/O函數(shù)抽取FPGA實(shí)現(xiàn)的部分,并且使用可綜合的VivadoHLS Video庫函數(shù)代碼代替OpenCV函數(shù)的調(diào)用。

            3.運(yùn)行HLS生成RTL代碼,在VivadoHLS工程中啟動(dòng)co-sim,HLS工具自動(dòng)重用OpenCV的測試激勵(lì)驗(yàn)證產(chǎn)生的RTL代碼。在Xilinx的ISE或者Vivado開發(fā)環(huán)境中做RTL的集成和SoC/FPGA實(shí)現(xiàn)。

            2.3 用HLS實(shí)現(xiàn)OpenCV應(yīng)用的實(shí)例(快速角點(diǎn)濾波器image_filter)

            我們通過快速角點(diǎn)的例子,說明通常用VivadoHLS實(shí)現(xiàn)OpenCV的流程。首先,開發(fā)基于OpenCV的快速角點(diǎn)算法設(shè)計(jì),并使用基于OpenCV的測試激勵(lì)仿真驗(yàn)證這個(gè)算法。接著,建立基于視頻數(shù)據(jù)流鏈的OpenCV處理算法,改寫前面OpenCV的通常設(shè)計(jì),這樣的改寫是為了與HLS視頻庫處理機(jī)制相同,方便后面步驟的函數(shù)替換。最后,將改寫的OpenCV設(shè)計(jì)中的函數(shù),替換為HLS提供的相應(yīng)功能的視頻函數(shù),并使用VivadoHLS綜合,在Xilinx開發(fā)環(huán)境下在FPGA可編程邏輯或作為Zynq SoC硬件加速器實(shí)現(xiàn)。當(dāng)然,這些可綜合代碼也可在處理器或ARM上運(yùn)行。

            3 VHLS實(shí)現(xiàn)OpenCV設(shè)計(jì)流程總結(jié)

            OpenCV函數(shù)可實(shí)現(xiàn)計(jì)算機(jī)視覺算法的快速原型設(shè)計(jì),并使用VivadoHLS工具轉(zhuǎn)換為RTL代碼,在FPGA可編程邏輯上或者ZynqSoC邏輯上作為硬件加速器,實(shí)現(xiàn)高分辨率高幀率的實(shí)時(shí)視頻處理。計(jì)算機(jī)視覺應(yīng)用與生俱來的異構(gòu)特性,使其需要軟硬件相結(jié)合的實(shí)現(xiàn)方案,采用Vivado HLS視頻庫能加快OpenCV函數(shù)向FPGA或Zynq SOC全可編程架構(gòu)的映射。

            參考文獻(xiàn):

            [1]Vivado Design Suite User Guide:High-LevelSynthesis(UG902)

            [2]Accelerating OpenCV applications with Zynq using VivadoHLS video libraries(XAPP1167)

            [3]Bradski G,Kaebler A.Learning OpenCV.ISBN 978-7-302-20993-5

            [4]Implementing memory structure for video processing in the VivadoHLS tool(XAPP793)

            [5]Gonzalez R C.Wood R E.Digital Image Processing,3rd ed.ISBN 978-7-121-11008-5

          fpga相關(guān)文章:fpga是什么


          c++相關(guān)文章:c++教程




          關(guān)鍵詞: 賽靈思 VivadoHLS OpenCV 201402

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();