當(dāng)前位置:首頁(yè) > 消費(fèi)電子 > 視頻技術(shù)
[導(dǎo)讀] 引言 當(dāng)前在視頻監(jiān)控,視頻會(huì)議,網(wǎng)絡(luò)流媒體等方面數(shù)字視頻編碼成為最核心,最基本的技術(shù)手段,尤其是視頻監(jiān)控現(xiàn)已成為最為普通的安保設(shè)備之一。基于電腦硬盤為存儲(chǔ)體的數(shù)字DVR已日漸取代模擬DV

引言

當(dāng)前在視頻監(jiān)控,視頻會(huì)議,網(wǎng)絡(luò)流媒體等方面數(shù)字視頻編碼成為最核心,最基本的技術(shù)手段,尤其是視頻監(jiān)控現(xiàn)已成為最為普通的安保設(shè)備之一。基于電腦硬盤為存儲(chǔ)體的數(shù)字DVR已日漸取代模擬DVR。數(shù)字DVR的最關(guān)鍵技術(shù)就是視頻壓縮技術(shù),而視頻壓縮技術(shù)又含有兩大選擇。首先是視頻壓縮采用何種算法標(biāo)準(zhǔn),當(dāng)前視頻算法的國(guó)際標(biāo)準(zhǔn)有MPEG2、MPEG4、H.264,H.264以其高壓縮效率,在低碼率下優(yōu)良的圖像質(zhì)量成為目前視頻監(jiān)控系統(tǒng)中首選的壓縮方式。

但任何事物都有其兩面性,H.264編碼的高效率,優(yōu)質(zhì)圖像是用算法的復(fù)雜性來?yè)Q取的。H.264編碼器的復(fù)雜性是MPEG2的4-5倍。第二個(gè)選擇是用什么芯片來實(shí)現(xiàn),TI公司的TMS320DM642芯片,是一款專門用作媒體處理的高速DSP,其強(qiáng)大的圖像處理能力為在監(jiān)控系統(tǒng)中實(shí)時(shí)實(shí)現(xiàn)H.264編碼提供了可能。為了降低成本,還必須充分運(yùn)用DM642本身的資源,使一顆DM642能處理更多路的視頻,這就是高效率優(yōu)化的目的,本文首先對(duì)整個(gè)視頻監(jiān)控的硬件平臺(tái)做了介紹,后結(jié)合DM642的結(jié)構(gòu)特點(diǎn),提出整個(gè)編碼軟件的框架的安排,對(duì)于占用系統(tǒng)資源最多的運(yùn)動(dòng)估計(jì)提出基于DSP的優(yōu)化方法,最后以整數(shù)DCT為例,討論了編寫匯編代碼的技巧。

硬件平臺(tái)的介紹

整個(gè)視頻監(jiān)控的硬件系統(tǒng)的框架如圖1所示。DM642芯片為了適應(yīng)數(shù)字媒體處理的需求,增加了三個(gè)可配置的視頻端口(VP0,VP1,和VP2),這些視頻口外設(shè)為常用的編解碼設(shè)備提供了無縫接口。因而不需要外加可編程邏輯器件和FIFO就可滿足系統(tǒng)設(shè)計(jì)的要求。

為了節(jié)省成本,提高DSP芯片的利用率,在一塊板卡可以同時(shí)處理多路的音視頻,壓縮卡與主機(jī)間的數(shù)據(jù)吞吐量會(huì)很大,為了保證數(shù)據(jù)存儲(chǔ)的實(shí)時(shí)性,系統(tǒng)采用PCI板卡,其與主機(jī)通信數(shù)據(jù)傳輸速率最高達(dá)528MB/s(66MHz,64bit),完全滿足大容量高速實(shí)時(shí)傳輸系統(tǒng)的需求。


圖1 硬件系統(tǒng)框架

由于每個(gè)視頻口可以接收兩路8/10bit的視頻信號(hào),視頻信號(hào)經(jīng)過SAA7144A/D轉(zhuǎn)換輸出為8位BT.656格式的數(shù)字視頻數(shù)據(jù)。這樣就能利用一顆DM642芯片處理最多6路視頻輸入。每個(gè)視頻端口的BT.656視頻采集模式采集8bit或是10bit4:2:2格式的亮度和色度信號(hào),并將它們復(fù)用到一個(gè)數(shù)據(jù)流里,視頻數(shù)據(jù)以Cb,Y,Cr,Y,Cb,Y,Cr的順序傳送,其中Cb,Y,Cr代表同一位置的亮度和色度樣點(diǎn),緊接著后面的Y代表下一個(gè)位置的亮度樣點(diǎn)。數(shù)據(jù)流經(jīng)解復(fù)用后亮度和色度信息分別存放到各自的Y,Cb,CrFIFO中,再經(jīng)EDMA搬移到SDRAM中,以備CPU讀取進(jìn)行壓縮編碼。編碼后的視頻流再經(jīng)PCI口存入到電腦的硬盤上,從而完成整個(gè)視頻監(jiān)控的流程。

編碼器整體框架的安排

JM代碼是很多可選的H.264標(biāo)準(zhǔn)軟件之一,它關(guān)心H.264全部的功能在代碼上得到體現(xiàn),所有的情況都得考慮,例如幀編碼,場(chǎng)編碼都有,內(nèi)存的分派沒有考慮到系統(tǒng)的實(shí)際情況,適合用來幫助理解H.264標(biāo)準(zhǔn),不太適合移植到DSP平臺(tái)上。為了高效的組織利用DM642有限的片內(nèi)資源,就得重新組織代碼,包括數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)存放的位置,程序存放的位置,精簡(jiǎn)地來安排程序。

首先要考慮的是L2的配置問題,第二級(jí)L2(256kB)是一個(gè)統(tǒng)一的程序/數(shù)據(jù)空間,可以整體作為SRAM映射到存儲(chǔ)空間,也可整體作為第二級(jí)cache,或者二者的比例的組合使用。因?yàn)橐坏┒?jí)緩存也不命中的話,那么讀取數(shù)據(jù)申請(qǐng)將轉(zhuǎn)由EDMA來完成,CPU至少有13個(gè)cycle的延遲。所以我們總是盡量把程序和數(shù)據(jù)放在片內(nèi)存儲(chǔ)器內(nèi)。但是即使全部將L2配置成SRAM也只有256kB大小,以CIF格式圖像為例,待編碼的一幀圖像大小是148.5kB,再加上運(yùn)動(dòng)估計(jì)的參考圖像就大大超過256kB了。所以在配置L2時(shí),筆者選擇的是SRAM224kB,L2cache32kB。首先考慮要放到SRAM的是表格,全局變量,棧數(shù)據(jù)和一些調(diào)用頻繁的核心程序,如運(yùn)動(dòng)搜索,DCT變換,量化……而整個(gè)待編碼圖像和參考圖像就只能放在片外存儲(chǔ)空間了。

既然圖像數(shù)據(jù)被存放到了片外存儲(chǔ)空間中,就要涉及到數(shù)據(jù)在片內(nèi)存儲(chǔ)跟片外存儲(chǔ)間的數(shù)據(jù)搬移,這可交由DM642強(qiáng)大的EDMA引擎來完成,EDMA工作時(shí)不占用CPU的周期,把CPU從繁重的搬移數(shù)據(jù)的工作中解放出來,專致于運(yùn)算工作。在編碼程序時(shí),為了避免CPU等待EDMA搬完數(shù)據(jù)后才能工作,可采用乒乓結(jié)構(gòu)的雙緩存區(qū),當(dāng)EDMA傳送數(shù)據(jù)到其中一塊存儲(chǔ)區(qū)域時(shí),CPU對(duì)另一塊存儲(chǔ)區(qū)域進(jìn)行處理。待二者都處理完畢后,乒乓區(qū)域交換。

需要通過EDMA搬移的數(shù)據(jù)有待編碼的宏塊,前后幀對(duì)應(yīng)的參考宏塊,和編碼后的重構(gòu)宏塊(B幀不需要),這些宏塊都包括亮度塊和色度塊。EDMA在搬大量數(shù)據(jù)時(shí)才能將它的性能發(fā)揮到極致,如果每編完一個(gè)宏塊就進(jìn)行一次乒乓緩存交換,那么在頻繁的配置EDMA通道參數(shù)上就耗費(fèi)了過多的CPU周期。有限的片內(nèi)存儲(chǔ)空間,制約著不能一次搬太多的宏塊,一般一次搬7--9個(gè)宏塊為宜。由于EDMA的同步信息是由CPU發(fā)出的,我們自然想到QDMA,但QDMA適用于單個(gè)的,獨(dú)立的快速搬移數(shù)據(jù),對(duì)于這種周期性的,重復(fù)性的搬移并沒有優(yōu)勢(shì)。

為了提高EDMA的效率,可以采用EDMA鏈,最多開辟12個(gè)EDMA通道,讓其首尾相連,這樣只需觸發(fā)一次CPU,可將待編碼的亮度塊色度塊,參考幀的亮度塊和色度塊……一次搬完,如圖2所示。在配置EDMA通道時(shí),我們注意到頻繁更換的只是EDMA的源地址和目的地址,而其它參量是不變的。由于EDMA控制器是基于RAM結(jié)構(gòu)的,每個(gè)通道是通過參數(shù)表來配置的,每一個(gè)通道的參數(shù)都可以在0x01A0000h~0x01A07ffh的2KB的配置表中找到自己固定的位置,所以在更新某一通道的源地址和目的地址時(shí),直接往配置表寫上新地址就行了,而不必調(diào)用CSL庫(kù)中的相應(yīng)的cache函數(shù)來修改源地址和目的地址。


圖2 EDMA鏈?zhǔn)疽鈭D


圖3 六邊形搜索算法

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉