




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
精品文檔-下載后可編輯一種基于AVS標(biāo)準(zhǔn)熵解碼器的實(shí)現(xiàn)-設(shè)計(jì)應(yīng)用AVS標(biāo)準(zhǔn)是《信息技術(shù)先進(jìn)音視頻編碼》系列標(biāo)準(zhǔn)的簡(jiǎn)稱,是我國(guó)具備自主知識(shí)產(chǎn)權(quán)的第二代信源編碼標(biāo)準(zhǔn)。AVS標(biāo)準(zhǔn)包括系統(tǒng)、視頻、音頻、數(shù)字版權(quán)管理等四個(gè)主要技術(shù)標(biāo)準(zhǔn)和一致性測(cè)試等支撐標(biāo)準(zhǔn)。
AVS是AviSynth的簡(jiǎn)稱。意思是AVI合成器,就是一個(gè)把影像文件從一個(gè)程序轉(zhuǎn)換到另外一個(gè)程序的過程,其間沒有臨時(shí)文件或中介文件產(chǎn)生。對(duì)于Rip的人來(lái)說(shuō),AVS就是基礎(chǔ),就是關(guān)鍵。像VirtualDubMod、MeGuid之類的強(qiáng)大壓縮軟件都必須通過AVS載入
目前音視頻產(chǎn)業(yè)可以選擇的信源編碼標(biāo)準(zhǔn)有四個(gè):MPEG-2、MPEG-4、AVC(也稱JVT、H.264)和AVS。從制訂者分,前三個(gè)標(biāo)準(zhǔn)是由MPEG組完成的,第四個(gè)是我國(guó)自主制定的。從發(fā)展階段分,MPEG-2是代信源標(biāo)準(zhǔn),其余三個(gè)為第二代標(biāo)準(zhǔn)。從主要技術(shù)指標(biāo)——編碼效率比較,MPEG-4是MPEG-2的1.4倍,AVS和AVC相當(dāng),都是MPEG-2的兩倍以上。
AVC標(biāo)準(zhǔn)中,對(duì)預(yù)測(cè)殘差有兩種熵編碼的方式:基于上下文的自適應(yīng)變長(zhǎng)碼(CAVLC)和基于上下文的自適應(yīng)二進(jìn)制算數(shù)編碼(CABAC);對(duì)于非預(yù)測(cè)殘差,采用指數(shù)哥倫布碼或CABAC編碼,視編碼器的設(shè)置而定[1]。
AVS標(biāo)準(zhǔn)所用的熵編碼技術(shù)相比于以前有了很多改進(jìn),它的語(yǔ)法元素和殘差系數(shù)是由定長(zhǎng)碼和指數(shù)哥倫布碼構(gòu)成的,其中指數(shù)哥倫布碼和語(yǔ)法元素之間存在多種映射關(guān)系。
1AVS標(biāo)準(zhǔn)熵解碼算法描述
在整個(gè)AVS視頻的解碼過程中,熵解碼模塊位于系統(tǒng)的前端,負(fù)責(zé)從壓縮后的碼流中解析出宏塊頭信息以及量化系數(shù),供后續(xù)的幀內(nèi)預(yù)測(cè)模塊和幀間預(yù)測(cè)模塊使用。而熵解碼模塊又可以大體分為兩個(gè)部分:解析K階指數(shù)哥倫布碼部分和解析語(yǔ)法元素部分。
解析K階指數(shù)哥倫布碼時(shí),首先從比特流的當(dāng)前位置開始尋找個(gè)非零比特,并將找到的零比特個(gè)數(shù)記為leadingZeroBits,然后根據(jù)leadingZeroBits計(jì)算CodeNum。用偽代碼描述如下:
由于AVS視頻中所有的語(yǔ)法元素以及經(jīng)過變換和量化的殘差系數(shù)都是以指數(shù)哥倫布碼的形式映射成二進(jìn)制碼流的,因此在解析出K階指數(shù)哥倫布碼的CodeNum后,下一步就是要還原出各種語(yǔ)法元素和殘差系數(shù)。
在AVS標(biāo)準(zhǔn)中規(guī)定了四種映射方式:ue(v)、se(v)、me(v)和ce(v)。其中ue(v)、se(v)和me(v)所描述的語(yǔ)法元素采用0階的指數(shù)哥倫布碼,ce(v)用來(lái)描述殘差系數(shù),可以采用0階、1階、2階或者3階指數(shù)哥倫布碼。它們的解析過程如下:
ue(v):無(wú)符號(hào)直接映射,語(yǔ)法元素的值等于CodeNum;
se(v):有符號(hào)映射,映射關(guān)系為:當(dāng)CodeNum=k時(shí),語(yǔ)法元素值為(-1)k+1×Ceil(k÷2)
me(v):分為MbCBP和MbCBP422兩種模式,分別根據(jù)CodeNum的值,查找相對(duì)應(yīng)的表來(lái)得到語(yǔ)法元素的值。
ce(v):ce(v)描述的語(yǔ)法元素可以采用0階、1階、2階或3階指數(shù)哥倫布碼進(jìn)行解析,還有19個(gè)相關(guān)的碼表。解析時(shí),首先語(yǔ)法元素trans_coefficient等于CodeNum,如果trans_coefficient小于59,可以根據(jù)trans_coefficient的值查找相關(guān)的碼表得到殘差系數(shù);如果trans_coefficient大于等于59,解析下一個(gè)ce(v)語(yǔ)法元素,得到一個(gè)新的CodeNum,escape_level_diff等于CodeNum,然后根據(jù)trans_coefficient和escape_level_diff求得殘差系數(shù)[3]。
2熵解碼器的硬件設(shè)計(jì)
由于熵解碼器位于整個(gè)解碼結(jié)構(gòu)的前端,所有后續(xù)模塊中需要用到的數(shù)據(jù)都是熵解碼模塊從原始碼流中解析出來(lái)的,因此熵解碼器性能的優(yōu)劣直接影響到整個(gè)AVS視頻解碼器的性能。
這種串行解碼的方式嚴(yán)重限制了熵解碼器的性能,所以需要找到一種能夠并行解碼的方式。這里的并行解碼并不是指同時(shí)對(duì)好幾個(gè)碼進(jìn)行解碼,而是針對(duì)一個(gè)變長(zhǎng)碼的多個(gè)位來(lái)說(shuō)的。具體來(lái)說(shuō)就是讀入N位數(shù)據(jù),通過比較操作,得到碼長(zhǎng),使得解碼可以在確定的時(shí)間長(zhǎng)度內(nèi)進(jìn)行,而不是隨著碼長(zhǎng)的不同而變化。
整個(gè)熵解碼器可以分為四個(gè)模塊:數(shù)據(jù)準(zhǔn)備模塊、解指數(shù)哥倫布碼模塊、語(yǔ)法元素解析模塊和解碼控制模塊。硬件結(jié)構(gòu)如圖1所示。
下面通過分析碼流數(shù)據(jù)的解析過程來(lái)逐個(gè)說(shuō)明各個(gè)模塊的功能和實(shí)現(xiàn)。
2.1數(shù)據(jù)準(zhǔn)備模塊
這個(gè)模塊的功能是為后邊的解指數(shù)哥倫布碼模塊準(zhǔn)備好未解碼數(shù)據(jù),要求解指數(shù)哥倫布碼模塊解完一個(gè)碼,數(shù)據(jù)準(zhǔn)備模塊就要在碼流中將解完的碼移走,并準(zhǔn)備好下一個(gè)要解的碼字送給下一模塊。硬件結(jié)構(gòu)如圖2所示。
RegA和RegB是兩個(gè)32位的寄存器,其中RegB直接從未解碼碼流中讀取數(shù)據(jù),RegA則接收RegB中的數(shù)據(jù),兩個(gè)寄存器共同組成barrelshifter的輸入。
barrelshifter是一個(gè)64位輸入、32位輸出的暫存器,每次輸出都將剛解完的一個(gè)碼字移出,以保證輸出的32位數(shù)據(jù)中位為下一個(gè)要解碼的碼字的開始。移位的位數(shù)由輸入的地址Addr來(lái)決定,即輸出64位輸入的[Addr,Addr+31]位。
當(dāng)En信號(hào)有效時(shí),更新數(shù)據(jù),將RegB中的數(shù)據(jù)存到RegA中,再?gòu)拇a流中讀取新的32位數(shù)據(jù),存到RegB中。其中Addr和En信號(hào)由解指數(shù)哥倫布碼模塊給出。
2.2解指數(shù)哥倫布碼模塊
指數(shù)哥倫布碼由3部分組成分別是:碼流中非0比特位前0的個(gè)數(shù)(leadingZeroBits)、一個(gè)1位和非0比特位開始leadingZeroBits+k位碼流數(shù)據(jù),表1為k階指數(shù)哥倫布編碼表;碼字的編碼方式為:
codenum=2n+k-2k+readbits(n),n=leadingZeroBitsAVS中k的階數(shù)取值范圍為0~3。
AVS中定義了4種描述符來(lái)表示指數(shù)哥倫布編碼的語(yǔ)法元素,分別是u(e),s(e),m(e),c(e),其中:描述符ue(v)表示語(yǔ)法元素的值等于CodeNum;se(v)根據(jù)表2中給出的有符號(hào)指數(shù)哥倫布碼的映射關(guān)系求語(yǔ)法元素的值;me(v)根據(jù)標(biāo)準(zhǔn)中規(guī)定的映射關(guān)系求語(yǔ)法元素的值;ce(v)用于表示指數(shù)哥倫布碼與殘差系數(shù)(2D-VLD)的映射關(guān)系,ce(v)描述的語(yǔ)法元素采用0階、1階、2階或3階指數(shù)哥倫布編碼進(jìn)行解析,對(duì)應(yīng)還有19個(gè)碼表供查找
這個(gè)模塊的功能是接收上一模塊準(zhǔn)備好的未解碼數(shù)據(jù),計(jì)算出從位開始的一個(gè)指數(shù)哥倫布碼的CodeNum,并根據(jù)這個(gè)碼的碼長(zhǎng)算出筒形移位器的移位地址。模塊結(jié)構(gòu)如圖3所示。
由于上一個(gè)模塊準(zhǔn)備好的未解碼碼流是一個(gè)以新的指數(shù)哥倫布碼的開始為位的32位碼流,因此要計(jì)算出這個(gè)碼的CodeNum,首先要算出這個(gè)碼的碼長(zhǎng),然后在這32位數(shù)據(jù)中截取出這個(gè)碼字,才可以計(jì)算它的CodeNum。根據(jù)指數(shù)哥倫布碼的結(jié)構(gòu),碼長(zhǎng)與這個(gè)碼的前導(dǎo)零個(gè)數(shù)M和階數(shù)K有密切關(guān)系,可以總結(jié)出一個(gè)公式:CodeL=2×M+K+1。碼長(zhǎng)計(jì)算模塊就是根據(jù)這個(gè)原理來(lái)計(jì)算碼長(zhǎng)的,首先通過一組比較器檢測(cè)從位開始有幾個(gè)零,然后根據(jù)上述公式得到碼長(zhǎng)。
在運(yùn)算器中,累加器是專門存放算術(shù)或邏輯運(yùn)算的一個(gè)操作數(shù)和運(yùn)算結(jié)果的寄存器。能進(jìn)行加、減、讀出、移位、循環(huán)移位和求補(bǔ)等操作。是運(yùn)算器的主要部分。在中央處理器CPU中,累加器(accumulator)是一種暫存器,它用來(lái)儲(chǔ)存計(jì)算所產(chǎn)生的中間結(jié)果。如果沒有像累加器這樣的暫存器,那么在每次計(jì)算(加法,乘法,移位等等)后就必須要把結(jié)果寫回到內(nèi)存,然后再讀回來(lái)。然而存取主內(nèi)存的速度是比從數(shù)學(xué)邏輯單元(ALU)到有直接路徑的累加器存取更慢。在匯編語(yǔ)言程序中,累加器——AX是一個(gè)非常重要的寄存器,但在程序中用它來(lái)保存臨時(shí)數(shù)據(jù)時(shí),將其轉(zhuǎn)存到其它寄存器或內(nèi)存單元中,以防止在其它指令的執(zhí)行過程中使其中的數(shù)據(jù)被修改,從而得到不正確的結(jié)果,為程序的調(diào)試帶來(lái)不必要的麻煩。
累加器模塊是一個(gè)模為32的加法器,將碼長(zhǎng)計(jì)算模塊計(jì)算出來(lái)的碼長(zhǎng)CodeL累加到上的移位地址上,得到一個(gè)新的移位地址,筒形移位器根據(jù)這個(gè)新的地址,將本次解碼的碼字移出,準(zhǔn)備好下一個(gè)未解碼碼流。En為進(jìn)位輸出,當(dāng)累加器的En為1時(shí),說(shuō)明已經(jīng)解完了32位數(shù)據(jù),這時(shí)需要對(duì)RegA和RegB進(jìn)行數(shù)據(jù)更新。
計(jì)算碼字的CodeNum時(shí),首先根據(jù)碼長(zhǎng)計(jì)算模塊算出來(lái)的碼字長(zhǎng)度,從上一模塊準(zhǔn)備好的未解碼碼流中把本次要解碼的碼字截取出來(lái),拋棄無(wú)用的位,然后再根據(jù)公式CodeNum=2leadingZeroBits+k-2k+read_bits(leadingZeroBits+k)計(jì)算這個(gè)碼字的CodeNum。顯然這個(gè)公式太過復(fù)雜,不適合直接硬件化,但是經(jīng)過分析公式以及指數(shù)哥倫布碼的結(jié)構(gòu),可以改造一下公式。因?yàn)橹笖?shù)哥倫布碼的結(jié)構(gòu)為前面M個(gè)前導(dǎo)0,中間一個(gè)1,后面M+K位數(shù)據(jù)組成,而read_bits(leadingZeroBits+k)即為后面M+K位數(shù)據(jù)的碼字值,2leadingZeroBits+k正好為中間那個(gè)1的碼字值,所以一個(gè)碼字的CodeNum就等于這個(gè)碼字的碼字值減去2k,這樣對(duì)CodeNum的計(jì)算就大大簡(jiǎn)化了。
2.3語(yǔ)法元素解析模塊
顧名思義,這個(gè)模塊就是終解析出語(yǔ)法元素含義的模塊,它接收上一模塊計(jì)算出來(lái)的CodeNum值,然后主要通過查表的方式解析出這個(gè)碼字所代表的語(yǔ)法元素含義,結(jié)構(gòu)如圖4所示。
這里主要介紹下復(fù)雜的ce(v)部分的解析過程。
逃逸碼判斷模塊:在解析ce(v)語(yǔ)法元素時(shí),首先要判斷是否為逃逸碼,即CodeNum59時(shí),按照正常ce(v)語(yǔ)法元素解析規(guī)則解析;CodeNum≥59時(shí),下一碼字為逃逸碼,則按照逃逸碼解析規(guī)則解析。
3測(cè)試與驗(yàn)證
將本文提出的熵解碼器結(jié)構(gòu)設(shè)計(jì)用VerilogHDL實(shí)現(xiàn),用ModelSim在綜合前進(jìn)行仿真,仿真模型如圖5所示。AVS標(biāo)準(zhǔn)參考軟件產(chǎn)生測(cè)試碼流數(shù)據(jù),將測(cè)試碼流數(shù)據(jù)輸入硬件描述語(yǔ)言仿真模型,然后將輸出數(shù)據(jù)與標(biāo)準(zhǔn)輸出對(duì)比,實(shí)現(xiàn)仿真功能。經(jīng)過測(cè)試,硬件熵解碼后的數(shù)據(jù)與軟件熵解碼后的數(shù)據(jù)完全一致。
整個(gè)電路使用Altera的QuartusII9.0軟件進(jìn)行綜合,使用的LE總數(shù)為1906個(gè)。變字長(zhǎng)解碼器模塊是AVS解碼
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 第5課 歌聲嘹亮-子程序設(shè)計(jì)和機(jī)器人發(fā)音 教學(xué)設(shè)計(jì) 2023-2024學(xué)年清華大學(xué)版(2012)初中信息技術(shù)九年級(jí)下冊(cè)
- 中國(guó)花生廠項(xiàng)目投資可行性研究報(bào)告
- 二手設(shè)備轉(zhuǎn)讓合同協(xié)議書范本簡(jiǎn)版7篇
- 2025年環(huán)氧煤瀝青項(xiàng)目可行性研究報(bào)告
- 古詩(shī)詞誦讀6 泊船瓜洲(教學(xué)設(shè)計(jì))-2023-2024學(xué)年語(yǔ)文六年級(jí)下冊(cè)統(tǒng)編版 -
- 2025年電動(dòng)兒童座車項(xiàng)目投資可行性研究分析報(bào)告-20241226-211206
- 2025年度酒水行業(yè)專業(yè)展會(huì)贊助合同
- 加快建設(shè)現(xiàn)代職業(yè)教育體系的策略及實(shí)施路徑
- 大連幼兒園裝修合同范本
- 15《真理誕生于一百個(gè)問號(hào)之后》教學(xué)設(shè)計(jì)-2024-2025學(xué)年統(tǒng)編版語(yǔ)文六年級(jí)下冊(cè)
- GB/T 45177-2024人工光型植物工廠光環(huán)境技術(shù)規(guī)范
- 2025年中考語(yǔ)文模擬試卷(含答案解析)
- 2025版校園樂器銷售代理與服務(wù)協(xié)議3篇
- 2024-2025年天津河西區(qū)七年級(jí)上學(xué)期期末道德與法治試題(含答案)
- 2025年個(gè)人學(xué)習(xí)領(lǐng)導(dǎo)講話心得體會(huì)和工作措施例文(6篇)
- 新HSK一至六級(jí)詞匯表
- 企業(yè)公司行政人事管理組織架構(gòu)圖帶照片
- 員工預(yù)支現(xiàn)金與費(fèi)用報(bào)銷流程
- 01-第一章運(yùn)動(dòng)學(xué)緒論P(yáng)PT課件
- 安全生產(chǎn)標(biāo)準(zhǔn)化現(xiàn)場(chǎng)評(píng)審方案
評(píng)論
0/150
提交評(píng)論