關(guān)鍵詞:視頻壓縮;重疊塊運動補償,編碼模式
隨著網(wǎng)絡(luò)和多媒體技術(shù)的發(fā)展,越來越多的數(shù)字視頻業(yè)務(wù)不斷涌現(xiàn)。H.264標準正是為適應(yīng)各種業(yè)務(wù)增長對于運動圖像壓縮率的更高要求而制定的。在H.264中,引入了可變大小的塊運動預(yù)測、多幀預(yù)測、1/4像素插值等技術(shù),以進一步提高運動預(yù)測的精度,提高了視頻壓縮效率。
在高壓縮效率下,基于塊運動預(yù)測和補償(block motion compensation,BMC)的視頻壓縮算法會產(chǎn)生塊效應(yīng),嚴重影響了重建視頻的主觀質(zhì)量。在H.264中,在運動預(yù)測/補償環(huán)路中引入去除塊效應(yīng)濾波器以降低塊效應(yīng)的影響。另一方面,文證明了重疊塊運動補償(overlapped blockmotion compensation,OBMC)也是降低塊效應(yīng)、提高預(yù)測精度的一種有效手段,并研究了最優(yōu)重疊塊匹配加權(quán)窗的系數(shù)設(shè)計方法。但以上算法尚未在重疊塊運動補償中有效利用H.264現(xiàn)有編碼框架中的多種預(yù)測模式,在H.264框架中引入重疊塊運動補償,可以進一步提高其編碼效率。
本文提出了一種基于編碼模式的自適應(yīng)重疊塊運動補償算法。該算法根據(jù)周圍已編碼塊的編碼模式,自適應(yīng)選擇加權(quán)系數(shù)提高當前編碼塊的運動預(yù)測精度。實驗結(jié)果表明,本算法在高碼率時,最大編碼增益可達0.21 dB,提高了H.264的編碼效率。
1 基于編碼模式的自適應(yīng)重疊塊運動補償
文提出重疊塊運動補償提高了預(yù)測精度和編碼效率,并均衡了失真分布。在OBMC中,對于當前編碼塊,可以擁有多個備選運動矢量,包括其自身的運動矢量和周圍已編碼塊的運動矢量。通過引入一組加權(quán)系數(shù),對每個候選的運動預(yù)測塊加權(quán)得到最終的運動預(yù)測。
考慮到H.264中最基本的編碼單位是4×4,為了描述方便,本算法中的OBMC選擇的塊大小為4×4。在實際實現(xiàn)中,為了提高運算速度,可以針對不同的編碼模式采取相應(yīng)的OBMC塊大小。對于當前幀內(nèi)每個塊,如圖1所示,其備選運動矢量集由其自身的運動矢量和周圍塊的運動矢量組成。令Bc表示當前編碼塊,Bi(i=1,2,3,4)表示其相鄰塊,相應(yīng)的運動矢量為vc、vi。
如圖2所示,假設(shè)p表示當前編碼塊內(nèi)像素的坐標,表示該像素采用OBMC得到的運動預(yù)測值,則有
其中,fn-1(p)表示參考幀中位置p處的像素值,而ωc(p)、ωi(p),1≤i≤4分別表示OBMC的加權(quán)系數(shù),且應(yīng)滿足以下約束
在對Bc塊進行編碼時,B2和B4塊的運動矢量有可能還未進行編碼(當B2、B4塊與Bc塊不在同一個宏塊中時)。此時為了保證編、解碼的同步,約定B2和B4的運動矢量設(shè)為vc。
由于塊Bi內(nèi)不同位置p的加權(quán)系數(shù)是不均勻的,它們的取值構(gòu)成加權(quán)矩陣Wi。Wi的設(shè)置在很大程度上影響了OBMC的編碼效率。文給出了若干Wi的選取方法,然而,它針對的是運動預(yù)測塊的劃分為固定的情況。
由于H.264中采取了可變大小塊運動預(yù)測,從定性上來看,劃分較小的運動預(yù)測塊所對應(yīng)的運動矢量一般來說更加精確,也更能夠反映相鄰塊的運動趨勢。基于該假設(shè),屬于較小劃分的塊所對應(yīng)的運動矢量,在OBMC中應(yīng)被賦予更大的權(quán)重,以進一步提高OBMC的運動預(yù)測精度,提高編碼效率。
根據(jù)這一推論,本算法采用了一種基于編碼模式的自適應(yīng)OBMC算法。對于當前編碼塊Bc的每個鄰近塊Bi,定義一個加權(quán)矩陣集合si,根據(jù)Bc和Bi的編碼模式,選取合適的加權(quán)矩陣Wi∈Si。也就是說,加權(quán)矩陣的選取策略取決于2個塊各自對應(yīng)的編碼模式。例如,假設(shè)相鄰塊Bl對應(yīng)的運動預(yù)測塊大小為8×8,當Bc的預(yù)測塊大小為16×16,相應(yīng)于v1的加權(quán)系數(shù)矩陣為W161,當Bc的預(yù)測塊大小為4×4時,相應(yīng)于v1的加權(quán)系數(shù)矩陣為W41。加權(quán)矩陣的選擇策略應(yīng)該保證對于加權(quán)矩陣中每個位置(m,n)的系數(shù),都有。在實際實現(xiàn)中,可以采用查找表來存儲選擇策略。同時,加權(quán)矩陣集合和相應(yīng)的選擇策略可以通過對若干測試序列進行訓(xùn)練而獲得。
在采用OBMC后,相應(yīng)運動搜索的度量準則應(yīng)進行相應(yīng)的修正。在本文中,為了降低實現(xiàn)復(fù)雜度,對運動矢量的搜索不采取迭代的方法。此時,在進行運動搜索時,當前塊選取的運動矢量不僅決定了其自身的運動預(yù)測值,也會影響到其右邊及下邊塊的運動預(yù)測值(左邊及上邊塊的運動矢量已經(jīng)確定,不再進行考慮)。為了反映這種影響,將運動搜索的準則重