專利名稱:編碼方法以及裝置、解碼方法以及裝置的制作方法
技術(shù)領(lǐng)域:
本發(fā)明涉及數(shù)據(jù)處理領(lǐng)域,尤其涉及一種編碼方法以及裝置、解碼方法以及裝置。
背景技術(shù):
在現(xiàn)有視頻圖像編碼過程中,編碼端需要對原始圖像塊數(shù)據(jù)或預測后的圖像塊差值數(shù)據(jù)進行空間變換,并對變換系數(shù)進行量化操作,再對量化后的系數(shù)進行熵編碼。解碼端則對熵解碼得到的系數(shù)進行反量化操作,重建得到變換系數(shù),再進行反變換操作得到原始圖像塊數(shù)據(jù)或圖像塊差值數(shù)據(jù)。為在解碼端進行反量化操作,解碼端需獲取編碼端量化過程中所采用的量化步長(QStep)。因此,編碼端需要將所采用的Qstep信息寫入碼流中。由于不同的Qstep可以使用不同的量化參數(shù)(QP,Quantization Parameter)來表示,所以編碼端可以對QP進行編碼,并傳輸?shù)浇獯a端。
高效視頻編碼測試模型(HM,Highefficiency video coding test Model)中將圖像劃分為等大小的最大編碼單元(IXU,Largest Coding Unit),姆個IXU中可以包括一個或多個大小不固定的CU。現(xiàn)有技術(shù)中的ー種圖像編碼方法中,允許具有獨立的QP的最小圖像是IXU,也就是說,每個IXU對應ー個QP。編碼端在進行編碼時,QP相關(guān)信息在圖像參數(shù)集(PPS, Picture ParameterSet)
中的描述為
Die parameter set rosp( ) {
Die mit qp mmus26 /* relative to 26 */
}
在條帶頭(SH, Slice Header)中的描述為 slice header() {slice_qp_delta
}
在LCU中的描述為 coding_tree( xO, yO, log2CUSize ) {
if( !skip_flag[ xO][yO])
Icu qp_delta
}·
編碼端按照上述的方式完成編碼后,將編碼后的數(shù)據(jù)發(fā)送至解碼端,解碼端對每ー個IXU,采用如下方式計算當前IXU的量化參數(shù)QPmi QPlcu = lcu_qp_delta+slice_qp_delta+pic_init_qp_minus26+260解碼端得到當前IXU的QPwu后,即可進行解碼。從上述現(xiàn)有技術(shù)的方案中可以看出現(xiàn)有技術(shù)中,每個IXU對應ー個QP,編碼端在通過調(diào)整QP以進行碼率控制時,只能以LCU為最精細粒度進行控制,由于在實際應用中LCU往往會設(shè)置的比較大,例如64像素*64像素(為簡便描述,后續(xù)簡稱為64*64,其他數(shù)據(jù)類似),所以現(xiàn)有技術(shù)的方案影響了碼率控制的精度。現(xiàn)有技術(shù)中另外ー種圖像編碼方法中,在各LCU的每個CU中都攜帶有該CU的qp_delta信息,從而可以提高碼率控制的精度。但是,在該現(xiàn)有技術(shù)中,由于最小的⑶可以設(shè)置為8*8,若在每個⑶中都攜帶該CU的qp_delta信息,則會增加大量的編碼開銷,從而影響圖像編碼的整體壓縮效率。
發(fā)明內(nèi)容
本發(fā)明實施例提供了一種編碼方法及裝置、解碼方法及裝置以及編解碼系統(tǒng),能夠有效提高碼率控制精度以及壓縮效率。本發(fā)明實施例提供的編碼方法,包括編碼端獲取待編碼數(shù)據(jù),所述待編碼數(shù)據(jù)至少為ー個最大編碼單元LCU ;編碼端按照預置的碼率控制算法確定所述LCU的量化深度參數(shù),并將所述量化深度參數(shù)寫入所述待編碼數(shù)據(jù),所述量化深度參數(shù)用于表示所述LCU中具有獨立QP的最小圖像塊尺寸;編碼端根據(jù)所述最小圖像塊尺寸與所述LCU中包含的各⑶的尺寸確定各⑶的QP ;編碼端根據(jù)所述各⑶的QP以及各⑶的QP預測值計算各⑶的QP差;對于每ー個滿足預置條件的CU,編碼端在該CU中攜帶該CU的QP差;編碼端對所述量化深度參數(shù)、滿足預置條件的CU的QP差、以及各CU進行編碼得到碼流。本發(fā)明實施例提供的解碼方法,包括解碼端對接收到的碼流進行解析得到量化深度參數(shù),所述量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸;解碼端按照所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸計算各CU的QP預測值;對于每ー個滿足預置條件的CU,解碼端從碼流中解析得到其QP差;解碼端根據(jù)所述各CU的QP預測值以及解析得到的QP差計算各CU的QP ;解碼端按照所述各CU的QP對各CU進行解碼。本發(fā)明實施例提供的編碼裝置,包括數(shù)據(jù)獲取単元,用于獲取待編碼數(shù)據(jù),所述待編碼數(shù)據(jù)至少為ー個最大編碼單元LCU;深度參數(shù)處理單元,用于按照預置的碼率控制算法確定所述LCU的量化深度參數(shù),并將所述量化深度參數(shù)寫入所述數(shù)據(jù)獲取單元獲取到的待編碼數(shù)據(jù),所述量化深度參數(shù)用于表示所述LCU中具有獨立QP的最小圖像塊尺寸;量化參數(shù)確定單元,用于根據(jù)所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸確定各CU的QP ;計算單元,用于根據(jù)所述量化參數(shù)確定單元確定的各CU的QP以及各CU的QP預測值計算各CU的QP差;填充單元,用于對于每ー個滿足預置條件的CU,在該CU中攜帶該CU的QP差;編碼單元,用于對所述量化深度參數(shù)、滿足預置條件的CU的QP差、以及各CU進行編碼得到碼流。本發(fā)明實施例提供的解碼裝置,包括第一解析単元,用于對接收到的碼流進行解析得到量化深度參數(shù),所述量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸;參數(shù)預測單元,用于按照所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸計算各CU的QP預測值;第二解析単元,用于對每ー個滿足預置條件的CU,從碼流中解析得到其QP差;參數(shù)計算單元,用于根據(jù)所述參數(shù)預測單元獲得的各CU的QP預測值以及所述第二解析単元解析得到的QP差計算各⑶的QP ;解碼單元,用于按照所述參數(shù)計算單元計算得到的各⑶的QP對各⑶進行解碼。從以上技術(shù)方案可以看出,本發(fā)明實施例具有以下優(yōu)點本發(fā)明實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每ー個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應ー個QP,而由LCU中滿足預置條件的CU對應QP,所以編碼端能夠以CU為最精細粒度進行碼率控制,由于ー個LCU中往往包含多個CU,因此能夠有效提高LCU的碼率控制精度;此外,編碼端僅在滿足預置條件的CU中才攜帶該CU的QP差,而并不會在所有的⑶中都攜帯QP差,所以可以減少編碼開銷,從而有效提高整體壓縮效率。
圖I為本發(fā)明編碼方法一個實施例示意圖;圖2為本發(fā)明解碼方法一個實施例示意圖;圖3為本發(fā)明編解碼方法一個實施例示意圖;圖4為本發(fā)明⑶與鄰近⑶之間的位置關(guān)系示意圖;圖5為本發(fā)明IXU結(jié)構(gòu)示意圖;圖6為本發(fā)明編碼后的ー種碼流結(jié)構(gòu)示意圖;圖7為本發(fā)明編解碼方法另ー實施例示意圖;圖8為本發(fā)明編碼后的另ー碼流結(jié)構(gòu)示意圖;圖9為本發(fā)明編碼裝置一個實施例示意圖;圖10為本發(fā)明編碼裝置另ー實施例示意圖11為本發(fā)明編碼裝置另ー實施例示意圖;圖12為本發(fā)明解碼裝置一個實施例示意圖;圖13為本發(fā)明解碼裝置另ー實施例示意圖;圖14為本發(fā)明解碼裝置另ー實施例示意圖。
具體實施例方式本發(fā)明實施例提供了一種編碼方法以及裝置、解碼方法以及裝置 ,能夠有效提高碼率控制精度以及壓縮效率。請參閱圖1,本發(fā)明實施例中編碼方法一個實施例包括101、編碼端獲取待編碼數(shù)據(jù);本實施例中,編碼端可以獲取到待編碼數(shù)據(jù),該待編碼數(shù)據(jù)至少為ー個LCU,即該待編碼數(shù)據(jù)可以為ー個IXU,也可以為多個IXU組成的數(shù)據(jù)。102、編碼端按照預置的碼率控制算法確定LCU的量化深度參數(shù),并將量化深度參數(shù)寫入待編碼數(shù)據(jù);編碼端根據(jù)預置的碼率控制算法獲取LCU的量化深度參數(shù),該量化深度參數(shù)用于表示IXU中具有獨立QP的最小圖像塊尺寸。需要說明的是,本實施例以及后續(xù)實施例中所描述的尺寸是指邊長,例如某CU為32*32,則定義其尺寸為32。編碼端可以采用嘗試替代的方式獲取LCU的量化深度參數(shù),即不斷調(diào)整量化深度參數(shù)的數(shù)值并進行模擬編碼,使得編碼后的碼率符合預期的要求,具體過程此處不作限定。當編碼端確定了量化深度參數(shù)之后,可以將該量化深度參數(shù)寫入待編碼數(shù)據(jù)中以準備發(fā)送至解碼端。103、編碼端根據(jù)最小圖像塊尺寸與IXU中包含的各⑶的尺寸確定各⑶的QP ;當編碼端獲取到LCU的量化深度參數(shù)之后,可以獲知該量化深度參數(shù)所對應的具有獨立QP的最小圖像塊尺寸,并根據(jù)最小圖像塊尺寸與IXU中包含的各⑶的尺寸確定各CU 的 QP。104、編碼端根據(jù)各⑶的QP以及各⑶的QP預測值計算各⑶的QP差;本實施例中,編碼端可以根據(jù)步驟103中得到的各⑶的QP計算得到各⑶的QP預測值,再根據(jù)該QP預測值,結(jié)合QP,計算得到各CU的QP差。本實施例中,某CU的QP差可以定義為該CU的QP與該CU的QP預測值之間的差值。105、對于每ー個滿足預置條件的⑶,編碼端在該⑶中攜帶該⑶的QP差;當編碼端確定了各⑶的QP差之后,可以從各⑶中選取滿足預置條件的⑶,并且在這些滿足預置條件的⑶中攜帯其QP差。106、編碼端對量化深度參數(shù)、滿足預置條件的⑶的QP差、以及各⑶進行編碼得到碼流。本實施例中,編碼端將量化深度參數(shù)寫入待編碼數(shù)據(jù),且將QP差寫入滿足預置條件的⑶之后,則可以對整個待編碼數(shù)據(jù)進行編碼,即對量化深度參數(shù)、滿足預置條件的⑶的QP差、以及各CU進行編碼,從而得到碼流。
本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每ー個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應ー個QP,而由LCU中滿足預置條件的CU對應QP,所以編碼端能夠以CU為最精細粒度進行碼率控制,由于ー個LCU中往往包含多個CU,因此能夠有效提高LCU的碼率控制精度;此外,編碼端僅在滿足預置條件的CU中才攜帶該CU的QP差,而并不會在所有的⑶中都攜帯QP差,所以可以減少編碼開銷,從而有效提高整體壓縮效率。上面從編碼端的角度描述了本發(fā)明編碼的過程,下面從解碼端的角度描述本發(fā)明解碼的過程,請參閱圖2,本發(fā)明解碼方法一個實施例包括201、解碼端對接收到的碼流進行解析得到量化深度參數(shù); 本實施例中,解碼端可以從編碼端接收到經(jīng)過編碼的碼流,由于編碼端在編碼吋,在待編碼數(shù)據(jù)中寫入了量化深度參數(shù),所以解碼端可以按照預先的約定從碼流相應的位置解析出該量化深度參數(shù)。該量化深度參數(shù)用于表示IXU中具有獨立QP的最小圖像塊尺寸。202、解碼端按照最小圖像塊尺寸與IXU中包含的各⑶的尺寸計算各⑶的QP預測值;本實施例中,解碼端從碼流中解析得到量化深度參數(shù)之后,可以根據(jù)該量化深度參數(shù)獲知具有獨立QP的最小圖像塊尺寸,并且根據(jù)該最小圖像塊尺寸與LCU中包含的各CU的尺寸計算得到各CU的QP預測值。203、對于每ー個滿足預置條件的⑶,解碼端從碼流中解析得到其QP差;本實施例中,解碼端還可以對每ー個滿足預置條件的⑶,從碼流中解析得到該⑶的QP差。需要說明的是,解碼端得到QP差的過程與解碼端計算各CU的QP預測值的過程并無先后順序的限制,可以先執(zhí)行得到QP差的過程,也可以先執(zhí)行計算各CU的QP預測值的過程,或者還可以同時執(zhí)行兩個過程,具體此處不作限定。204、解碼端根據(jù)各⑶的QP預測值以及解析得到的QP差計算各⑶的QP ;解碼端通過步驟202獲知了各⑶的QP預測值以及步驟203解析得到QP差之后,可以根據(jù)這些參數(shù)計算各CU的QP。205、解碼端按照各⑶的QP對各⑶進行解碼。本實施例中,當解碼端獲知各⑶的QP之后,則可以對各⑶進行反量化處理以及后續(xù)的解碼過程,具體此處不作限定。本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每ー個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應ー個QP,所以在解碼端進行解碼時可以針對各CU進行解碼,而無需針對一整個LCU進行解碼,從而能夠提高解碼效率。為便于理解,下面從編解碼的角度進行描述,請參閱圖3,本發(fā)明編解碼方法ー個實施例包括301、編碼端獲取待編碼的序列、圖像或條帶;本實施例中,編碼端獲取到的待編碼數(shù)據(jù)為序列或圖像或條帶,需要說明的是,一個序列中包含若干個圖像,一個圖像中包含若干個條帶,一個條帶中包含若干個LCU。也就是說,本實施例中,編碼端獲取到的待編碼數(shù)據(jù)為多個LCU。302、編碼端按照預置的碼率控制算法確定IXU的量化深度參數(shù)lcu_qp_d印th ;編碼端根據(jù)預置的碼率控制算法獲取對應的lcU_qp_d印th的數(shù)值,具體的,編碼端可以采用嘗試替代的方式獲取lcu_cip_depth的數(shù)值,即不斷調(diào)整lcu_cip_depth的數(shù)值并進行模擬編碼,使得編碼后的碼率符合預期的要求,具體過程此處不作限定。本實施例中的lcu_cip depth的取值范圍可以取O至MaxSymbol內(nèi)的所有整數(shù),其中,MaxSymbol可以通過如下方式計算
MaxSymbol = Iog2 unax_coding_block_size) —Iog2 (min_coding_b丄ock_sizeノ ;其中,max_coding_block_size表不最大的CU 的尺寸,即 LCU 的尺寸,min_coding_block_size表示最小的⑶的尺寸。需要說明的是,本實施例以及后續(xù)實施例中所描述的尺寸是指邊長,例如某CU為32*32,則定義其尺寸為32。本實施例中,該lcu_qp_depth用于表示IXU中具有獨立QP的最小圖像塊尺寸,當lcu_qp_depth為O時,表不具有獨立QP的最小圖像塊即為LQJ,當lcu_cip_depth為I時,表示將IXU劃分為4個32*32的⑶,最小圖像塊尺寸為32,以此類推。本實施例中的lcu_qp_depth是指序列、圖像或條帶中的姆ー個IXU的具有獨立QP的最小圖像塊尺寸,也就是說,該序列、圖像或條帶中的所有LCU均使用相同的lcu_qp_depth。303、編碼端將lcu_qp_d印th寫入序列參數(shù)集、圖像參數(shù)集或條帶頭信息;本實施例中,編碼端在獲取到lcu_cip_depth的數(shù)值之后,可以將該lcu_cip_depth寫入待編碼數(shù)據(jù)編碼端可以將lcu_cip_depth寫入該序列的序列參數(shù)集(SPS, SequenceParameterSet),具體可以如下所示
sea Oarameter set rbspt ) { Icu qp aeptn
}或者,編碼端可以將lcu_qp_d印th寫入該圖像的PPS,具體可以如下所示
Pic Oarameter set rbspt ) {
Icu qp depth
}
或者,編碼端可以將lcu_qp_cbpth寫入該條帶的條帶頭信息,具體可以如下所
示
slice_header() {lcu_qp_depth
}可以理解的是,本實施例中僅以幾個例子說明了 lcu_qp_depth的寫入位置,在實際應用中,該lcu_qp_cbpth還可以寫入序列、圖像或條帶的其他位置,具體此處不作限定。304、編碼端計算包含獨立QP的最小圖像塊尺寸QPBlkSize ;編碼端獲取到lcu_cip_depth之后,可以根據(jù)該lcu_cip_depth計算最小圖像塊QPBlk 的尺寸 QPBlkSize。假設(shè)IXU大小為max_coding_block_size,則QPBlkSize可以通過如下的方式計算得到QPBlkSize = max_coding_block_size/ (2lcu-qp-depth)。例如,當max_coding_block_size 為 64, lcu_qp_depth 為 2 時,則 QPBlkSize 為16,即最小圖像塊為16*16的⑶。305、編碼端根據(jù)QPBlkSize、CU的尺寸獲取各CU的QP ;本實施例中,編碼端可以分以下幾種情況獲取各CU的QP 對于尺寸大于或等于QPBlkSize的⑶,編碼端按照預置的碼率控制算法計算該⑶的QP ;對于尺寸小于QPBlkSize的⑶,編碼端首先確定該⑶所屬的最小圖像塊,然后按照預置的碼率控制算法計算該最小圖像塊的QP,并將該最小圖像塊的QP作為該最小圖像塊中所有⑶的QP。本實施例中,編碼端按照預置的碼率控制算法計算QP的過程為本領(lǐng)域技術(shù)人員的公知常識,具體此處不作限定。306、編碼端獲取各CU的QP預測值;當編碼端獲取到各⑶的QP之后,則可以按照編碼次序(解碼次序與編碼次序相同),使用各CU鄰近的已編碼的CU的QP獲取各CU的QP預測值。典型的,該鄰近已編碼的⑶包括左⑶,上⑶與左上⑶。為便于描述,首先對參考CU進行定義編碼端將每一個尺寸大于或等于QPBlkSize的⑶作為一個參考⑶,且對于尺寸小于QPBlkSize的⑶,編碼端確定該⑶所屬的最小圖像塊,并將該最小圖像塊的左上⑶作為一個參考CU。定義了參考⑶之后,編碼端可以根據(jù)各參考⑶的該鄰近⑶的QP計算各參考⑶的QP預測值,具體的計算方式可以有多種,下面以幾個例子進行說明 一、采用左⑶、上⑶以及左上⑶進行計算
請參閱圖4,其中,CU。為某參考⑶,該⑶可以是一個尺寸大于或等于QPBlkSize的⑶,也可以是位于最小圖像塊的左上角的⑶。CUu為CUc的上CU,CUl為CUc的左CU,CUul為CUc的左上CU,本實施例中,CUc的鄰近⑶為左⑶、上⑶以及左上⑶,其中CUc的左上角像素坐標為(X。,y。),則CUl為包含像素點(x「l,yc)的CU, CUu為包含像素點(X。,yc-l)的CU,CUul為包含像素點(Xe-I,Yc-D的⑶。編碼端確定了參考⑶的鄰近⑶之后,可以根據(jù)步驟305計算的結(jié)果獲取這些⑶的 QP,其中,CUc 的 QP 為 QP。,CUu 的 QP 為 QPu, CUl 的 QP 為 QP^ CUul 的 QP 為 QP皿。需要說明的是,并不是每一個⑶都能獲取到其左⑶、上⑶以及左上⑶,例如本身就位于圖像或條帶最左側(cè)的CU就不會存在左CU,因此,編碼端可以按照如下一些具體條件確定各CU的預測值 (I)若CUc的鄰近⑶均不存在,則根據(jù)該CUc所屬的條帶以及圖像確定該CUdAQP預測值QPp ;具體的,QPp= slice_qP_delta+pic_init_cip_minus26+26,其中,slice_qp_delta為包含在條帶頭信息中的信息,pic_init_qp_minus26為包含在圖像參數(shù)集中的信息。(2)若CUc只存在CUl,則將QPl作為QPp ;(3)若CUc只存在CUu,則將QPu作為QPp ;(4)若CUcW鄰近⑶均存在,則獲取QPl與QPul之間的第一差異I QPfQPuL I,以及QPu與QPul之間的第二差異I QPu-QPm I。若I QPl-QPul I < I QPfQP肌I,則表示QPl和QPul的差異小于QPu和QPul的差異。這種情況下,( 和CUm很有可能屬于圖像中的同一個物體,物體邊緣出現(xiàn)在CUu和CUm邊緣,所以可以采用QPu作為QPp; 若I QPfQPm I > = I QPu-QPul I,按照上述的推理,則可以將QP^作為QPP。在實際應用中,可以用下述代碼實現(xiàn)上述流程if((QPL exists) && (QPul exists) && (QPu exists) &&(|QPL — QPUL| < IQPu —QPulI))
QPp =QPu;
else if ((QPl exists) && (QPul exists) && (QPu exists) &&|QPL _ QPUL| >IQPu-QPulI))
QPp = QPl;
else if (QPl exists)
QPp = QPl;
else if (QPu exists)
QPp = QPu;
else
QPp = slice_qp—delta + pic_init_qp_minus26 + 26可以理解的是,上述的代碼僅僅是實現(xiàn)過程中的一個例子,在實際應用中,還可以使用其他類似的代碼實現(xiàn),具體實現(xiàn)方式此處不作限定。二、采用左⑶、上⑶以及前一被編碼⑶進行計算同樣請參閱圖4,本實施例中,可以使用( 以及CUu作為某參考CU。的鄰近CU,CUc可以是一個尺寸大于或等于QPBlkSize的⑶,也可以是位于最小圖像塊的左上角的⑶。CUc的左上角像素坐標為(X。,y。),則CUl為包含像素點(x「l,yc)的CU, CUu為包含像素點(X。,Yc-D 的 CU,CUc 的 QP 為 QPC,CUu 的 QP 為 QPu, CUl 的 QP 為 QP”需要說明的是,并不是每一個CU都能獲取到其左CU以及上CU,例如本身就位于圖像或條帶最左側(cè)的⑶就不會存在左⑶,因此,編碼端可以按照如下一些具體條件確定各⑶的預測值(I)若CUc的CUl存在,則將QPl作為QPp ;(2)若CU。的( 不存在,且CU。的CUu或該CU。的前一被編碼CU存在,則將QPu或前一被編碼⑶的QP作為QPp ; (3)若CUc的CUl不存在,且CUc的CUu與該CUc的前一被編碼CU都存在,則將QPu或前一被編碼⑶的QP作為QPP,具體使用QPu還是前一被編碼⑶的QP作為QPP,可在編解碼端預先規(guī)定;(4)若CUc的CUl,CUu以及前一被編碼CU均不存在,則根據(jù)該CUc所屬的條帶以及圖像確定QPp 具體的,QPp= slice_cip_delta+pic_init_cip_minus26+26,其中,slice_qp_delta為包含在條帶頭信息中的信息,pic_init_qp_minus26為包含在圖像參數(shù)集中的信息。上述僅以兩個例子說明了編碼端計算各參考⑶的QP預測值的過程,可以理解的是,在實際應用中,編碼端還可以采用更多的方式計算各參考CU的QP預測值,具體此處不作限定。
307、編碼端將滿足預置條件的CU的QP差cu_qp_delta寫入該CU ;
編碼端通過步驟305計算得到了各⑶的QP,通過步驟306計算得到了各參考⑶的QP預測值,則編碼端可以根據(jù)這些參數(shù)進一步計算各⑶的QP差cu_qp_delta,具體計算方式可以為對于每一個參考⑶,編碼端將該 參考⑶的QP與該參考⑶的QP預測值之間的差值作為該參考CU的QP差,即cu_qp_delta = QPc-QPp ;若該參考CU所屬的最小圖像塊中包含其它CU,則編碼端將該參考CU的QP差作為該最小圖像塊內(nèi)其它⑶的QP差。也就是說,對于⑶的尺寸大于或等于QPBlkSize的⑶,由于這一類⑶本身即是參考CU,所以編碼端可以將這些CU的QP與QP預測值之間的差值作為這些CU的cu_qp_delta ;對于⑶的尺寸小于QPBlkSize的⑶,即相當于一個最小圖像塊中包含若干個⑶,該最小圖像塊的左上角的⑶為參考⑶,通過步驟306可以獲知該參考⑶的QP預測值,再結(jié)合步驟305中計算的QP可以得到該參考⑶的cu_qp_delta = QPc-QPp,之后再將該參考CU的cu_qp_delta賦值給該最小圖像塊內(nèi)其他的CU,需要說明的是,在實際應用中,除了使用賦值操作之外,還可以采用別的方式處理,例如若判斷該最小圖像塊中某CU滿足預置條件,則將該⑶中攜帶該⑶所屬的最小圖像塊的參考⑶的cu_qp_delta。本實施例中,編碼端獲取到各⑶的cu_qp_delta之后,可以在滿足預置條件的⑶中攜帶該CU的cu_qp_delta,具體的滿足預置條件的CU可以為在其壓縮碼流中存在非零量化后變換系數(shù)的CU。若某CU采用skip編碼模式,則其壓縮碼流中不會存在非零量化后變換系數(shù),則此類⑶不滿足預置條件,若不采用skip編碼模式,則⑶在其壓縮碼流中可能會包含有非零量化后變換系數(shù),這部分CU則滿足預置條件。本實施例中,對于滿足預置條件的⑶,編碼端可以將該⑶的cu_qp_delta寫入該⑶的如下位置
Coding_unit( x0, yO, log2CUSize ) { if( slice—type != I)
Skip_flag[ x0 ] [ yO ] if( skip_flag[ x0][y0])
prediction_unit( xO, yO, log2CUSize, log2CUSize ) else {
Prediction_unit( xO, yO, Iog2CUSize, Iog2CUSize ) Transform_tree( xO, yO, Iog2CUSize, 0, 0 ){
if (sig_coeff_num > 0) {
cu_qp_delta
transform_coeff( xO, yO, Iog2TrafoSize, trafoDepth, cldx )
}
}
}其中,sig_coeff_num > O是當前QJ對應的碼流中是否存在cu_qp_delta的判決條件,若該判決條件為真,則說明當前CU對應的碼流中存在cu_qp_delta,若該判決條件為假,則說明當前⑶對應的碼流中不存在cu_cip_delta。 需要說明的是,對于尺寸小于QPBlkSize的⑶而言,編碼端按照編碼次序依次判斷該CU所屬的最小圖像塊中的CU是否滿足預置條件,若一個CU不滿足預置條件,則繼續(xù)判斷后續(xù)的CU是否滿足預置條件,若后續(xù)的某個CU滿足預置條件,則將該CU的cu_qp_delta寫入該⑶中,并且停止判斷,即不再為該最小圖像塊中的其他⑶寫入CU_qp_delta,而無論這些⑶是否滿足預置條件。需要說明的是,由于并非所有CU均滿足該預置條件,所以編碼端除了在滿足預置條件的⑶中攜帶該⑶的cu_qp_delta之外,還可以對不滿足預置條件的⑶的QP進行重新設(shè)置,具體方式可以為對于每一個不滿足預置條件的⑶,編碼端通過如下方式設(shè)置該⑶的QP :對于尺寸大于或等于QPBlkSize的⑶,編碼端將該⑶的QP預測值作為該⑶的QP ;對于尺寸小于QPBlkSize的⑶,若該⑶所屬的最小圖像塊中的其它⑶均不滿足預置條件,則編碼端將該CU所屬的最小圖像塊中的參考CU的QP預測值作為該CU的QP。通過上述對不滿足預置條件的⑶的QP的重新設(shè)置,可以保證后續(xù)編碼⑶在進行QP預測時能夠獲取與解碼端相同的預測值。308、編碼端對lcu_cip_depth、cu_qp_delta以及各QJ進行編碼得到碼流;編碼端在獲取到lcu_cip_depth、cu_qp_delta之后可以對各⑶進行編碼,本實施例中,編碼端對lcu_qp_depth進行編碼的過程可以包括編碼端采用定長碼或變長碼對lcu_qp_cbpth進行二值化得到對應的二進制碼字;編碼端將獲得的二進制碼字按照定長編碼、變長編碼或算術(shù)熵編碼的方法寫入步驟302中確定的位置所對應的碼流。其中,編碼端所采用的變長碼可以為無符號的指數(shù)哥倫布碼,或其他類似的變長碼,具體此處不作限定。編碼端對cu_qp_delta進行編碼的過程可以包括
編碼端采用變長碼對滿足預置條件的⑶的CU_qp_delta進行二值化得到對應的
二進制碼字;編碼端將獲得的二進制碼字按照變長編碼或算術(shù)熵編碼的方法寫入碼流。編碼端將獲得的二進制碼字按照定長編碼、變長編碼或算術(shù)熵編碼的方法寫入步驟307中確定的位置所對應的碼流。其中,編碼端所采用的變長碼可以為帶符號的指數(shù)哥倫布碼,或其他類似的變長碼,具體此處不作限定。本實施例中,編碼端對CU的編碼過程此處不作限定,當編碼完成后即得到碼流,編碼端可以向解碼端發(fā)送該碼流。
309、解碼端對接收到的碼流進行解碼得到lcu_cip_depth ;解碼端接收到碼流之后,可以根據(jù)預先與編碼端的約定獲知lcU_qp_cbpth在碼流中所處的位置為SPS,或PPS,或SH,從而對這部分的內(nèi)容使用定長解碼、變長解碼或算術(shù)熵解碼的方法獲取二進制碼字;解碼端采用定長碼或變長碼對二進制碼字進行逆二值化得到lcu_qp_cbpth。本實施例中的變長碼可以為無符號的指數(shù)哥倫布碼,或者是其他類似的變長碼,具體此處不作限定。本實施例中的lcu_qp_depth用于表示序列、或圖像、或條帶中每一個IXU中具有獨立QP的最小圖像塊尺寸。310、解碼端計算包含獨立QP的最小圖像塊尺寸QPBlkSize ; 解碼端計算得到lcu_(ip_depth之后,可以根據(jù)該lcu_cip_depth計算得到QPBlkSize,具體的計算方式可以與前述步驟304中編碼端計算QPBlkSize的方式相同,具體此處不再贅述。311、解碼端從滿足預置條件的⑶中解析得到該⑶的cu_cip_delta ;本實施例中,對于每一個滿足預置條件的CU,解碼端可以從該CU的碼流中對應的位置使用變長解碼或算術(shù)熵解碼的方法獲取二進制碼字;解碼端采用變長碼對二進制碼字進行逆二值化得到該⑶的cu_qp_delta。本實施例中的變長碼可以為帶符號的指數(shù)哥倫布碼,或者是其他類似的變長碼,具體此處不作限定。需要說明的是,按照前述步驟307中的描述,sig_coeff_num > O是當前⑶對應的碼流中是否存在cu_qp_delta的判決條件,所以解碼端可以通過校驗該判決條件以獲知該CU是否滿足預置條件,滿足預置條件的CU同樣可以為在其壓縮碼流中存在非零量化后變換系數(shù)的CU。本實施例中,由于不是所有CU都是滿足預置條件的CU,所以解碼端可以按照如下方式確定所有⑶的cu_cip_delta 對于每一個尺寸大于或等于QPBlkSize的⑶,解碼端判斷該⑶是否滿足預置條件,若滿足,則從該⑶中解析該⑶的cu_qp_delta,若不滿足,則將該⑶的cu_qp_delta設(shè)置為O ;對于尺寸小于QPBlkSize的⑶,解碼端確定該⑶所屬的最小圖像塊,并按照該最小圖像塊中CU的解碼次序,依次判斷該最小圖像塊中每一個CU是否滿足預置條件,若滿足,則停止判斷,并將該⑶的cu_cip_delta作為該最小圖像塊中所有⑶的cu_cip_delta,若該最小圖像塊中所有CU均不滿足預置條件,則將該最小圖像塊中所有CU的cu_qp_delta設(shè)置為O。312、解碼端根據(jù)QPBlkSize、CU的尺寸獲取各CU的QP預測值;當解碼端獲取到QPBlkSize之后,則可以根據(jù)各CU的尺寸以及該QPBlkSize獲取各⑶的QP預測值。本步驟具體過程與前述步驟306中編碼端獲取各CU的QP預測值的方式相同。按306中描述,鄰近區(qū)域為已編碼或已解碼區(qū)域,因為編碼次序與解碼次序相同,所以已編碼區(qū)域與已解碼區(qū)域為統(tǒng)一區(qū)域。因為該臨近區(qū)域內(nèi)CU的QP都可得,所以可按照306中相 同的方法獲得各CU的QP預測值。當獲得各⑶的QP預測值之后,結(jié)合步驟311中獲取到的各⑶的cu_qp_delta,則可以得到該⑶的QP,即QP = QP預測值+cu_cip_delta。313、解碼端根據(jù)各CU的QP預測值及cu_cip_delta計算各⑶的QP ;解碼端計算得到各⑶的QP預測值之后,則可以根據(jù)各⑶的QP預測值及cu_qp_delta計算各⑶的QP,具體方式可以為對于尺寸大于或等于QPBlkSize,且不滿足預置條件的⑶,解碼端將該⑶的QP預測值作為該⑶的QP ;對于尺寸大于或等于QPBlkSize,且滿足預置條件的⑶,解碼端將該⑶的QP預測值與該CU的cu_qp_delta之和作為該CU的QP ;對于尺寸小于QPBlkSize的CU,若該⑶滿足預置條件,則解碼端獲取該⑶所屬的最小圖像塊的左上⑶的QP預測值,并將該QP預測值與該cu_qp_delta之和作為該⑶的QP,并將該CU的QP作為該最小圖像塊中所有CU的QP ;對于尺寸小于QPBlkSize的⑶,若該⑶所屬的最小圖像塊中所有⑶均不滿足預置條件,則解碼端獲取該⑶所屬的最小圖像塊的左上⑶的QP預測值,并將該QP預測值作為該最小圖像塊中所有⑶的QP。314、解碼端按照各⑶的QP對各⑶進行解碼。本實施例中,解碼端可以使用步驟313中得到各⑶的QP對各⑶進行反量化處理以及后續(xù)的解碼過程,具體此處不作限定。為便于理解,下面以一具體實例對本發(fā)明編解碼方法進行簡要描述,請參閱圖5,圖5為本發(fā)明LCU結(jié)構(gòu)不意圖,其中,max_coding_block_size為64, QPBlkSize為16。從圖5中可以看出,該IXU中包含37個⑶,其中,畫叉的⑶為采用skip編碼的⑶,即不滿足預置條件的⑶,其余的⑶中,假設(shè)⑶3和⑶23在其壓縮碼流中包含量化后變換系數(shù)全部為0,則CU3以及CU23也為不滿足預置條件的CU,其余的CU為滿足預置條件的CU。則按照前述圖3實施例中所描述的編碼過程,圖5所示的LCU經(jīng)過編碼之后得到的碼流結(jié)構(gòu)如圖6所示,Ml, M2. . . M37等為頭信息,Cl,C4. . . C37等為變換系數(shù),DQPl,DQP4. . . DQP37 等為 cu_qp_delta0本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每一個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個IXU不僅僅再對應一個QP,而由IXU中滿足預置條件的⑶來對應QP,所以編碼端能夠以CU為最精細粒度進行碼率控制,由于一個LCU中往往包含多個CU,因此能夠有效提高LCU的碼率控制精度;其次,編碼端僅在滿足預置條件的CU中才攜帶該CU的QP差,而并不會在所有的CU中都攜帶QP差,所以可以減少編碼開銷,從而有效提高整體壓縮效率;再次,本實施例中,編碼端和解碼端計算CU的QP預測值時可以采用多種預測方式,使得計算過程更加靈活,從而能適應多個不同的環(huán)境。上面介紹了一種編解碼方法,下面介紹另外一種編解碼方法,具體請參閱圖7,本發(fā)明編解碼方法另一實施例包括701、編碼端獲取待編碼的IXU ;本實施例中,編碼端獲取到的待編碼數(shù)據(jù)為一個LCU。
702、編碼端按照預置的碼率控制算法確定IXU的量化深度參數(shù)lcu_qp_cbpth ;編碼端根據(jù)預置的碼率控制算法獲取對應的lcU_qp_cbpth的數(shù)值,具體的,編碼端可以采用嘗試替代的方式獲取lcu_cip_depth的數(shù)值,即不斷調(diào)整lcu_cip_depth的數(shù)值并進行模擬編碼,使得編碼后的碼率符合預期的要求,具體過程此處不作限定。本實施例中的lcu_cip_depth的取值范圍可以取O至MaxSymbol內(nèi)的所有整數(shù),其中,MaxSymbol可以通過如下方式計算MaxSymbol = Iog2 (max_coding_block_size)-Iog2 (min_coding_block_size);其中,max_coding_block_size表示最大的 QJ 的尺寸,即 IXU 的尺寸,min_coding_block_size表示最小的⑶的尺寸。需要說明的是,本實施例以及后續(xù)實施例中所描述的尺寸是指邊長,例如某CU為32*32,則定義其尺寸為32。本實施例中,該lcu_qp_depth用于表示IXU中具有獨立QP的最小圖像塊尺寸,當lcu_qp_depth為O時,表不具有獨立QP的最小圖像塊即為LQJ,當lcu_cip_depth為I時,表示將IXU劃分為4個32*32的⑶,最小圖像塊尺寸為32,以此類推。本實施例中的lcu_qp_cbpth是指當前的一個IXU的具有獨立QP的最小圖像塊尺寸,也就是說,該序列、圖像或條帶中的每一個IXU均使用獨立的lcu_qp_depth,每一個IXU所使用的lcu_qp_depth均有可能不相同。703、編碼端將lcu_cip_depth寫入當前IXU中按編碼次序第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU中;本實施例中,編碼端在獲取到lcu_cip_depth的數(shù)值之后,可以將該lcu_cip_depth寫入當前LCU中按編碼次序第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU中slice_data() {
CurrTbAddr = first_tb_in_slice moreDataFlag = I do {
xCU = HorLumaLocation( CurrTbAddr) yCU = VerLumaLocation( CurrTbAddr) lcu_qp_depthFlag = I coding_tree( xCU, yCU, Log2TbSize ){
coding_unit( xO, yO, log2CUSize ) { if( slice—type != I) skip_flag[ xO ] [ yO ] if(!skip_flag[ xO][yO]&& lcu_qp_depthFlag){ if (sig_coeff_num > 0) {
lcu_qp_depth lcu_qp_depthFlag = 0
}
}
}
}
} while( moreDataFlag )
}其中,引入lcu_qp_cbpthFlag變量是為達到僅為在第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU中傳輸lcu_qp_depth的目的。當然也可使用其它方法實現(xiàn)同樣的碼流結(jié)構(gòu)。本實施例中,sig_coeff_num > O是當前⑶碼流中是否存在lcu_cip_depth的判決條件。在滿足該判決條件時,lcu_qp_depth也可放在當前CU碼流中的其它位置,具體此處不作限定。由于并不是每一個⑶都符合攜帶lcu_qp_depth的條件,所以,本實施例中,編碼端在當前IXU中,按照⑶的編碼順序,對每一個⑶檢驗其是否具備攜帶lcu_qp_depth的條件,即該CU是否為第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU。如果當前⑶不具備攜帶lcu_qp_depth的條件,則編碼端繼續(xù)對當前IXU種后續(xù)的CU進行檢驗。若在某CU中發(fā)現(xiàn)其具備攜帶lcU_qp_depth的條件,則在前述規(guī)定的位置將 lcu_cip_depth 寫入該 CU。本實施例中,當編碼端在某個⑶中寫入了 lcu_qp_depth之后,貝U無需在該⑶所屬的LQJ的其他QJ中再寫入lcu_cip_depth。704 708、與前述圖3所示實施例中的步驟304 308相同,此 處 不再贅述。709、解碼端對接收到的碼流進行解碼得到lcu_cip_depth ;解碼端接收到碼流之后,可以根據(jù)預先與編碼端的約定獲知lcU_qp_cbpth在碼流中所處的位置,從而對這部分的內(nèi)容使用定長解碼、變長解碼或算術(shù)熵解碼的方法獲取二進制碼字;解碼端采用定長碼或變長碼對二進制碼字進行逆二值化得到lcu_qp_cbpth。本實施例中的變長碼可以為無符號的道數(shù)哥倫布碼,或者是其他類似的變長碼,具體此處不作限定。本實施例中的lcu_qp_cbpth用于表示當前的IXU中具有獨立QP的最小圖像塊尺寸。710 714、與前述圖3所示實施例中描述的步驟310 314相同,此處不再贅述。為便于理解,下面以一具體實例對本發(fā)明編解碼方法進行簡要描述,同樣請參閱圖5,圖5為本發(fā)明IXU結(jié)構(gòu)不意圖,其中,max_coding_block_size為64, QPBlkSize為16。從圖5中可以看出,該IXU中包含37個⑶,其中,畫叉的⑶為采用skip編碼的⑶,即不滿足預置條件的⑶,其余的⑶中,假設(shè)⑶3和⑶23在其壓縮碼流中包含量化后變換系數(shù)全部為0,則CU3以及CU23也為不滿足預置條件的CU,其余的CU為滿足預置條件的CU。則按照前述圖7所示實施例中所描述的編碼過程,圖5所示的IXU經(jīng)過編碼之后得到的碼流結(jié)構(gòu)如圖8所示,depth為lcu_cip_depth, Ml, M2. . . M37等為頭信息,Cl,C4. · · C37 等為變換系數(shù),DQPl,DQP4. · · DQP37 等為 cu_qp_delta。本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每一個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應一個QP,而由LCU中滿足預置條件的CU對應QP,所以編碼端能夠以CU為最精細粒度進行碼率控制,由于一個LCU中往往包含多個CU,因此能夠有效提高LCU的碼率控制精度;其次,編碼端僅在滿足預置條件的CU中才攜帶該CU的QP差,而并不會在所有的CU中都攜帶QP差,所以可以減少編碼開銷,從而有效提高整體壓縮效率;再次,本實施例中,編碼端和解碼端計算CU的QP預測值時可以采用多種預測方式,使得計算過程更加靈活,從而能適應多個不同的環(huán)境;更進一步,本實施例中,lcu_qp_depth用于表示當前的IXU中具有獨立QP的最小圖像塊尺寸,所以每個IXU會攜帶一個lcu_qp_depth,使得不同的IXU可以使用不同的lcu_cip_depth,從而能夠進一步提高IXU的碼率控制精度。
下面對本發(fā)明編碼裝置實施例進行描述,請參閱圖9,本發(fā)明編碼裝置一個實施例包括數(shù)據(jù)獲取單元901,用于獲取待編碼數(shù)據(jù),該待編碼數(shù)據(jù)至少為一個最大編碼單元LCU ;深度參數(shù)處理單元902,用于按照預置的碼率控制算法確定該IXU的量化深度參數(shù),并將該量化深度參數(shù)寫入該數(shù)據(jù)獲取單元901獲取到的待編碼數(shù)據(jù),該量化深度參數(shù)用于表示該LCU中具有獨立QP的最小圖像塊尺寸;量化參數(shù)確定單元903,用于根據(jù)該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸確定各⑶的QP ; 計算單元904,用于根據(jù)該量化參數(shù)確定單元903確定的各⑶的QP以及各⑶的QP預測值計算各CU的QP差;填充單元905,用于對于每一個滿足預置條件的⑶,在該⑶中攜帶該⑶的QP差;編碼單元906,用于對該量化深度參數(shù)、滿足預置條件的⑶的QP差、以及各⑶進行編碼得到碼流。為便于理解,下面對本發(fā)明編碼裝置進行詳細描述,具體請參閱圖10,本發(fā)明編碼裝置另一實施例包括數(shù)據(jù)獲取單元1001,用于獲取待編碼數(shù)據(jù),該待編碼數(shù)據(jù)至少為一個最大編碼單元 LCU ;深度參數(shù)處理單元1002,用于按照預置的碼率控制算法確定該IXU的量化深度參數(shù),并將該量化深度參數(shù)寫入該數(shù)據(jù)獲取單元1001獲取到的待編碼數(shù)據(jù),該量化深度參數(shù)用于表示該LCU中具有獨立QP的最小圖像塊尺寸;量化參數(shù)確定單元1003,用于根據(jù)該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸確定各⑶的QP ;計算單元1005,用于根據(jù)該量化參數(shù)確定單元1003確定的各⑶的QP以及各⑶的QP預測值計算各CU的QP差;填充單元1006,用于對于每一個滿足預置條件的⑶,在該⑶中攜帶該⑶的QP差;編碼單元1007,用于對該量化深度參數(shù)、滿足預置條件的⑶的QP差、以及各⑶進行編碼得到碼流。本實施例中的編碼裝置還可以進一步包括預測單元1004,用于根據(jù)各參考⑶的鄰近⑶的QP計算各參考⑶的QP預測值;對于尺寸大于或等于該最小圖像塊尺寸的⑶,每一個⑶作為一個參考⑶,對于尺寸小于該最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶。本實施例中的預測單元1004包括第一校驗模塊10041,用于對每一個參考⑶,判斷該參考⑶的鄰近⑶是否存在,該參考⑶的鄰近⑶包括該參考⑶的左⑶,上⑶以及左上⑶;第一預測模塊10042,用于當該參考⑶的鄰近⑶均不存在時,根據(jù)該參考⑶所屬的條帶以及圖像確定該參考CU的QP預測值;第二預測模塊10043,用于當該參考⑶只存在左⑶時,將該左⑶的QP作為該參考CU的QP預測值;第三預測模塊10044,用于當該參考⑶只存在上⑶時,將該上⑶的QP作為該參考CU的QP預測值;第四預測模塊10045,用于當該參考⑶的鄰近⑶均存在時,獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若該第一差異小于第二差異,則將該上CU的QP作為該參考CU的QP預測值,若該第一差異大于或等于第二差異,則將該左CU的QP作為該參考CU的QP預測值。請參閱圖11,本發(fā)明編碼裝置另一實施例包括數(shù)據(jù)獲取單元1101,用于獲取待編碼數(shù)據(jù),該待編碼數(shù)據(jù)至少為一 個最大編碼單元 LCU ;深度參數(shù)處理單元1102,用于按照預置的碼率控制算法確定該IXU的量化深度參數(shù),并將該量化深度參數(shù)寫入該數(shù)據(jù)獲取單元1101獲取到的待編碼數(shù)據(jù),該量化深度參數(shù)用于表示該LCU中具有獨立QP的最小圖像塊尺寸;量化參數(shù)確定單元1103,用于根據(jù)該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸確定各⑶的QP ;計算單元1105,用于根據(jù)該量化參數(shù)確定單元1103確定的各⑶的QP以及各⑶的QP預測值計算各CU的QP差;填充單元1106,用于對于每一個滿足預置條件的⑶,在該⑶中攜帶該⑶的QP差;編碼單元1107,用于對該量化深度參數(shù)、滿足預置條件的⑶的QP差、以及各⑶進行編碼得到碼流。本實施例中的編碼裝置還可以進一步包括預測單元1104,用于根據(jù)各參考⑶的鄰近⑶的QP計算各參考⑶的QP預測值;對于尺寸大于或等于該最小圖像塊尺寸的⑶,每一個⑶作為一個參考⑶,對于尺寸小于該最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶。本實施例中的預測單元1104包括第二校驗模塊11041,用于對每一個參考⑶,判斷該參考⑶的左⑶是否存在;第五預測模塊11042,用于當該參考⑶的左⑶存在時,將該左⑶的QP作為該參考CU的QP預測值;第六預測模塊11043,用于當該參考⑶的左⑶不存在,且該參考⑶的上⑶或該參考⑶的前一被編碼⑶存在時,將該上⑶的QP或前一被編碼⑶的QP作為該參考⑶的QP預測值;第七預測模塊11044,用于當該參考⑶的左⑶,上⑶以及前一被編碼⑶均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值。本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每一個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應一個QP,而由LCU中滿足預置條件的CU對應QP,所以編碼端能夠以CU為最精細粒度進行碼率控制,由于一個LCU中往往包含多個CU,因此能夠有效提高LCU的碼率控制精度;
其次,編碼端僅在滿足預置條件的CU中才攜帶該CU的QP差,而并不會在所有的⑶中都攜帶QP差,所以可以減少編碼開銷,從而有效提高整體壓縮效率。下面對本發(fā)明編碼裝置實施例進行描述,請參閱圖12,本發(fā)明解碼裝置一個實施例包括第一解析單元1201,用于對接收到的碼流進行解析得到量化深度參數(shù),該量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸;參數(shù)預測單元1202,用于按照該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸計算各⑶的QP預測值;第二解析單元1203,用于對每一個滿足預置條件的⑶,從碼流中解析得到其QP差; 參數(shù)計算單元1204,用于根據(jù)該參數(shù)預測單元1202獲得的各⑶的QP預測值以及該第二解析單元1203解析得到的QP差計算各CU的QP ;解碼單元1205,用于按照該參數(shù)計算單元1204計算得到的各⑶的QP對各⑶進行解碼。為便于理解,下面對本發(fā)明編碼裝置進行詳細描述,具體請參閱圖13,本發(fā)明解碼裝置另一實施例包括第一解析單元1301,用于對接收到的碼流進行解析得到量化深度參數(shù),該量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸;參數(shù)預測單元1302,用于按照該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸計算各⑶的QP預測值;第二解析單元1303,用于對每一個滿足預置條件的⑶,從碼流中解析得到其QP差;參數(shù)計算單元1304,用于根據(jù)該參數(shù)預測單元1302獲得的各⑶的QP預測值以及該第二解析單元1303解析得到的QP差計算各CU的QP ;解碼單元1305,用于按照該參數(shù)計算單元計算得到的各⑶的QP對各⑶進行解碼。其中,參數(shù)預測單元1302可以進一步包括第一參數(shù)校驗模塊13021,用于對每一個參考⑶,判斷該參考⑶的鄰近⑶是否存在,該參考⑶的鄰近⑶包括該參考⑶的左⑶,上⑶以及左上⑶,對于尺寸大于或等于該最小圖像塊尺寸的⑶,每一個⑶作為一個參考⑶,對于尺寸小于該最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶;第一參數(shù)預測模塊13022,用于當該參考⑶的鄰近⑶均不存在時,根據(jù)該參考⑶所屬的條帶以及圖像確定該參考CU的QP預測值;第二參數(shù)預測模塊13023,用于當該參考⑶只存在左⑶時,將該左⑶的QP作為該參考CU的QP預測值;第三參數(shù)預測模塊13024,用于當該參考⑶只存在上⑶時,將該上⑶的QP作為該參考CU的QP預測值;第四參數(shù)預測模塊13025,用于當該參考⑶的鄰近⑶均存在時,獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若該第一差異小于第二差異,則將該上CU的QP作為該參考CU的QP預測值,若該第一差異大于或等于第二差異,則將該左CU的QP作為該參考CU的QP預測值。本實施例中的參數(shù)計算單元1304可以進一步包括 第一計算模塊13041,用于對尺寸大于或等于該最小圖像塊尺寸,且不滿足預置條件的CU,將該CU的QP預測值作為該CU的QP ;第二計算模塊13042,用于對尺寸大于或等于該最小圖像塊尺寸,且滿足預置條件的CU,將該CU的QP預測值與該CU的QP差之和作為該CU的QP ;第三計算模塊13043,用于對尺寸小于該最小圖像塊單元尺寸的⑶,若該⑶滿足 預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值與該CU的QP差之和作為該CU的QP,并將該CU的QP作為該最小圖像塊中所有CU的QP ;第四計算模塊13044,用于對尺寸小于該最小圖像塊單元尺寸的⑶,若該⑶所屬的最小圖像塊中所有CU均不滿足預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值作為該最小圖像塊中所有CU的QP。請參閱圖14,本發(fā)明解碼裝置另一實施例包括第一解析單元1401,用于對接收到的碼流進行解析得到量化深度參數(shù),該量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸;參數(shù)預測單元1402,用于按照該最小圖像塊尺寸與該IXU中包含的各⑶的尺寸計算各⑶的QP預測值;第二解析單元1403,用于對每一個滿足預置條件的⑶,從碼流中解析得到其QP差;參數(shù)計算單元1404,用于根據(jù)該參數(shù)預測單元1402獲得的各⑶的QP預測值以及該第二解析單元1403解析得到的QP差計算各CU的QP ;解碼單元1405,用于按照該參數(shù)計算單元計算得到的各⑶的QP對各⑶進行解碼。其中,參數(shù)預測單元1402可以進一步包括第二參數(shù)校驗模塊14021,用于對每一個參考⑶,判斷該參考⑶的左⑶是否存在,對于尺寸大于或等于該最小圖像塊尺寸的CU,每一個CU作為一個參考CU,對于尺寸小于該最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶;第五參數(shù)預測模塊14022,用于當該參考⑶的左⑶存在時,將該左⑶的QP作為該參考CU的QP預測值;第六參數(shù)預測模塊14023,用于當該參考⑶的左⑶不存在,且該參考⑶的上⑶或該參考CU的前一被編碼CU存在時,將該上CU的QP或前一被編碼CU的QP作為該參考CU的QP預測值;第七參數(shù)預測模塊14024,用于當該參考⑶的左CU,上⑶以及前一被編碼⑶均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值。本實施例中的參數(shù)計算單元1404可以進一步包括第一計算模塊14041,用于對尺寸大于或等于該最小圖像塊尺寸,且不滿足預置條件的CU,將該CU的QP預測值作為該CU的QP ;第二計算模塊14042,用于對尺寸大于或等于該最小圖像塊尺寸,且滿足預置條件的CU,將該CU的QP預測值與該CU的QP差之和作為該CU的QP ;第三計算模塊14043,用于對尺寸小于該最小圖像塊單元尺寸的⑶,若該⑶滿足預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值與該CU的QP差之和作為該CU的QP,并將該CU的QP作為該最小圖像塊中所有CU的QP ;第四計算模塊14044,用于對尺寸小于該最小圖像塊單元尺寸的⑶,若該⑶所屬的最小圖像塊中所有CU均不滿足預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值作為該最小圖像塊中所有CU的QP。本實施例中,編碼端在編碼時可以在待編碼數(shù)據(jù)中寫入用于表示具有獨立QP的最小圖像塊尺寸的量化深度參數(shù),并且對每一個滿足預置條件的CU中,都攜帶該CU的QP差,使得每個LCU不僅僅再對應一個QP,所以在解碼端進行解碼時可以針對各CU進行解碼,而無需針對一整個LCU進行解碼,從而能夠提高解碼效率。
本發(fā)明實施例提供的技術(shù)可以應用在數(shù)字信號處理領(lǐng)域中,通過編碼器,解碼器實現(xiàn)。視頻編碼器,解碼器廣泛應用于各種通訊設(shè)備或電子設(shè)備中,例如數(shù)字電視、機頂盒、媒體網(wǎng)關(guān),移動電話,無線裝置,個人數(shù)據(jù)助理(PDA),手持式或便攜式計算機,GPS接收機/導航器,照相機,視頻播放器,攝像機,錄像機,監(jiān)控設(shè)備,視頻會議和可視電話設(shè)備等等。這類設(shè)備中包括處理器,存儲器,以及傳輸數(shù)據(jù)的接口。視頻編解碼器可以直接由數(shù)字電路或芯片例如DSP (digital signal processor)實現(xiàn),或者由軟件代碼驅(qū)動一處理器執(zhí)行軟件代碼中的流程而實現(xiàn)。本領(lǐng)域普通技術(shù)人員可以理解實現(xiàn)上述實施例方法中的全部或部分步驟是可以通過程序來指令相關(guān)的硬件完成,該程序可以存儲于一種計算機可讀存儲介質(zhì)中,上述提到的存儲介質(zhì)可以是只讀存儲器,磁盤或光盤等。以上對本發(fā)明所提供的一種編碼方法以及裝置、解碼方法以及裝置進行了詳細介紹,對于本領(lǐng)域的一般技術(shù)人員,依據(jù)本發(fā)明實施例的思想,在具體實施方式
及應用范圍上均會有改變之處,因此本說明書內(nèi)容不應理解為對本發(fā)明的限制。
權(quán)利要求
1.一種編碼方法,其特征在于,包括 編碼端獲取待編碼數(shù)據(jù),所述待編碼數(shù)據(jù)至少為一個最大編碼單元LCU ; 編碼端按照預置的碼率控制算法確定所述LCU的量化深度參數(shù),并將所述量化深度參數(shù)寫入所述待編碼數(shù)據(jù),所述量化深度參數(shù)用于表示所述LCU中具有獨立QP的最小圖像塊尺寸; 編碼端根據(jù)所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸確定各CU的QP ; 編碼端根據(jù)所述各CU的QP以及各CU的QP預測值計算各CU的QP差; 對于每一個滿足預置條件的CU,編碼端在該CU中攜帶該CU的QP差; 編碼端對所述量化深度參數(shù)、滿足預置條件的CU的QP差、以及各CU進行編碼得到碼流。
2.根據(jù)權(quán)利要求I所述的方法,其特征在于, 所述待編碼數(shù)據(jù)為序列、或圖像、或條帶; 所述量化深度參數(shù)用于表示所述序列、或圖像、或條帶中每一個LCU中具有獨立QP的最小圖像塊尺寸。
3.根據(jù)權(quán)利要求2所述的方法,其特征在于,所述將所述量化深度參數(shù)寫入所述待編碼數(shù)據(jù)包括 編碼端將所述量化深度參數(shù)寫入所述序列的序列參數(shù)集中,或所述圖像的圖像參數(shù)集中,或所述條帶的條帶頭信息中。
4.根據(jù)權(quán)利要求I所述的方法,其特征在于, 所述待編碼數(shù)據(jù)為一個LCU; 所述量化深度參數(shù)用于表示所述一個LCU中具有獨立QP的最小圖像塊尺寸。
5.根據(jù)權(quán)利要求4所述的方法,其特征在于,所述將所述量化深度參數(shù)寫入所述待編碼數(shù)據(jù)包括 編碼端將所述量化深度參數(shù)寫入所述一個LCU中按編碼次序第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU中。
6.根據(jù)權(quán)利要求I至5中任一項所述的方法,其特征在于,所述編碼端根據(jù)所述最小圖像塊尺寸與所述IXU中包含的各⑶的尺寸確定各⑶的QP包括 對于尺寸大于或等于所述最小圖像塊尺寸的CU,編碼端按照預置的碼率控制算法計算該CU的QP ; 對于尺寸小于所述最小圖像塊尺寸的CU,編碼端確定該CU所屬的最小圖像塊,按照預置的碼率控制算法計算該最小圖像塊的QP,并將該最小圖像塊的QP作為該最小圖像塊中所有⑶的QP。
7.根據(jù)權(quán)利要求I至5中任一項所述的方法,其特征在于,所述編碼端根據(jù)所述各CU的QP以及各CU的QP預測值計算各CU的QP差包括 編碼端將每一個尺寸大于或等于所述最小圖像塊尺寸的CU作為一個參考CU ; 對于尺寸小于所述最小圖像塊尺寸的CU,編碼端確定該CU所屬的最小圖像塊,并將該最小圖像塊的左上⑶作為一個參考⑶; 編碼端根據(jù)各參考CU的鄰近CU的QP計算各參考CU的QP預測值; 對于每一個參考CU,編碼端將該參考CU的QP與該參考CU的QP預測值之間的差值作為該參考CU的QP差; 若所述參考CU所屬的最小圖像塊中包含其它CU,則編碼端將所述參考CU的QP差作為所述其它CU的QP差。
8.根據(jù)權(quán)利要求7所述的方法,其特征在于,所述編碼端根據(jù)各參考CU的鄰近CU的QP計算各參考CU的QP預測值包括 對于每一個參考CU,編碼端判斷該參考CU的鄰近CU是否存在,該參考CU的鄰近CU包括該參考⑶的左⑶,上⑶以及左上⑶; 若該參考CU的鄰近CU均不存在,則根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值; 若該參考⑶只存在左⑶,則將該左⑶的QP作為該參考⑶的QP預測值; 若該參考CU只存在上CU,則將該上CU的QP作為該參考CU的QP預測值; 若該參考⑶的鄰近⑶均存在,則獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若所述第一差異小于第二差異,則將該上⑶的QP作為該參考CU的QP預測值,若所述第一差異大于或等于第二差異,則將該左CU的QP作為該參考CU的QP預測值。
9.根據(jù)權(quán)利要求7所述的方法,其特征在于,所述編碼端根據(jù)各CU的QP計算各CU的QP預測值包括 對于每一個參考CU,編碼端判斷該參考CU的左CU是否存在,若存在,則將該左CU的QP作為該參考CU的QP預測值; 若該參考⑶的左⑶不存在,且該參考⑶的上⑶或該參考⑶的前一被編碼⑶存在,則將該上CU的QP或前一被編碼CU的QP作為該參考CU的QP預測值; 若該參考CU的左CU,上CU以及前一被編碼CU均不存在,則根據(jù)該參考CU所屬的條帶以及圖像確定該參考⑶的QP預測值。
10.根據(jù)權(quán)利要求7所述的方法,其特征在于, 所述滿足預置條件的CU為在其壓縮碼流中存在非零量化后變換系數(shù)的CU。
11.根據(jù)權(quán)利要求10所述的方法,其特征在于,所述方法還包括 對于每一個不滿足所述預置條件的⑶,編碼端通過如下方式設(shè)置該⑶的QP 對于尺寸大于或等于所述最小圖像塊尺寸的CU,編碼端將該CU的QP預測值作為該CU的QP ; 對于尺寸小于所述最小圖像塊尺寸的CU,若該CU所屬的最小圖像塊中的其它CU均不滿足所述預置條件,則編碼端將該CU所屬的最小圖像塊中的參考CU的QP預測值作為該CU的QPo
12.根據(jù)權(quán)利要求I至5中任一項所述的方法,其特征在于, 所述編碼端對所述量化深度參數(shù)進行編碼包括 編碼端采用定長碼或變長碼對所述量化深度參數(shù)進行二值化得到對應的二進制碼字; 編碼端將獲得的二進制碼字按照定長編碼、變長編碼或算術(shù)熵編碼的方法寫入碼流; 所述編碼端對滿足預置條件的CU的QP差進行編碼包括 編碼端采用變長碼對所述滿足預置條件的CU的QP差進行二值化得到對應的二進制碼字; 編碼端將獲得的二進制碼字按照變長編碼或算術(shù)熵編碼的方法寫入碼流。
13.—種解碼方法,其特征在于,包括 解碼端對接收到的碼流進行解析得到量化深度參數(shù),所述量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸; 解碼端按照所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸計算各CU的QP預測值; 對于每一個滿足預置條件的⑶,解碼端從碼流中解析得到其QP差; 解碼端根據(jù)所述各CU的QP預測值以及解析得到的QP差計算各CU的QP ; 解碼端按照所述各CU的QP對各CU進行解碼。
14.根據(jù)權(quán)利要求13所述的方法,其特征在于,所述解碼端對接收到的碼流進行解析得到量化深度參數(shù)包括 解碼端從序列的序列參數(shù)集中,或圖像的圖像參數(shù)集中,或條帶的條帶頭信息中解析得到所述量化深度參數(shù); 所述量化深度參數(shù)用于表示所述序列、或圖像、或條帶中每一個LCU中具有獨立QP的最小圖像塊尺寸。
15.根據(jù)權(quán)利要求13所述的方法,其特征在于,所述解碼端對接收到的碼流進行解析得到量化深度參數(shù)包括 對于每一個LCU,解碼端從按解碼次序第一個在其壓縮碼流中存在非零量化后變換系數(shù)的CU中解析得到所述量化深度參數(shù); 所述量化深度參數(shù)用于表示所述在其壓縮碼流中存在非零量化后變換系數(shù)的CU所屬的IXU中具有獨立QP的最小圖像塊尺寸。
16.根據(jù)權(quán)利要求13至15中任一項所述的方法,其特征在于,所述解碼端按照所述最小圖像塊尺寸與所述IXU中包含的各⑶的尺寸計算各⑶的QP預測值包括 解碼端將每一個尺寸大于或等于所述最小圖像塊尺寸的CU作為一個參考CU ; 對于尺寸小于所述最小圖像塊尺寸的CU,解碼端確定該CU所屬的最小圖像塊,并將該最小圖像塊的左上⑶作為一個參考⑶; 對于每一個參考CU,解碼端判斷該參考CU的鄰近CU是否存在,該參考CU的鄰近CU包括該參考⑶的左⑶,上⑶以及左上⑶; 若該參考CU的鄰近CU均不存在,則根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值; 若該參考⑶只存在左⑶,則將該左⑶的QP作為該參考⑶的QP預測值; 若該參考CU只存在上CU,則將該上CU的QP作為該參考CU的QP預測值; 若該參考⑶的鄰近⑶均存在,則獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若所述第一差異小于第二差異,則將該上⑶的QP作為該參考CU的QP預測值,若所述第一差異大于或等于第二差異,則將該左CU的QP作為該參考CU的QP預測值。
17.根據(jù)權(quán)利要求13至15中任一項所述的方法,其特征在于,所述解碼端按照所述最小圖像塊尺寸與所述IXU中包含的各⑶的尺寸計算各⑶的QP預測值包括解碼端將每一個尺寸大于或等于所述最小圖像塊尺寸的CU作為一個參考CU ; 對于尺寸小于所述最小圖像塊尺寸的CU,解碼端確定該CU所屬的最小圖像塊,并將該最小圖像塊的左上⑶作為一個參考⑶; 對于每一個參考CU,解碼端判斷該參考CU的左CU是否存在,若存在,則將該左CU的QP作為該參考CU的QP預測值; 若該參考⑶的左⑶不存在,且該參考⑶的上⑶或該參考⑶的前一被解碼⑶存在,則將該上CU的QP或前一被解碼CU的QP作為該參考CU的QP預測值; 若該參考CU的左CU,上CU以及前一被解碼CU均不存在,則根據(jù)該參考CU所屬的條帶以及圖像確定該參考⑶的QP預測值。
18.根據(jù)權(quán)利要求13至15中任一項所述的方法,其特征在于,所述對于每一個滿足預置條件的CU,解碼端從碼流中解析得到其QP差包括 對于每一個尺寸大于或等于所述最小圖像塊尺寸的CU,解碼端判斷該CU是否滿足所述預置條件,若滿足,則從該CU中解析該CU的QP差,若不滿足,則將該CU的QP差設(shè)置為O ; 對于尺寸小于所述最小圖像塊尺寸的CU,解碼端確定該CU所屬的最小圖像塊,并按照該最小圖像塊中CU的解碼次序,依次判斷該最小圖像塊中每一個CU是否滿足所述預置條件,若滿足,則停止判斷,并將該CU的QP差作為該最小圖像塊中所有CU的QP差,若該最小圖像塊中所有CU均不滿足所述預置條件,則將該最小圖像塊中所有CU的QP差設(shè)置為O。
19.根據(jù)權(quán)利要求18所述的方法,其特征在于,滿足預置條件的CU為在其壓縮碼流中存在非零量化后變換系數(shù)的CU ; 所述解碼端根據(jù)所述各CU的QP預測值以及解析得到的QP差計算各CU的QP包括對于尺寸大于或等于所述最小圖像塊尺寸,且不滿足所述預置條件的CU,解碼端將該⑶的QP預測值作為該⑶的QP ; 對于尺寸大于或等于所述最小圖像塊尺寸,且滿足所述預置條件的CU,解碼端將該CU的QP預測值與該CU的QP差之和作為該CU的QP ; 對于尺寸小于所述最小圖像塊單元尺寸的CU,若該CU滿足所述預置條件,則解碼端獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值與該QP差之和作為該⑶的QP,并將該⑶的QP作為該最小圖像塊中所有⑶的QP ; 對于尺寸小于所述最小圖像塊單元尺寸的CU,若該CU所屬的最小圖像塊中所有CU均不滿足所述預置條件,則解碼端獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值作為該最小圖像塊中所有CU的QP。
20.根據(jù)權(quán)利要求18所述的方法,其特征在于,所述解碼端對接收到的碼流進行解析得到量化深度參數(shù)包括 解碼端從對應的位置使用定長解碼、變長解碼或算術(shù)熵解碼的方法獲取二進制碼字; 解碼端采用定長碼或變長碼對所述二進制碼字進行逆二值化得到所述量化深度參數(shù); 所述解碼端從碼流中解析得到其QP差包括 解碼端從對應的位置使用變長解碼或算術(shù)熵解碼的方法獲取二進制碼字; 解碼端采用變長碼對所述二進制碼字進行逆二值化得到所述QP差。
21.一種編碼裝置,其特征在于,包括 數(shù)據(jù)獲取單元,用于獲取待編碼數(shù)據(jù),所述待編碼數(shù)據(jù)至少為一個最大編碼單元LCU;深度參數(shù)處理單元,用于按照預置的碼率控制算法確定所述LCU的量化深度參數(shù),并將所述量化深度參數(shù)寫入所述數(shù)據(jù)獲取單元獲取到的待編碼數(shù)據(jù),所述量化深度參數(shù)用于表不所述L⑶中具有獨立QP的最小圖像塊尺寸; 量化參數(shù)確定單元,用于根據(jù)所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸確定各CU的QP ; 計算單元,用于根據(jù)所述量化參數(shù)確定單元確定的各CU的QP以及各CU的QP預測值計算各CU的QP差; 填充單元,用于對于每一個滿足預置條件的CU,在該CU中攜帶該CU的QP差; 編碼單元,用于對所述量化深度參數(shù)、滿足預置條件的CU的QP差、以及各CU進行編碼得到碼流。
22.根據(jù)權(quán)利要求21所述的編碼裝置,其特征在于,所述編碼裝置還包括 預測單元,用于根據(jù)各參考⑶的鄰近⑶的QP計算各參考⑶的QP預測值; 對于尺寸大于或等于所述最小圖像塊尺寸的CU,每一個CU作為一個參考CU,對于尺寸小于所述最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶。
23.根據(jù)權(quán)利要求22所述的編碼裝置,其特征在于,所述預測單元包括 第一校驗模塊,用于對每一個參考CU,判斷該參考CU的鄰近CU是否存在,該參考CU的鄰近⑶包括該參考⑶的左⑶,上⑶以及左上⑶; 第一預測模塊,用于當該參考CU的鄰近CU均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考⑶的QP預測值; 第二預測模塊,用于當該參考⑶只存在左⑶時,將該左⑶的QP作為該參考⑶的QP預測值; 第三預測模塊,用于當該參考CU只存在上CU時,將該上CU的QP作為該參考CU的QP預測值; 第四預測模塊,用于當該參考⑶的鄰近⑶均存在時,獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若所述第一差異小于第二差異,則將該上CU的QP作為該參考CU的QP預測值,若所述第一差異大于或等于第二差異,則將該左⑶的QP作為該參考⑶的QP預測值。
24.根據(jù)權(quán)利要求22所述的編碼裝置,其特征在于,所述預測單元包括 第二校驗模塊,用于對每一個參考CU,判斷該參考CU的左CU是否存在; 第五預測模塊,用于當該參考CU的左CU存在時,將該左CU的QP作為該參考CU的QP預測值; 第六預測模塊,用于當該參考CU的左CU不存在,且該參考CU的上CU或該參考CU的前一被編碼CU存在時,將該上CU的QP或前一被編碼CU的QP作為該參考CU的QP預測值;第七預測模塊,用于當該參考CU的左CU,上CU以及前一被編碼CU均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值。
25.一種解碼裝置,其特征在于,包括 第一解析單元,用于對接收到的碼流進行解析得到量化深度參數(shù),所述量化深度參數(shù)用于表示LCU中具有獨立QP的最小圖像塊尺寸; 參數(shù)預測單元,用于按照所述最小圖像塊尺寸與所述LCU中包含的各CU的尺寸計算各CU的QP預測值; 第二解析單元,用于對每一個滿足預置條件的CU,從碼流中解析得到其QP差; 參數(shù)計算單元,用于根據(jù)所述參數(shù)預測單元獲得的各CU的QP預測值以及所述第二解析單元解析得到的QP差計算各CU的QP ; 解碼單元,用于按照所述參數(shù)計算單元計算得到的各CU的QP對各CU進行解碼。
26.根據(jù)權(quán)利要求25所述的解碼裝置,其特征在于,所述參數(shù)預測單元包括 第一參數(shù)校驗模塊,用于對每一個參考CU,判斷該參考CU的鄰近CU是否存在,該參考⑶的鄰近⑶包括該參考⑶的左⑶,上⑶以及左上⑶,對于尺寸大于或等于所述最小圖像塊尺寸的⑶,每一個⑶作為一個參考⑶,對于尺寸小于所述最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶; 第一參數(shù)預測模塊,用于當該參考CU的鄰近CU均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考⑶的QP預測值; 第二參數(shù)預測模塊,用于當該參考CU只存在左CU時,將該左CU的QP作為該參考CU的QP預測值; 第三參數(shù)預測模塊,用于當該參考CU只存在上CU時,將該上CU的QP作為該參考CU的QP預測值; 第四參數(shù)預測模塊,用于當該參考⑶的鄰近⑶均存在時,獲取左⑶的QP與左上⑶的QP之間的第一差異,以及上⑶的QP與左上⑶的QP之間的第二差異,若所述第一差異小于第二差異,則將該上CU的QP作為該參考CU的QP預測值,若所述第一差異大于或等于第二差異,則將該左CU的QP作為該參考CU的QP預測值。
27.根據(jù)權(quán)利要求25所述的解碼裝置,其特征在于,所述參數(shù)預測單元包括 第二參數(shù)校驗模塊,用于對每一個參考CU,判斷該參考CU的左CU是否存在,對于尺寸大于或等于所述最小圖像塊尺寸的CU,每一個CU作為一個參考CU,對于尺寸小于所述最小圖像塊尺寸的⑶,該⑶所屬的最小圖像塊的左上⑶作為一個參考⑶; 第五參數(shù)預測模塊,用于當該參考CU的左CU存在時,將該左CU的QP作為該參考CU的QP預測值; 第六參數(shù)預測模塊,用于當該參考CU的左CU不存在,且該參考CU的上CU或該參考CU的前一被編碼CU存在時,將該上CU的QP或前一被編碼CU的QP作為該參考CU的QP預測值; 第七參數(shù)預測模塊,用于當該參考CU的左CU,上CU以及前一被編碼CU均不存在時,根據(jù)該參考CU所屬的條帶以及圖像確定該參考CU的QP預測值。
28.根據(jù)權(quán)利要求25至27中任一項所述的解碼裝置,其特征在于,所述參數(shù)計算單元包括 第一計算模塊,用于對尺寸大于或等于所述最小圖像塊尺寸,且不滿足預置條件的CU,將該CU的QP預測值作為該CU的QP ; 第二計算模塊,用于對尺寸大于或等于所述最小圖像塊尺寸,且滿足預置條件的CU,將該⑶的QP預測值與該⑶的QP差之和作為該⑶的QP ;第三計算模塊,用于對尺寸小于所述最小圖像塊單元尺寸的CU,若該CU滿足預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值與該CU的QP差之和作為該CU的QP,并將該CU的QP作為該最小圖像塊中所有CU的QP ; 第四計算模塊,用于對尺寸小于所述最小圖像塊單元尺寸的CU,若該CU所屬的最小圖像塊中所有CU均不滿足預置條件,則獲取該CU所屬的最小圖像塊的左上CU的QP預測值,并將該QP預測值作為該最小圖像塊中所有CU的QP。
全文摘要
本發(fā)明實施例公開了一種編碼方法及裝置、解碼方法及裝置以及編解碼系統(tǒng)。本發(fā)明實施例方法包括編碼端獲取待編碼數(shù)據(jù),待編碼數(shù)據(jù)至少為一個LCU;編碼端按照碼率控制算法確定LCU的量化深度參數(shù),并將量化深度參數(shù)寫入待編碼數(shù)據(jù);編碼端根據(jù)最小圖像塊尺寸與LCU中包含的各CU的尺寸確定各CU的QP;編碼端根據(jù)各CU的QP以及各CU的QP預測值計算各CU的QP差;對于每一個滿足預置條件的CU,編碼端在該CU中攜帶該CU的QP差;編碼端對量化深度參數(shù)、滿足預置條件的CU的QP差、以及各CU進行編碼得到碼流。本發(fā)明實施例還提供一種解碼方法以及編解碼裝置。本發(fā)明實施例能夠有效提高碼率控制精度以及壓縮效率。
文檔編號H04N7/50GK102685478SQ20111005919
公開日2012年9月19日 申請日期2011年3月11日 優(yōu)先權(quán)日2011年3月11日
發(fā)明者區(qū)子廉, 龐超, 楊海濤 申請人:華為技術(shù)有限公司