新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于嵌入式平臺(tái)的視頻編碼器的實(shí)現(xiàn)

基于嵌入式平臺(tái)的視頻編碼器的實(shí)現(xiàn)

作者: 時(shí)間:2011-08-18 來(lái)源:網(wǎng)絡(luò) 收藏

 ?。?)1/4像素精度的運(yùn)動(dòng)估值。在h.264中通過6階FIR濾波器的內(nèi)插獲得l/2像素位置的預(yù)測(cè)值。當(dāng)l/2像素值獲得后,通過取整數(shù)像素位置和l/2像素位置像素值均值的方式獲得l/4像素位置的值,這樣迸一步減小幀間預(yù)測(cè)誤差,減少了經(jīng)變換和量化后的非零比特?cái)?shù),提高了編碼效率。

  (3)多參考幀運(yùn)動(dòng)估值。以往的編碼技術(shù)在對(duì)P幀(場(chǎng))圖像進(jìn)行幀間預(yù)測(cè)時(shí),只允許以前一個(gè)I幀(場(chǎng))圖像或P幀(場(chǎng))圖像為參考幀。對(duì)B圖像進(jìn)行預(yù)測(cè)時(shí)只允許以前后兩個(gè)I幀(場(chǎng))圖像或P幀(場(chǎng))圖像為參考圖像。h.264則允許在ReferenceBuffer中的多個(gè)圖像中選取一個(gè)(P預(yù)測(cè)方式)或兩個(gè)(B預(yù)測(cè)方式,圖像作為參考圖像。參考圖像甚至可以是采用雙向預(yù)測(cè)編碼方式的圖像。

 ?。?)參考圖像的選取與其編碼方式無(wú)關(guān)。允許選取與當(dāng)前圖像更加匹配的圖像為參考圖像進(jìn)行預(yù)測(cè),減小了預(yù)測(cè)誤差,提高編碼效率。

 ?。?)更精確的幀內(nèi)預(yù)測(cè)。在h.264中,每個(gè)4*4塊中的每個(gè)像素都可用17個(gè)最接近先前已編碼的像素的不同加權(quán)和來(lái)進(jìn)行幀內(nèi)預(yù)測(cè)。

 ?。?)環(huán)路去方塊濾波器。h.264/AVC把去方塊濾波引入運(yùn)動(dòng)估計(jì)預(yù)測(cè)環(huán)路中,既可去除方塊效應(yīng),又能保護(hù)圖像細(xì)節(jié)邊緣,同時(shí)亦改善了圖像的主、客觀評(píng)定質(zhì)量。而且經(jīng)過濾波后的圖像根據(jù)需要放在緩存中用于幀間預(yù)測(cè),進(jìn)一步提高預(yù)測(cè)精度。

 ?。?)h.264使用統(tǒng)一的可交長(zhǎng)度編碼國(guó)Ⅵz)碼表。以往標(biāo)準(zhǔn)的熵編碼通常采用變長(zhǎng)度的哈夫曼編碼,其碼表不統(tǒng)一,不能適應(yīng)變化多端的內(nèi)容,從而影響編碼效率的提高。在此,即對(duì)h.263不同系數(shù)采用不同碼表進(jìn)行VLC作了改進(jìn),采用了一個(gè)統(tǒng)一碼表的IrvIC,同時(shí),又對(duì)h.26L中的VCL方法進(jìn)行了改進(jìn),使量化后的DCT變換系數(shù)使用內(nèi)容的自適應(yīng)可變長(zhǎng)度編碼(CAⅥC),此外還定義了一種上下文內(nèi)容的自適應(yīng)二進(jìn)制算術(shù)編碼(CABAC),其性能比CAVLC更好。從而,借助UVLC,CAVLC及CABAC較好地提高了壓縮編碼效率。

  4 PXA255上的h.264編碼算法的

  ITU-T(國(guó)際電信標(biāo)準(zhǔn)化部門)提供了h.264的核心算法,本文使用的是開源編碼軟件x264。將其通過交叉編譯后移植到PXA255開發(fā)上。由于h.264編碼算法復(fù)雜度高、運(yùn)算量大等特點(diǎn)導(dǎo)致h.264編碼效率不高,經(jīng)初步測(cè)試編碼速率為QCIF格式圖像10幀/秒,不能達(dá)到實(shí)時(shí)編碼的要求。

  因此需要對(duì)編碼程序進(jìn)行相應(yīng)的優(yōu)化。

  4.1 C語(yǔ)言優(yōu)化

  編碼軟件包含了解碼和傳輸部分的程序,而本文只對(duì)進(jìn)行編碼,并不需要解碼和傳輸。所以對(duì)代碼進(jìn)行調(diào)整,刪除解碼和傳輸部分的代碼,再重新改寫makefile文件。這樣可以縮小程序的空間大小,減少程序的運(yùn)行時(shí)間,提高編碼效率。

  使用盡量小的數(shù)據(jù)類型。能夠使用字符型(char)定義的變量,就不要使用整型(int)變量來(lái)定義;能夠使用整型變量定義的變量就不要用長(zhǎng)整型(10ng in0,能不使用浮點(diǎn)型(float)變量就不要使用雙精度浮點(diǎn)型(doubles)變量。

  程序中被多次調(diào)用的、函數(shù)體代碼不是很大的函數(shù)使用內(nèi)聯(lián)函數(shù)。使用內(nèi)聯(lián)函數(shù)可以避免由于保護(hù)現(xiàn)場(chǎng)和記憶執(zhí)行的地址所帶來(lái)的時(shí)間和空間方面的開銷,以提高程序的執(zhí)行效率。

  4.2 Itrm匯編優(yōu)化

  用C語(yǔ)言編程結(jié)構(gòu)化程度高,易于編寫,但執(zhí)行速度相對(duì)較慢:與之相反,匯編程序速度快,但很難有較好的結(jié)構(gòu),而且編寫起來(lái)耗時(shí),不易調(diào)試。C和匯編混合編程結(jié)合了各自的優(yōu)勢(shì),往往能構(gòu)造出結(jié)構(gòu)好且執(zhí)行速度快的程序。利用匯編語(yǔ)言優(yōu)化C語(yǔ)言代碼,優(yōu)化后的匯編程序可以被C語(yǔ)言程序調(diào)用,并且在匯編程序中也可以調(diào)用C語(yǔ)言程序。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評(píng)論


相關(guān)推薦

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

關(guān)閉