亚洲免费av电影一区二区三区,日韩爱爱视频,51精品视频一区二区三区,91视频爱爱,日韩欧美在线播放视频,中文字幕少妇AV,亚洲电影中文字幕,久久久久亚洲av成人网址,久久综合视频网站,国产在线不卡免费播放

        ?

        基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集方法

        2016-11-23 10:02:36談恩民位慶海
        計算機測量與控制 2016年5期
        關鍵詞:分片數(shù)據(jù)量字節(jié)

        談恩民,位慶海

        (桂林電子科技大學電子工程與自動化學院,廣西桂林 541004)

        基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集方法

        談恩民,位慶海

        (桂林電子科技大學電子工程與自動化學院,廣西桂林541004)

        針對如何在工業(yè)應用中找到一種實現(xiàn)周期更短和更低成本的圖像數(shù)據(jù)采集方法進行了研究;通過分析以太網(wǎng)幀格式和JPEG圖像數(shù)據(jù)特點,給出了一種對JPEG圖像幀進行分片并對分片進行數(shù)據(jù)封裝的方法,在此基礎之上實現(xiàn)了基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集設計;最后在FPGA環(huán)境中對該設計進行了實現(xiàn),此實現(xiàn)成功應用到了工程項目當中;實踐表明,基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集方法能夠在不添加外置存儲器等復雜器件的情況下實現(xiàn)穩(wěn)定的、實時的JPEG圖像數(shù)據(jù)采集。

        JPEG;圖像采集;數(shù)據(jù)分片;數(shù)據(jù)封裝;FPGA

        0 引言

        在工業(yè)現(xiàn)場,由于各種極端的環(huán)境和具體應用需求,通常需要對工業(yè)設備或現(xiàn)場進行實時的圖像采集。目前,國內(nèi)應用于視頻監(jiān)控領域的圖像采集方案多采用CCD圖像傳感器+視頻解碼器(如SAA7113H)+FPGA/CPLD+DSP實現(xiàn),這種方案開發(fā)周期較長,并且在現(xiàn)有的通用圖像采集處理系統(tǒng)中,需要用幀緩存模塊對圖像數(shù)據(jù)整幀或多幀進行存儲,存儲設備一般采用SDRAM、SRAM等,這種大容量的高速存儲器件成本較高。

        針對現(xiàn)有圖像采集方案所存在的問題,本文充分利用JPEG壓縮圖像數(shù)據(jù)量小的優(yōu)勢和FPGA的高速數(shù)據(jù)處理能力,提出了基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集方法,這種方法只需緩存數(shù)據(jù)包文而不需要對圖像數(shù)據(jù)的整幀進行存儲,從而可以不用外部存儲器?;诖藢崿F(xiàn)了圖像傳感器(可直接驅(qū)動輸出JPEG圖像)+FPGA+以太網(wǎng)的圖像采集方案,該方案實現(xiàn)簡單、開發(fā)周期短,并降低了開發(fā)成本。

        1 JPEG圖像數(shù)據(jù)分片與封裝的實現(xiàn)

        1.1以太網(wǎng)幀格式簡介

        以太網(wǎng)有多種幀格式,按照目前最常用的Ethernet V2標準的規(guī)定,以太網(wǎng)MAC幀長度要介于64~1 518 Byte之間,其數(shù)據(jù)部分要介于46~1 500Byte之間,當數(shù)據(jù)字段的長度小于46字節(jié)時,MAC子層就會在數(shù)據(jù)字段的后面填充無效數(shù)據(jù)以滿足數(shù)據(jù)幀長不小于64字節(jié)[7]。如圖1為以太網(wǎng)MAC幀格式,數(shù)據(jù)部分為實際需要傳輸?shù)目蛻魯?shù)據(jù),當其字節(jié)數(shù)低于46時,會包含一定的填充數(shù)據(jù)。以太網(wǎng)MAC層對數(shù)據(jù)添加一定的幀首和幀尾封裝為MAC幀數(shù)據(jù)報。

        圖1 Ethernet V2標準MAC層幀格式(單位:Byte)

        設MAC幀首、幀尾信息大小為Sh字節(jié),數(shù)據(jù)部分大小為Sc字節(jié),則實際數(shù)據(jù)報利用效率G=Sc/(Sh+Sc)??梢姰擲h大小一定時,Sc越小,數(shù)據(jù)報的利用率越低,相當于網(wǎng)絡的有效負載越小,因此增大數(shù)據(jù)報長度可以提高網(wǎng)絡利用率。但在本文的實現(xiàn)方案中,圖像數(shù)據(jù)采集時一次性需發(fā)送的數(shù)據(jù)量越大,所需的緩存資源也越大,因本系統(tǒng)無外置存儲器,故需綜合考慮網(wǎng)絡利用率和硬件資源,本系統(tǒng)采用最大數(shù)據(jù)部分長度為256字節(jié)。

        1.2JPEG圖像數(shù)據(jù)封裝

        常見圖像傳感器的輸出圖像格式有RGB、YUV和JPEG等,JPEG是國際標準化組織(ISO)和CCITT聯(lián)合制定的靜態(tài)圖像的壓縮編碼標準,它與RGB、YUV圖像相比有如下特點:

        1)JPEG數(shù)據(jù)量大幅縮小,使用有損壓縮時,在壓縮比25:1的情況下,壓縮后的圖像與原始圖像相比,視覺上很難看出區(qū)別[8];

        2)由于JPEG壓縮編碼過程中涉及到熵編碼(一般采用霍夫曼編碼),其圖像幀的數(shù)據(jù)量是不確定的[9];

        3)JPEG圖像幀的起始并不是由行同步信號(HS)和場同步信號(VS)確定,而是由特定字節(jié)標示,16進制數(shù)據(jù)FFD8表示開始,F(xiàn)FD9表示結束[10]。

        為了實現(xiàn)基于圖像數(shù)據(jù)包文的數(shù)據(jù)采集,在數(shù)據(jù)經(jīng)以太網(wǎng)傳輸之前,需要對圖像幀數(shù)據(jù)進行分片、封裝,在封裝的過程中,也實現(xiàn)了數(shù)據(jù)發(fā)送端和接收端的通信協(xié)議。如圖2為本圖像采集系統(tǒng)采用的數(shù)據(jù)封裝包文格式。

        圖2 數(shù)據(jù)封裝包文格式

        包文中各部分的含義如下:

        1)有效長度:指示數(shù)據(jù)封裝包的有效數(shù)據(jù)字節(jié)數(shù),如上即為包文類型、包文數(shù)據(jù)、CRC校驗碼的字節(jié)數(shù)總和,在數(shù)據(jù)接收端,先接收此字節(jié),然后根據(jù)此字節(jié)的指示確定接收數(shù)據(jù)的長度;

        2)包文類型:用于標示數(shù)據(jù)源或目的,如0x01標示攝像頭1的數(shù)據(jù),0x02標示攝像頭2的數(shù)據(jù);

        3)圖像數(shù)據(jù):實際需要傳輸?shù)腏PEG數(shù)據(jù);

        4)CRC16校驗碼:根據(jù)包文數(shù)據(jù)生成的16bit的CRC校驗碼,用于接收端對接收的包文數(shù)據(jù)進行校驗,當校驗不通過時,進行錯誤包文統(tǒng)計并對當前圖像幀作出相應處理。

        1.3不定長數(shù)據(jù)封裝的實現(xiàn)算法與實現(xiàn)流程

        在對數(shù)據(jù)進行封裝時,封裝包文長度的確定,要綜合考慮以太網(wǎng)幀格式和JPEG圖像幀數(shù)據(jù)總量不確定的特點。在對JPEG圖像幀取某定長分片時(如256 Byte),因其幀數(shù)據(jù)總量不確定,那么最后一個分片的長度也不確定,此時就會出現(xiàn)低于46 Byte的圖像包文,這樣的包文可以直接發(fā)送,但是以太網(wǎng)端填充的無效數(shù)據(jù)會浪費以太網(wǎng)帶寬。為了避免小于46 Byte的包文出現(xiàn),本系統(tǒng)提出了如下不定長的數(shù)據(jù)封裝方法,實現(xiàn)更高效的數(shù)據(jù)傳輸。

        設定最長包文長度是最短包文長度的2倍。設允許的最小包文長度為K(不小于46 Byte),則最長包文長度為2 K(不大于1 500 Byte),包文中添加的包頭、包尾字節(jié)數(shù)之和為C,封裝后的包文格式如圖3所示。

        圖3 不定長數(shù)據(jù)封裝包文格式

        取最短、最長包文圖像數(shù)據(jù)部分長度分別為P min、P max,圖像數(shù)據(jù)部分長度之和為R,則

        圖像數(shù)據(jù)的采集時,到來的圖像數(shù)據(jù)先存于緩存中,打包時根據(jù)需要從緩存中取一定量的數(shù)據(jù)。設在圖像數(shù)據(jù)的緩存中,所統(tǒng)計的當前圖像幀數(shù)據(jù)總量為M,則我們對包文的圖像數(shù)據(jù)部分長度N按照以下公式取值:

        式中,N為0表示不進行數(shù)據(jù)封裝操作,設最終的包文長度為P,則

        P=N+C

        可以驗證各式中P的取值范圍:

        表1 包文長度P取值范圍

        C的值遠小于K,通過上表分析可知此時P的最小值為K,最大值為2K,即經(jīng)過以上處理算法,所有數(shù)據(jù)包文的長度都介于K-2K之間,且沒有無效數(shù)據(jù)的填充,達到了預定的目的。

        為便于不定長數(shù)據(jù)封裝方法的進一步闡明,取K為128 Byte(此時包文長度最小值為128 Byte,最大值為256 Byte),取C為4 Byte,即假設打包時添加的包頭、包尾數(shù)據(jù)字節(jié)數(shù)之和為4。在這種情況下,以上算法的實現(xiàn)流程如圖4所示。

        圖4 不定長數(shù)據(jù)封裝方法的實現(xiàn)流程圖

        2 基于圖像數(shù)據(jù)封裝包文的數(shù)據(jù)采集系統(tǒng)

        2.1系統(tǒng)功能

        系統(tǒng)實現(xiàn)雙攝像頭的圖像采集功能。攝像頭圖像數(shù)據(jù)經(jīng)FPGA采集處理后,經(jīng)以太網(wǎng)傳輸給上位機,上位機端對接收的JPEG數(shù)據(jù)進行解碼并實時顯示,同時上位機也具有對下位機的配置或控制功能,系統(tǒng)功能框圖如圖5所示。

        圖5 系統(tǒng)功能框圖

        2.2系統(tǒng)硬件結構

        系統(tǒng)中,攝像頭采用OV公司的OV2640圖像傳感器,該圖像傳感器在FPGA的驅(qū)動下,可直接輸出JPEG圖像,開發(fā)周期短且性能穩(wěn)定,輸出圖像最大支持UXGA(1600×1200分辨率)、15fps。采集的圖像采用TCP協(xié)議經(jīng)以太網(wǎng)傳輸,本系統(tǒng)采用TCP/IP協(xié)議棧芯片W5300實現(xiàn)高速硬件以太網(wǎng)解決方案,此方案具有較短的開發(fā)周期與較高的彈性,而且能夠增加穩(wěn)定性與有效降低主CPU負擔,模塊化的設計也便于以后系統(tǒng)的升級。主處理器采用Altera的Cyclone IV系列FPGA芯片EP4CE6E22C8,Cyclone IV系列是Altera的低成本FPGA系列,采用經(jīng)過優(yōu)化的60nm低功耗工藝,實現(xiàn)了低功耗、高性能和低成本的綜合。系統(tǒng)硬件結構如圖6所示。

        圖6 系統(tǒng)硬件結構

        系統(tǒng)初次工作,通過JTAG接口完成系統(tǒng)的配置,此后系統(tǒng)上電由EPCS4SI8N完成系統(tǒng)的自動配置。

        2.3系統(tǒng)實現(xiàn)

        FPGA功能模塊的實現(xiàn)框圖如圖7所示,系統(tǒng)工作時,由W5300配置模塊完成對W5300的配置,實現(xiàn)TCP協(xié)議的以太網(wǎng)通信,然后PC上位機發(fā)送配置命令,經(jīng)以太網(wǎng)傳輸給FPGA,F(xiàn)PGA對配置命令進行解析并完成對兩路OV2640攝像頭的配置,OV2640按照具體配置輸出JPEG圖像數(shù)據(jù),再由FPGA完成對圖像數(shù)據(jù)的分片、封裝處理,經(jīng)過處理的兩路圖像數(shù)據(jù)最終經(jīng)以太網(wǎng)傳輸給上位機分別顯示,上位機端在對圖像實時顯示的同時可以隨時發(fā)送控制命令,并經(jīng)指令解析模塊解析,完成暫停某路圖像的接收、改變圖像輸出分辨率、幀率等功能。

        數(shù)據(jù)封裝模塊完成圖像幀的分片、封裝功能,將采集到的原始圖像幀數(shù)據(jù)轉(zhuǎn)化為若干圖像包文,是實現(xiàn)基于圖像分片封裝包文的核心,下面對該模塊的實現(xiàn)進行說明。

        圖7 FPGA功能模塊實現(xiàn)框圖

        在FPGA中,用兩個FIFO分別對兩路圖像數(shù)據(jù)進行緩存,具體實現(xiàn)時,不定長數(shù)據(jù)封裝方法的K和C的值以及FIFO的寬度、深度均以參數(shù)化定義,這樣可以很方便的調(diào)整數(shù)據(jù)封裝包的格式。本系統(tǒng)實現(xiàn)時,取K值為128 Byte,考慮到一定的數(shù)據(jù)突發(fā)因素,取單個FIFO深度為1 024、寬度為10(幀開始、結束各1 bit,圖像數(shù)據(jù)8 bit)。實現(xiàn)框圖如圖8所示。

        圖8 不定長數(shù)據(jù)封裝方法FPGA實現(xiàn)框圖

        上述方法中,數(shù)據(jù)緩存的讀寫兩側(cè)是相互獨立的,可以同時進行,這符合圖像數(shù)據(jù)隨時到來的特點,因此數(shù)據(jù)段打包不會影響圖像數(shù)據(jù)的傳輸速度。但須注意,使用前述不定長數(shù)據(jù)封裝的M是當前幀的數(shù)據(jù)總量,而非緩存中有數(shù)據(jù)的總量,因為圖像數(shù)據(jù)是隨時到來的,若當前圖像幀數(shù)據(jù)尚未封裝完畢,而下一幀圖像又到來時,緩存中將同時存在兩幀的圖像數(shù)據(jù)。

        動態(tài)包長模塊即是根據(jù)前述不定長數(shù)據(jù)封裝算法實現(xiàn)。在FPGA中,它依據(jù)數(shù)據(jù)封裝模塊是否空閑以及FIFO中當前圖像幀的數(shù)據(jù)量產(chǎn)生讀FIFO數(shù)據(jù)長度值,因為系統(tǒng)有兩個FIFO,實現(xiàn)時要根據(jù)具體FIFO中的數(shù)據(jù)量選擇所讀取的FIFO,若兩個FIFO中的數(shù)據(jù)均滿足取數(shù)據(jù)要求,則對兩個FIFO進行輪流選擇。所讀的FIFO以及讀數(shù)據(jù)量確定后,F(xiàn)IFO根據(jù)給定的長度值輸出指定長度的圖像數(shù)據(jù);CRC16碼生成模塊產(chǎn)生輸出圖像數(shù)據(jù)的CRC16校驗碼;最終,圖像數(shù)據(jù)經(jīng)數(shù)據(jù)封裝模塊添加相應的包頭、包尾生成圖像包文。

        如圖9為Singal TapⅡ邏輯分析工具對某幀輸出圖像最后兩個封裝包文的實時波形抓取,該圖像幀結束標志(img_ eop)到來前,包文長度(pck_cnt)均為256 Byte,圖像幀結束標志(img_eop)到來時,剩余當前幀數(shù)據(jù)段長度(fifo_ num)為287 Byte,在不定長數(shù)據(jù)打包方法下,分兩次發(fā)送完成,先后兩次所取圖像數(shù)據(jù)量(pck_img_num)分別為144、143,包文長度 (pck_cnt)字節(jié)數(shù)分別為148、147。這樣就完成了對一幀數(shù)據(jù)的完整分片、封裝。

        最后圖像幀數(shù)據(jù)以圖像包文為單位傳輸給W5300接口,經(jīng)以太網(wǎng)傳輸給上位機,上位機端根據(jù)發(fā)送端的數(shù)據(jù)封裝協(xié)議提取圖像數(shù)據(jù),并對數(shù)據(jù)分片進行重組,最后對重組的JPEG圖像幀進行解碼并實時顯示,完成了圖像采集任務。

        圖9 Singal TapⅡ?qū)崟r波形抓取

        3 結束語

        本文所提出的JPEG圖像采集方案,整體硬件結構簡單、實現(xiàn)方便,大大縮短了項目開發(fā)周期,同時,在硬件處理速度與資源足夠時,本方案能夠在不添加任何額外硬件的前提下實現(xiàn)攝像頭的擴展。本文所提出的方法在基于FPGA的工業(yè)相機項目中得到了應用,實踐證明,本方案性能穩(wěn)定,能夠滿足具體應用環(huán)境的需求。

        [1]王巧玉.基于FPGA的網(wǎng)絡視頻監(jiān)控系統(tǒng) [D].西安:西安電子科技大學,2011.

        [2]付強,夏靖波,楊軍.基于FPGA的多路圖像采集系統(tǒng)的軟件設計[J].電子設計工程,2011,19(3):174-177.

        [3]牛彥明,史忠科.基于DSP和FPGA的多路圖像信息提取系統(tǒng)設計[J].彈箭與制導學報,2007,27(5):341-343,346.

        [4]彭加進.基于JPEG圖像壓縮的嵌入式視頻采集處理系統(tǒng)[D].南京:河海大學,2007.

        [5]張小琴.基于FPGA的高速圖像數(shù)據(jù)采集系統(tǒng)設計[D].武漢:武漢理工大學,2010.

        [6]龔濤.基于FPGA的圖像采集處理系統(tǒng)[D].武漢:華中科技大學,2005.

        [7]范興剛,孫優(yōu)賢.以太網(wǎng)幀[J].工業(yè)控制計算機,2002,15(10):29-31.

        [8]唐賽明.基于FPGA的JPEG壓縮編碼的研究與實現(xiàn)[D].長沙:湖南大學,2007.

        [9]張元偉,劉彥隆.基于JPEG標準的靜態(tài)圖像壓縮算法研究[J].電子設計工程,2010,18(2):78-80.

        [10]邢賽鵬,平西建,詹杰勇.JPEG圖像數(shù)據(jù)格式簡明分析[J].微計算機信息,2005(36):166-168.

        Data Acquisition Method Based on Image Data Encapsulation

        Tan Enmin,Wei Qinghai
        (School of Electronic Engineering and Automation,Guilin University of Electronic Technology,Guilin541004,China)

        How to find an implementation for a shorter period and lower cost of image data acquisition method in industrial applications were studied.By analyzing the Ethernet frame format and JPEG image data characteristics,given a JPEG image frames of fragmentation and the fragmentation data encapsulation method,on this basis to realize the data acquisition method based on the packet of image data encapsulation.Finally the design was implemented in the FPGA environment,and this implementation was successfully applied to the project.Practice shows that the proposed method can achieve stability and real-time JPEG image data acquisition without adding external memory devices and other complex devices.

        JPEG;image data acquisition;data fragmentation;data encapsulation;FPGA

        1671-4598(2016)05-0169-04

        10.16526/j.cnki.11-4762/tp.2016.05.049

        TP274.2

        A

        2015-10-14;

        2015-12-18。

        國家自然科學基金(61306024);國家自然科學基金(61376024)。

        談恩民(1966-),男,河南光山人,博士,教授,主要從事現(xiàn)代測試理論、電路可測試性設計、計算機輔助測試方向的研究。

        猜你喜歡
        分片數(shù)據(jù)量字節(jié)
        上下分片與詞的時空佈局
        詞學(2022年1期)2022-10-27 08:06:12
        No.8 字節(jié)跳動將推出獨立出口電商APP
        基于大數(shù)據(jù)量的初至層析成像算法優(yōu)化
        計算Lyapunov指數(shù)的模糊C均值聚類小數(shù)據(jù)量法
        分片光滑邊值問題的再生核方法
        CDN存量MP4視頻播放優(yōu)化方法
        高刷新率不容易顯示器需求與接口標準帶寬
        寬帶信號采集與大數(shù)據(jù)量傳輸系統(tǒng)設計與研究
        電子制作(2019年13期)2020-01-14 03:15:18
        No.10 “字節(jié)跳動手機”要來了?
        基于模糊二分查找的幀分片算法設計與實現(xiàn)
        国产激情无码一区二区三区| 日本特殊按摩在线观看| 亚洲乱码一区二区av高潮偷拍的| 在线观看老湿视频福利| 欧美gv在线观看| 免费国产一级片内射老| 99亚洲女人私处高清视频| 国产区女主播在线观看| 久久久久亚洲精品无码网址色欲| 亚洲色成人网一二三区| 一本久道在线视频播放| 米奇欧美777四色影视在线| 美女视频黄的全免费视频网站 | 精品国产一区二区三区av性色| 粗了大了 整进去好爽视频| 中文人妻av大区中文不卡| 国产精品国产三级国产剧情| 尤物在线精品视频| 欧美日韩国产成人高清视| 亚洲av色香蕉一区二区三区蜜桃| 亚洲av成人av三上悠亚| 99精品人妻少妇一区二区| 成人免费va视频| 免费人成网在线观看品观网 | 亚洲日韩乱码中文无码蜜桃臀 | 国产日韩AV无码免费一区二区| 91偷自国产一区二区三区| 色噜噜久久综合伊人一本| 91av精品视频| 久久精品国产精品亚洲婷婷| 国产自拍高清在线观看| 国产成人免费一区二区三区| 成人免费无码a毛片| 青青草免费手机直播视频| 老师露出两个奶球让我吃奶头| 屁屁影院一区二区三区| 日美韩精品一区二区三区| 午夜精品久久久久久久久| 亚洲av无码片在线观看| 无码啪啪熟妇人妻区| 24小时免费在线观看av|