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

Xilinx FPGA/Zynq設計中使用HLS實現OpenCV的開發流程

2014-04-29 00:00:00郭豐收
電子產品世界 2014年3期

摘要:首先介紹OpenCV中圖像類型和函數處理方法,之后通過設計實例描述在VivadoHLS中調用OpenCV庫函數實現圖像處理的幾個基本步驟,闡述從OpenCV設計到RTL轉換綜合的開發流程。本文網絡版地址:http://www.eepw.com.cn/article/233872.htm

關鍵詞:可編程;處理器;VivadoHLS;OpenCV;Zynq AP SOC

DOI: 10.3969/j.issn.1005-5517.2014.2.011

郭豐收:Xilinx DSP專家,主要從事在Xilinx器件上實現數字信號處理的系統方案、架構和算法應用。

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

1 OpenCV中圖像IplImage, CvMat, Mat 類型的關系和VivadoHLS中圖像hls::Mat類型

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

1.1 OpenCV中的Mat矩陣類型

在OpenCV中,Mat是一個多維的密集數據數組。可以用來處理向量和矩陣、圖像、直方圖等等常見的多維數據。

Mat類型較CvMat與IplImage類型來說,有更強的矩陣運算能力,支持常見的矩陣運算。在計算密集型的應用當中,將CvMat與IplImage類型轉化為Mat類型將大大減少計算時間花費。

1 . 2 O p e n C V中的C v M a t與IplImage類型

在openCV中,CvMat和IplImage類型更側重于“圖像”,尤其是對其中的圖像操作進行一定程度的優化。OpenCV沒有向量(vector)的數據結構,但當我們要表示向量時,需要用矩陣數據表示。但是,CvMat更抽象,它的元素數據類型并不僅限于基礎數據類型,而且可以是任意的預定義數據類型,比如RGB或者別的多通道數據。

在OpenCV類型關系上,我們可以說IplImage類型繼承自CvMat類型,當然還包括其他的變量將之解析成圖像數據。IplImage類型較之CvMat多了很多參數,比如depth和nChannels。IplImage對圖像的另一種優化是變量origin原點,為了彌補這一點,OpenCV允許用戶定義自己的原點設置。

1.3 VivadoHLS中圖像數據類型hls::Mat<>

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

2 使用V i v a d o H L S實現OpenCV到RTL代碼轉換的流程

2.1 OpenCV設計中的權衡

OpenCV圖像處理是基于存儲器幀緩存而構建的,它總是假設視頻frame數據存放在外部DDR 存儲器中,因此,OpenCV對于訪問局部圖像性能較差,因為處理器的小容量高速緩存性能不足以完成這個任務。而且出于性能考慮,基于OpenCV設計的架構比較復雜,功耗更高。在對分辨率或幀速率要求低,或者在更大的圖像中對需要的特征或區域進行處理時,OpenCV似乎足以滿足很多應用的要求,但對于高分辨率高幀率實時處理的場景下,OpenCV很難滿足高性能和低功耗的需求。

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

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

OpenCV函數不能直接通過HLS進行綜合,因為OpenCV函數一般都包含動態的內存分配、浮點以及假設圖像在外部存儲器中存放或者修改。

VivadoHLS視頻庫用于替換很多基本的OpenCV函數,它與OpenCV具有相似的接口和算法,主要針對在FPGA架構中實現的圖像處理函數,包含了專門面向FPGA的優化,比如定點運算而非浮點運算(不必精確到比特位),片上的行緩存(line buffer)和窗口緩存(window buffer)。圖2.1展示了在Xilinx Zynq AP SoC器件上實現視頻處理的系統結構。2.2 在FPGA/Zynq開發中使用VivadoHLS實現OpenCV的設計流程

設計開發流程主要有如圖2.2三個步驟。

1. 在計算機上開發OpenCV應用,由于是開源的設計,采用C++的編譯器對其進行編譯、仿真和debug,最后產生可執行文件。這些設計無需修改即可在 ARM內核上運行OpenCV應用。

2.使用I/O函數抽取FPGA實現的部分,并且使用可綜合的VivadoHLS Video庫函數代碼代替OpenCV函數的調用。

3.運行HLS生成RTL代碼,在VivadoHLS工程中啟動co-sim,HLS工具自動重用OpenCV的測試激勵驗證產生的RTL代碼。在Xilinx的ISE或者Vivado開發環境中做RTL的集成和SoC/FPGA實現。

2.3 用HLS實現OpenCV應用的實例(快速角點濾波器image_filter)

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

3 VHLS實現OpenCV設計流程總結

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

參考文獻:

[ 1 ] V i v a d o D e s i g n S u i t e U s e r G u i d e : H i g h -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

主站蜘蛛池模板: 国产美女无遮挡免费视频| 国产亚洲欧美在线人成aaaa| 精品视频在线观看你懂的一区| 亚洲伦理一区二区| 无码福利视频| 久久夜夜视频| 国产精品私拍在线爆乳| 久久人体视频| 久久久久国产一区二区| 亚洲国产中文精品va在线播放 | 亚洲中文字幕手机在线第一页| 国产亚洲精久久久久久无码AV| 丁香婷婷综合激情| 超级碰免费视频91| 丰满少妇αⅴ无码区| 亚洲娇小与黑人巨大交| 2018日日摸夜夜添狠狠躁| 热re99久久精品国99热| 97狠狠操| 国产视频久久久久| 欧美.成人.综合在线| 色妞永久免费视频| 22sihu国产精品视频影视资讯| 91亚洲精品第一| 亚洲毛片网站| 老司机精品久久| 国产欧美高清| 中文字幕啪啪| 精品少妇人妻无码久久| 成年人国产视频| 99精品国产自在现线观看| 2021国产在线视频| 色哟哟国产精品一区二区| 国产成人精品高清不卡在线| 国产成人一级| 久久亚洲高清国产| 无码精品国产dvd在线观看9久| 亚洲中文久久精品无玛| 国内精品久久久久鸭| 2024av在线无码中文最新| 欧美日韩综合网| 国产精品无码一二三视频| 欧美天堂在线| 永久天堂网Av| www欧美在线观看| 国产午夜无码专区喷水| 久久国产热| 国产成人av一区二区三区| 尤物午夜福利视频| 毛片一级在线| 色偷偷一区二区三区| 欧美黑人欧美精品刺激| 亚洲视频四区| 操国产美女| 欧美a网站| 欧美日韩亚洲综合在线观看| 69免费在线视频| 久久综合伊人 六十路| 色视频国产| 久久精品人人做人人爽电影蜜月 | 国产亚洲精品自在久久不卡| 国产美女自慰在线观看| 亚洲不卡网| 毛片免费在线视频| 国产中文一区二区苍井空| 青青草原国产免费av观看| 欧美国产日韩一区二区三区精品影视 | 国产激情影院| 亚洲a级在线观看| 欧美不卡视频一区发布| 欧美狠狠干| 亚洲 日韩 激情 无码 中出| 亚洲人网站| 欧美另类视频一区二区三区| 精品一区二区无码av| 日本高清视频在线www色| 欧美区一区| 无码国产伊人| 国产美女免费| 国产精女同一区二区三区久| 久久久久免费精品国产| 99人体免费视频|