欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

動態(tài)影像壓縮的可變位元率控制裝置的制作方法

文檔序號:7755748閱讀:281來源:國知局
專利名稱:動態(tài)影像壓縮的可變位元率控制裝置的制作方法
技術領域
本發(fā)明有關于資料壓縮的領域,特別是指一種適用于視訊編碼系統(tǒng)以執(zhí)行可變位元率控制的裝置。
背景技術
眾所周知,電子通訊世界正經歷一次數位革命,以數位表示信息的主要優(yōu)點在于能夠幾近無誤地儲存、再生、傳收、處理及運用的資料位元流(bitstream)。舉例而言,NTSC的彩色視訊影像每秒有29.97張畫面,每張畫面約480條可見掃瞄線,每條掃瞄線約需480點以紅、綠、藍三色呈現(xiàn)的像素(pixel),但若每種色彩成分以8位編碼,則所產生的位元率(bitrate)每秒約168百萬位元(Mbits/s),故各種視訊格式其未經壓縮處理的位元率非常高而不經濟,因此不適于多數的應用。
與電腦、電信網絡、消費性產品整合的數位音訊和視訊,更加刺激信息革命的前進,而這革命的核心則是視、音訊的數位壓縮技術。許多的壓縮標準,包含以壓縮技術共通的精髓為基礎的算法,如ITU-T(前身是CCITT)建議書H.261和H.263,以及ISO/IEC的MPEG-1、MPEG-2和MPEG-4標準。MPEG的演算法是由動態(tài)影像專家群組(Moving Picture Experts Group,MPEG)所發(fā)展出來,該動態(tài)影像專家群組是國際標準組織(InternationalStandards Organization,ISO)及國際電子技術委員會(InternationalElectrotechnical Commission,IEC)的聯(lián)合技術委員會,致力于發(fā)展視、音訊的壓縮及多路傳殊的表現(xiàn)方式,這些標準規(guī)定了壓縮位元流的語法(syntax)以及解碼的方法,但對于編碼器所使用的演算法而言,卻為編碼的新穎性與多樣性保留了相當多的自由度。
根據MPEG,一連串的視訊畫面(picture)分成一序列的畫面群組(groupof picture,GOP),其中每組GOP以I-畫面開始,后面跟著P-畫面和B-畫面的安排,圖1以顯示的順序說明一組典型的GOP。I-畫面的編碼毋須參考先前或將來的畫面,P-畫面則參考連串的視訊畫面中在時間上最接近的I-畫面或P-畫面來進行編碼,而B-畫面散布于I-畫面和P-畫面之間。并且利用先前的、將來的或兩者兼具的緊鄰I-畫面和P-畫面來編碼。雖然好幾張B-畫面可以緊接著連續(xù)出現(xiàn),但絕不能以B-畫面預估其它的畫面。
每張畫面具有三種成分亮度值(luminance,以Y表示),紅色差值(redcolor difference,以Cr表示),以及藍色差值(blue color difference,以Cb表示)。對于MPEG的4:2:0的格式而言,每一種Cr和Cb成分的取樣點在水平與垂直方向只有Y成分的一半。如圖2所示,一張MPEG的畫面其基本構成方塊是大區(qū)塊(macroblock,以MB表示)。以4:2:0的視訊為例,每個MB包含一個Y成分16×16取樣點的陣列,以及兩個Cr和Cb成分8×8取樣點的區(qū)塊,其中Y成分16×16取樣點的陣列實際上由4個8×8取樣點的區(qū)塊所組成。
編碼器的作用在于決定何種畫面編碼型態(tài)以及何種預測模式為最佳。對每張I-畫面,MB中的每個8×8方塊均經過離散余弦轉換(discrete cosinetransform,DCT)而形成8×8轉換系數陣列,轉換系數接著以一量化矩陣進行量化,然后用Z字形(zig-zag)掃瞄DCT系數的量化結果而得到一連串的DCT系數,并且此DCT系數序列以可變長度碼(variable length code,VLC)進行編碼。P-畫面必須決定將每個MB以I型MB或P型MB進行編碼,I型MB的編碼是以上述的方式進行的,而對于每個P型MB,則需得到該MB以先前畫面所做的預測,此預測是藉由一種移動向量(motion vector)獲得,移動向量象征著目前畫面中即將編碼的MB及其在先前畫面中的預估MB之間的變動,預估MB與目前MB間的預測誤差則以DCT、量化、Z字形掃瞄以及VLC進行編碼。
處理B-畫面時,必須決定以下列何種MB模式來編碼每個MBI模式、F模式、B模式以及FB模式。I模式是以MB本身而不借助移動補償來編碼(如I型MB一般);F模式為單向的向前預測編碼,是以先前畫面得到移動補償的預估(如P型MB一般);反之,B模式為單向的向后預測編碼,是以后來的畫面得到移動補償的預估。特別的是FB模式,其是雙向的預測編碼,運用向前的和向后的移動補償預估兩者來做內插(interpolation)而得到FB模式的移動補償預估。對F、B和FB模式而言,預測誤差可以使用DCT、量化、Z字形掃瞄以及VLC進行編碼。
視訊編碼器必須為整張畫面選取量化位階以便在給定的位元率下控制可見的失真,然而,以選取的量化位階編碼一張畫面所用的實際位元數,必然是在真正編碼之后才會得知,現(xiàn)實中并不存在一個逆轉函數,能夠在給定希望達到的量化位階下,事先決定一張畫面所用的實際位元數。編碼器很重要的一點即為位元率的控制。MPEG中重要的視訊編碼器限制即每張畫面所用位元數變化的限制,特別是在固定位元率運作的情形,這種限制是透過視訊緩沖器檢驗者(Video Buffer Verifier,VBV)來施行。若對于每張畫面而言,VBV的輸入資料速率均相同,則視訊可說是以固定位元率(ConstantBitrate,CBR)編碼;否則即為可變位元率(Variable Bitrate,VBR)編碼。VBV乃一種虛擬緩沖器并且是在解碼器端的輸入緩沖器模型,以固定位元率而言,編碼器分配給一張畫面的位元額度須使VBV緩沖器不會滿溢或匱乏;而對于可變位元率,編碼過的位元流則是以特定的最大位元率進入VBV緩沖器直到其飽和、再沒有多的位元輸入為止,這可解釋為進入VBV緩沖器的位元率實際上是可變的且能達到上述的最大位元率。故對于可變位元率,則只要防止VBV匱乏即可。
可變位元率控制的目的是盡可能的提高解碼后視訊的品質而還能維持輸出位元率在允許的范圍內。和固定位元率的方式不同,可變位元率擁有較大的彈性來分配額外的位元數給景物較復雜、變動較劇烈的畫面。不過,傳統(tǒng)的可變位元率控制架構卻相當復雜,通常需進行好幾次才能完成視訊編碼的處理。

發(fā)明內容
本發(fā)明的目的是提供一種新穎的動態(tài)影像壓縮的可變位元率控制裝置,可用于單次、即時的視訊編碼器,再者,也期待能提供一種適合施行于積體電路、具有可變位元率控制的動態(tài)影像壓縮裝置。
根據本發(fā)明,每一張畫面其目標位元的分配,是基于先前畫面的編碼結果和對即將被編碼的目前畫面其預先分析的活動量,再者,藉由目前畫面的預先分析的活動量以及先前編碼畫面的實際復雜度間的關系,目前畫面的復雜度將能夠被估計而得。由于畫面的復雜度含有該畫面編碼之后的品質資訊,故此預估的目前畫面復雜度對視訊編碼器是非常有用的,可以更精確地分配目標位元額度給每張畫面,藉以達到視訊序列中不同畫面之間均一的視覺品質。
本發(fā)明是針對于一種動態(tài)影像壓縮的可變位元率控制裝置。根據本發(fā)明,該裝置包括一移動估算單元、一復雜度估計器、一目標位元分派器以及一參數更新器。移動估算單元接收視訊序列里的一組連續(xù)畫面中即將被編碼的目前畫面,用以計算此目前畫面的全活動量?;谀壳爱嬅娴娜顒恿恳约斑@組連續(xù)畫面中一同型態(tài)的先前編碼畫面其活動量對復雜度之比,復雜度估計器可用來估計目前畫面的復雜度。以目前畫面預估的復雜度,目標位元分派器更新本組連續(xù)畫面的瞬間復雜度,并且基于這組連續(xù)畫面的既定平均位元率、統(tǒng)計復雜度及瞬間復雜度來計算該組連續(xù)畫面的瞬間位元率,而根據目前畫面的復雜度、這組連續(xù)畫面的瞬間復雜度及瞬間位元率,目標位元分派器將目標位元額度分配給目前畫面。而參數更新器在目前畫面編碼之后,根據目前畫面的全活動量、實際消耗位元數和編碼目前畫面實際所用量化位階的平均值,計算目前畫面其活動量對復雜度之比;其中,目前畫面的活動量對復雜度之比與目前畫面的全活動量成正比,而與目前畫面的實際消耗位元數以及目前畫面實際所用量化位階的平均值成反比。此外,參數更新器還以目前畫面的復雜度為基礎來計算前述的統(tǒng)計復雜度。
另一方面,本發(fā)明還揭露一種目標位元分派器,包括一瞬間位元率計算器、一配額計算器以及一限度單元。瞬間位元率計算器接收視訊序列中一組連續(xù)畫面里即將被編碼的目前畫面所含的復雜度以及該組連續(xù)畫面的統(tǒng)計復雜度,且以該復雜度為基礎來更新此組連續(xù)畫面的瞬間復雜度,并根據一函數來計算這組連續(xù)畫面的瞬間位元率,其中該函數取決于該組連續(xù)畫面的既定平均位元率、統(tǒng)計復雜度及瞬間復雜度。配額計算器則以目前畫面的復雜度、這組連續(xù)畫面的瞬間位元率及瞬間復雜度為基礎,將目標位元額度分配給目前畫面,而限度單元則用來將此目標位元額度限制在既定的上限之下。


圖1是以顯示的順序呈現(xiàn)典型的畫面群組(GOP)。
圖2是MPEG的大區(qū)塊。
圖3是本發(fā)明的可變位元率控制裝置其較佳實施例的方塊示意圖。
圖4是本發(fā)明的操作流程圖。
圖5是圖3中的目標位元分派器的方塊示意圖。
圖號說明300......動態(tài)影像壓縮裝置310......移動估算單元312......訊號線320......復雜度估計器330......目標位元分派器340......參數更新器350......影像編碼器510......瞬間位元率計算器
520..........配額計算器530..........限度單元P(i)..........畫面A(i)..........全活動量Cest(i)..........預估復雜度ACR(i)......活動量對復雜度之比EB .............超用位元量STAT_C ......統(tǒng)計復雜度TB(i)......目標位元額度AQ(i).......實際所用量化位階的平均值UB(i)......實際消耗位元數CD.......編碼后的資料INST_R ......瞬間位元率INST_C ......瞬間復雜度具體實施方式
為使本發(fā)明的上述目的、特征和優(yōu)點能更明顯易懂,下文特舉一較佳實施例,并配合所附圖式,作詳細說明如下一開始,預測用的I-畫面和P-畫面必須先在MPEG編碼器內解碼,利用計算原始畫面及解碼的畫面間的均方根(root mean square)誤差,可以得到解碼畫面其品質的客觀量度。以均方根誤差作為解碼畫面的失真度,則解碼畫面的復雜度(complex)-C定義如下C=r×d其中,r是編碼該畫面所需的位元率,d是解碼的畫面的失真度。理論上,平均的量化位階(quantization step size)和失真度之間為一比例關系,故,畫面的復雜度可定義成C≈r×q2]]>其中,q是該畫面的平均量化位階。在畫面編碼之后,將可得知位元率(實際消耗位元數)以及平均量化位階,而該畫面的復雜度也因此獲得。
畫面的復雜度端視畫面的本質及其編碼的形式而定。先前技術利用最近編碼畫面的復雜度來表示目前畫面的復雜度,并且為I-、P-及B-畫面分別保持其復雜度以減輕不同編碼形式的影響,倘若視訊序列的畫面其內容為平順的變化,則此方式可達到相當不錯的效果。然而,由于畫面編碼的目標位元配額與其實際消耗位元數之間不相符合,如果視訊序列的內容大幅變動,上述方式并不適合用來達成一致的視覺品質。
根據本發(fā)明,預先分析目前畫面的活動量(activity)以及先前編碼畫面的實際復雜度之間的關系,目前畫面的復雜度將能藉此預估?;顒恿渴且环N在畫面編碼后其位元率和品質的量度嘗試,假設一整張畫面的全活動量A正比于復雜度C,則A=k×C≈k2×r×q=k′×r×q]]>其中,k是比例常數。若k′為活動量對復雜度之比(activity-to-complexityratio,ACR),則全活動量A還可以下列式子表示A=ACR×r×q根據本發(fā)明,可以從相同型態(tài)的先前編碼畫面來預估ACR。觀念上,先在編碼一張畫面前計算其全活動量A,然后,即將被編碼的畫面P(i)的復雜度Cest(i)以如下方式估算Cest(i)=A(i)ACR(i-1)]]>其中,A(i)是畫面P(i)的全活動量,ACR(i-1)是同型態(tài)的先前編碼畫面其活動量對復雜度之比。以下,在符號或變數中的上標(i)表示該符號或變量是與即將被編碼的目前畫面有關;同理,在符號或變量中的上標(i-1)則與先前編碼畫面相關。
估計的復雜度Cest(i)可用來為合適型態(tài)的畫面更新其復雜度,所以三種型態(tài)的畫面其復雜度CI、CP和CB將分別儲存以利后續(xù)的處理。一組連續(xù)畫面的瞬間復雜度(instantaneous complexity)也以如下方式更新INST_C=NI×CI+NP×CP+NB×CB其中,NI、NP和NB分別是該組連續(xù)畫面中I-、P-及B-畫面的數目,而且此處所指的一組連續(xù)畫面至少包含一組GOP。除了CI、CP和CB之外,也分別存放I-、P-及B-畫面的復雜度統(tǒng)計量SCI、SCP和SCB,并且取目前畫面的復雜度Cest(i)來更新同型態(tài)畫面的復雜度統(tǒng)計量,則一組連續(xù)畫面的統(tǒng)計復雜度為STAT_C=NI×SCI+NP×SCP+NB×SCB若是最大、最小位元率已根據每組連續(xù)畫面期望達到的編碼位元率而事先決定,如此,一組連續(xù)畫面的瞬間位元率可由下列式子計算而得INST_R=ERmean·(1+SF·(INST_CSTAT_C-1))]]>其中,ERmean是本組連續(xù)畫面的既定平均位元率,SF是一縮放因子,其范圍在0到1之間;瞬間位元率INST_R還須進一步地限制在每組連續(xù)畫面的既定最大、最小位元率之間ERmin≤INST_R≤ERmax一旦瞬間復雜度INST_C和瞬間位元率INST_R已經決定,則目前畫面P(i)的目標位元額度TB(i)為TB(i)=Cest(i)INST_C×INST_R]]>由上式可知,目標位元額度TB(i)與復雜度Cest(i)以及瞬間位元率INST_R成正比,而與瞬間復雜度INST_C成反比。
所有的MPEG-2資料位元流均必須遵循MPEG-2標準的VBV規(guī)則,分配的目標額度必須受限以使VBV緩沖器不會滿溢(overflow)或匱乏(underflow)。當目前畫面的目標位元額度決定好之后,便可利用許多不同型態(tài)的影像編碼器,像是MPEG-2標準描述的測試原型5(Test Model 5),根據目標位元額度來完成畫面的壓縮。
目前畫面在完成編碼之后,其實際的復雜度將可得知,而目前畫面的全活動量和實際復雜度之間的關系,ACR(i)可從以下計算得到ACR(i)=A(i)AQ(i)×UB(i)]]>其中,ACR(i)與全活動量A(i)成正比,而與目前畫面的實際消耗位元數UB(i)以及平均量化位階AQ(i)成反比。此ACR(i)可拿來預估下一張同型態(tài)的畫面的復雜度。ACR(i)可以和ACR(i-1)做線性結合來避免受到那些富含噪聲畫面的影響。
本發(fā)明的單次(single-pass)視訊編碼可藉由圖3的較佳實施例并配合圖4的操作流程圖來解釋。如圖3所示,動態(tài)影像壓縮裝置300包括一移動估算單元310、一復雜度估計器320、一目標位元分派器330、一參數更新器340以及一影像編碼器350。移動估算單元310接收視訊序列里的一組連續(xù)畫面中即將被編碼的目前畫面P(i),用來在執(zhí)行移動估算的區(qū)塊匹配時,計算此目前畫面P(i)的全活動量A(i)(步驟S410)?;谌顒恿緼(i)以及這組連續(xù)畫面中同型態(tài)的先前編碼畫面的ACR(i-1),復雜度估計器320可用來估計目前畫面的復雜度Cest(i)(步驟S420)。目標位元分派器330以預估的復雜度Cest(i)更新本組連續(xù)畫面其瞬間復雜度INST_C(步驟S430),同時,目標位元分派器330從參數更新器340接收該組連續(xù)畫面的統(tǒng)計復雜度STAT_C,并根據這組連續(xù)畫面的既定平均位元率ERmean、統(tǒng)計復雜度STAT_C、瞬間復雜度INST_C,計算該組連續(xù)畫面的瞬間位元率INST_R(步驟S440)。
目標位元分派器330接著以瞬間位元率INST_R、復雜度Cest(i)以及瞬間復雜度INST_C為基礎將目標位元額度TB(i)分配給目前畫面P(i)(步驟S450)。因此,影像編碼器350依目標位元額度TB(i)而決定目前畫面P(i)使用的所有量化位階,這些量化位階作為畫面P(i)中每一空間區(qū)域大區(qū)塊(MB)的編碼之用。影像編碼器350根據這些量化位階編碼目前畫面P(i)(步驟S460)。在目前畫面編碼完成后,影像編碼器350將畫面P(i)的實際消耗位元數UB(i)以及實際所用量化位階的平均值AQ(i)回報給參數更新器340。然后以全活動量A(i)、實際消耗位數UB(i)和實際所用量化位階的平均值AQ(i)為基礎,參數更新器340為目前畫面P(i)計算其活動量對復雜度之比ACR(i)(步驟S470)。
等效上,圖3的較佳實施例可考量以硬件以及/或是軟件來實現(xiàn)。根據本發(fā)明,移動估算單元310和圖3中的其它組件可以管線(pipeline)模式運作,在復雜度估計器320開始計算目前畫面的復雜度之前,移動估算單元310必須先完成即將被編碼的目前畫面其全活動量的計算以及移動向量的估算,并且,當移動估算單元310為下張畫面作準備時,復雜度估計器320和其它組件仍正忙于完成所有與目前畫面相關的運作。接下來將詳細地描述較佳實施例中的每個組件。
移動估算單元310的主要目的之一為決定用何種預測模式來編碼一張畫面里的每個MB,如果必要的話,也進行向前和向后的移動預測,還可從區(qū)塊匹配運算中提取畫面活動量的信息。首先,計算每個MB的自身活動量(intra-activity),將一個MB中4個8×8亮度值區(qū)塊的像素強度以Ym,n,m=0,...,7,n=0,...,7來表示,并且每個8×8區(qū)塊其平均值為Y,則每個MB的內活動量IntraActIntraAct=Σk=03σk]]>其中
σk=Σm=07Σn=07(Ym,n-Y‾)2]]>倘若需要較低的計算復雜度,可以相對Y的絕對差值代替IntraAct=Σk=03Δk]]>其中Δk=Σm=07Σn=07|Ym,n-Y‾|]]>由于I-畫面中的MB僅有一種模式I模式,因此IntraAct即為I-畫面的每個MB的活動量。
如果畫面為P-或B-畫面,則需進行移動估算。最常使用來發(fā)現(xiàn)最佳移動向量的技術是區(qū)塊匹配。對非自身編碼(nonintra coding)而言(如P-和B-畫面),利用將失真標準如變異數或失真絕對值和減至最低,來選擇向前、向后、雙向的預測或不需移動補償。一旦P-或B-畫面中每個MB的MB模式決定,在每個移動補償的差值MB中4個8×8區(qū)塊的變異數也可求得,移動補償的差值MB是待處理MB和預估MB間像素對像素之差;失真絕對值和通常具有較佳的計算效率,因此可用來取代變異數。將4個8×8區(qū)塊的變異數或失真絕對值和相加以求得非內編碼畫面中每個MB的相互活動量(inter-activity),InterAct,然后把非內編碼畫面中每個MB的IntraAct及其InterAct拿來作比較,以判斷InterAct是否較小,若是,則以InterAct作為該MB的活動量,并以相互模式(inter-mode)編碼該MB;否則以IntraAct作為該MB的活動量,并以自身模式(intra-mode)編碼該MB。最后,對目前的I-、P-或B-畫面,將所有MB的活動量相加而得全活動量A(i),移動估算單元310再把全活動量A(i)傳送給復雜度估計器320以及參數更新器340。
接著,復雜度估計器320為某種型態(tài)的目前畫面P(i)估算其復雜度,且依照三種畫面型態(tài),引進加權系數至預估的復雜度Cest(i)。因為B-畫面絕不能被用來預估其它的畫面,故可減少B-畫面的加權系數以分配較少的位元給B-畫面而保留較多的位元給I-和P-畫面;一般而言,編碼I-畫面會產生最多的位元,因此P-畫面的加權系數又小于I-畫面的加權系數。復雜度估計器320根據目前畫面的型態(tài)更新復雜度CI、CP或CB三者其中之一,目前畫面P(i)的復雜度Cest(i)以如下方式估算if(I-畫面)Cest(i)=CI=KI×A(i)ACRI(i-1)]]>else if(P-畫面)Cest(i)=CP=KP×A(i)ACRP(i-1)]]>else if(B-畫面)Cest(i)=CB=KB×A(i)ACRB(i-1)]]>其中,ACRI(i-1)、ACRP(i-1)及ACRB(i-1)是一組連續(xù)畫面中,I、P和B型態(tài)的先前編碼畫面各自的活動量對復雜度之比。這些ACRI(i-1)、ACRP(i-1)和ACRB(i-1)存放在參數更新器340之中,而復雜度估計器320會為適當型態(tài)的先前畫面讀取對應的活動量對復雜度之比。KI、KP及KB分別是I-、P-和B-畫面的加權系數,其范圍一般是在0到1.0之間。至于I-畫面,較佳實施例可以采用KI=1.0。
目標位元分派器330可為一組連續(xù)畫面中的三種型態(tài)I-畫面、P-畫面及B-畫面分別儲存其復雜度CI、復雜度CP與復雜度CB。當收到Cest(i)的時候,視目前畫面P(i)的型態(tài),每次僅更新復雜度CI、CP、CB三者其中之一,如下if(I-畫面)CI=Cest(i)]]>else if(P-畫面)CP=Cest(i)]]>
else if(B-畫面)CB=Cest(i)]]>如圖5所示的較佳實施例,目標位元分派器330是由瞬間位元率計算器510、配額計算器520以及限度單元530所組成。瞬間位元率計算器510為該組連續(xù)畫面更新其瞬間復雜度INST_C,如下INST_C=NI×CI+NP×CP+NB×CB其中,NI、NP和NB分別是一組連續(xù)畫面中I-、P-及B-畫面的數目。在此同時,瞬間位元率計算器510還從參數更新器340讀取這組連續(xù)畫面的統(tǒng)計復雜度STAT_C,并且依據下式計算一組連續(xù)畫面的瞬間位元率INST_RINST_R=ERmean·(1+SF·(INST_CSTAT_C-1))]]>其中,ERmean是本組連續(xù)畫面的既定平均位元率,SF是一縮放因子,其范圍在0到1之間;而瞬間位元率INST_R最好限制在這組連續(xù)畫面的最大、最小位元率ERmax及ERmin之間。
配額計算器520接著分配目標位元額度TB(i)給目前畫面P(i),而目標位元額度TB(i)是根據TB(i)=Cest(i)INST_C×INST_R]]>但是,實際的消耗位元數并不會和期望的位元額度剛好相等,因此發(fā)展一種回授策略來使畫面實際消耗的位元數接近于目標位元額度,在較佳實施例中,編碼至目前為止的超用位元量,可由正在編碼的目前畫面攤還一部份TB(i)=TB(i)-AR×EB其中,EB是參數更新器340傳來的超用位元量,AR則是既定的攤還率,其范圍一般是在0.05到0.2之間。按照前面的式子,目標位元額度TB(i)是與目前畫面的復雜度Cest(i)以及一組連續(xù)畫面的瞬間位元率INST_R成正比,而與一組連續(xù)畫面的瞬間復雜度INST_C成反比。限度單元530則能用來調整目標位元額度TB(i)以符合VBV規(guī)范,因此事先定下了額度的上限(U_bound)及下限(L_bound)。就固定位元率(CBR)的操作而言,分配給一張畫面的目標位元額度須使VBV緩沖器不會滿溢或匱乏,所以限度單元530將目標位元額度TB(i)限制在上、下限范圍內if(TB(i)>U_bound)then TB(i)=U_boundif(TB(i)<L_bound)then TB(i)=L_bound若是可變位率(VBR),則只要防止VBV匱乏即可,故if(TB(i)>U_bound) then TB(i)=U_bound然后,目標位元額度TB(i)會被傳送到參數更新器340以及影像編碼器350。
回到圖3,影像編碼器350透過訊號線312從移動估算單元310接收畫面資料以及每個MB的移動向量和MB模式。為了盡可能的使畫面達到最佳品質,影像編碼器350依據目標位元額度TB(i)來決定目前畫面的每個MB編碼所用的量化位階,以這些資料為基礎,影像編碼器350開始對目前畫面P(i)進行編碼且輸出編碼后的資料CD。在目前畫面P(i)編碼之后,影像編碼器350將所用的量化位階做平均并且計算實際消耗位元數UB(i),再回報目前畫面的UB(i)以及實際所用量化位階的平均值AQ(i)給參數更新器340。
參數更新器340會為一組連續(xù)畫面中的三種型態(tài)I-畫面、P-畫面及B-畫面分別儲存其復雜度統(tǒng)計量SCI、SCP與SCB,并且取畫面的復雜度Cest(i)來更新這三種型態(tài)中同型態(tài)畫面的復雜度統(tǒng)計量,如下SCX=SCX·(WX-1)+CestWX]]>其中,下標x所代表的I、P及B型態(tài)端視目前畫面P(i)的型態(tài)而定,WI、WP和WB分別是I-畫面、P-畫面及B-畫面的既定加權系數。換言之,依據目前畫面P(i)的型態(tài),復雜度統(tǒng)計量SCI、SCP或SCB每次只有其中一個會被更新if(I-畫面)
SCI=SCI·(WI-1)+Cest(i)WI]]>else if(P-畫面)SCP=SCP·(WP-1)+Cest(i)WP]]>else if(B-畫面)SCB=SCB·(WB-1)+Cest(i)WB]]>其中,WI、WP和WB的范圍一般是在200至2000之間。參數更新器340接著以下列的方程式計算一組連續(xù)畫面的統(tǒng)計復雜度STAT_C,STAT_C=NI× SCI+NP×SCP+NB×SCB其中,NI、NP和NB分別是每組連續(xù)畫面中I-、P-及B-畫面的數目。畫面P(i)的目標位元額度TB(i)以及實際消耗位元數UB(i)間的差距,會由參數更新器340做累計以便在面P(i)編碼的后得到超用位元量EBEB=EB×(1-AR)+UB(i)-TB(i)其中,AR是既定的攤還率。因此,活動量和實際復雜度之間的關系,ACR(i),可從以下計算得到ACR(i)=A(i)AQ(i)×UB(i)]]>這個剛編碼完成畫面P(i)所屬的ACR(i)可用來預估下一張同型態(tài)畫面的復雜度。為使ACR(i)不會受到富含噪聲畫面的影響,較佳實施例利用了ACR(i)和ACR(i-1)的線性組合,例如if(I-畫面)ACRI(i)=ACRI(i-1)×(1-CW)+ACR(i)×CW]]>else if(P-畫面)ACRP(i)=ACRP(i-1)×(1-CW)+ACR(i)×CW]]>
else if(B-畫面)ACRB(i)=ACRB(i-1)×(1-CW)+ACR(i)×CW]]>其中,CW是線性組合既定的加權系數。更新過的ACRI(i)、ACRP(i)及ACRB(i)會被傳送到復雜度估計器320,以便為下一張適當型態(tài)的畫面估算其復雜度,此外,超用位元量EB以及統(tǒng)計復雜度STAT_C則送至目標位元分派器330作為位分配之用。
雖然本發(fā)明已以一具體實施例揭露如上,然其僅為了易于說明本發(fā)明的技術內容,而并非將本發(fā)明狹義地限定于該實施例,任何熟習此技藝者,在不脫離本發(fā)明的精神和范圍內,當可作些許的更動與潤飾,因此本發(fā)明的保護范圍當視權利要求的界定為準。
權利要求
1.一種動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,至少包含一移動估算單元,接收一視訊序列里的一組連續(xù)畫面中即將被編碼的一目前畫面,以計算該目前畫面的一全活動量;一復雜度估計器,基于該目前畫面的該全活動量以及該組連續(xù)畫面中一同型態(tài)的先前編碼畫面其活動量對復雜度之比,來估計該目前畫面的一復雜度;一目標位元分派器,以該目前畫面的該復雜度更新該組連續(xù)畫面的一瞬間復雜度,并且基于該組連續(xù)畫面的一既定平均位元率、一統(tǒng)計復雜度及該瞬間復雜度來計算該組連續(xù)畫面的一瞬間位元率,而根據該目前畫面的該復雜度、該組連續(xù)畫面的該瞬間復雜度及該瞬間位元率,分配一目標位元額度給該目前畫面;以及一參數更新器,根據該目前畫面的該全活動量、該目前畫面的一實際消耗位元數和編碼該目前畫面實際所用量化位階的一平均值,計算該目前畫面其活動量對復雜度之比,并且基于該目前畫面的該復雜度來計算該組連續(xù)畫面的該統(tǒng)計復雜度;其中,該目前畫面的該活動量對復雜度之比與該目前畫面的該全活動量成正比,而與該目前畫面的該實際消耗位元數以及該目前畫面實際所用量化位階的該平均值成反比。
2.根據權利要求1所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,更至少包含一影像編碼器,依上述目前畫面的上述目標位元額度而決定上述目前畫面所使用的復數個量化位階,該些量化位階是作為上述目前畫面中的每一空間區(qū)域編碼之用,該影像編碼器根據該些量化位階編碼上述目前畫面,且將上述目前畫面的上述實際消耗位元數以及上述目前畫面實際所用量化位階的上述平均值回報給上述參數更新器。
3.根據權利要求1所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述復雜度估計器所估計得到的上述目前畫面的上述復雜度,是依據一方程式Cest=K×AACR]]>其中,Cest是上述目前畫面預估的上述復雜度,K是一既定的加權值,其范圍在0到1之間,A是上述目前畫面的上述全活動量,ACR是上述同型態(tài)的先前編碼畫面其活動量對復雜度之比。
4.根據權利要求2所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述參數更新器計算上述目前畫面其活動量對復雜度之比,是依據ACR=AAQ×UB]]>其中,ACR代表上述目前畫面其活動量對復雜度之比,A是上述目前畫面的上述全活動量,AQ是上述目前畫面實際所用量化位階的上述平均值,UB是上述目前畫面的上述實際消耗位元數。
5.根據權利要求1所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述目標位元分派器為上述一組連續(xù)畫面中的三種型態(tài)I-畫面、P-畫面及B-畫面分別儲存其復雜度CI、復雜度CP與復雜度CB,并且取上述目前畫面的上述復雜度來更新該三種型態(tài)中同型態(tài)畫面的復雜度。
6.根據權利要求5所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述目標位元分派器至少包含一瞬間位元率計算器,以上述目前畫面的上述復雜度為基礎,來更新上述一組連續(xù)畫面的上述瞬間復雜度,并且根據一函數來計算上述一組連續(xù)畫面的上述瞬間位元率,其中該函數取決于上述一組連續(xù)畫面的上述既定平均位元率、上述瞬間復雜度及上述統(tǒng)計復雜度;一配額計算器,以上述目前畫面的上述復雜度、上述一組連續(xù)畫面的上述瞬間位元率及上述瞬間復雜度為基礎,來分配上述目標位元額度;以及一限度單元,用來將上述目標位元額度限制在一既定上限之下。
7.根據權利要求6所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述瞬間位元率計算器求得的上述一組連續(xù)畫面的上述瞬間復雜度,是根據INST_C=NI×CI+NP×CP+NB×CB其中,INST_C代表上述瞬間復雜度,NI、NP和NB分別是上述一組連續(xù)畫面的中上述I-、P-及B-畫面的數目。
8.根據權利要求6所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述瞬間位元率計算器計算上述一組連續(xù)畫面的上述瞬間位元率,是根據INST_R=ERmean·(1+SF·(INST_CSTAT_C-1))]]>其中,ERmean是上述一組連續(xù)畫面的上述既定平均位元率,SF是一縮放因子,其范圍在0到1之間,INST_C、STAT_C分別是上述一組連續(xù)畫面的上述瞬間復雜度與上述統(tǒng)計復雜度,INST_R代表上述瞬間位元率。
9.根據權利要求1所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述參數更新器為上述一組連續(xù)畫面中的三種型態(tài)I-畫面、P-畫面及B-畫面分別儲存其復雜度統(tǒng)計量SCI、復雜度統(tǒng)計量SCP與復雜度統(tǒng)計量SCB,并且取上述目前畫面的上述復雜度來更新該三種型態(tài)中同型態(tài)畫面的復雜度統(tǒng)計量,如下SCX=SCX·(WX-1)+CestWX]]>其中,該下標x所代表的I、P及B型態(tài)端視上述目前畫面的型態(tài)而定,WI、WP和WB分別是I-畫面、P-畫面及B-畫面的既定加權系數,Cest是上述目前畫面的上述復雜度。
10.根據權利要求9所述的動態(tài)影像壓縮的可變位元率控制裝置,其特征在于,上述參數更新器計算上述一組連續(xù)畫面的上述統(tǒng)計復雜度,是根據STAT_C=NI×SCI+NP×SCP+NB×SCB其中,STAT_C代表上述統(tǒng)計復雜度,NI、NP和NB分別是上述一組連續(xù)畫面的中上述I-、P-及B-畫面的數目。
全文摘要
一種動態(tài)影像壓縮的可變位元率控制裝置。根據本發(fā)明,先計算一組連續(xù)畫面中即將被編碼的目前畫面的全活動量,然后基于全活動量以及該組連續(xù)畫面中同型態(tài)的先前編碼畫面其活動量對復雜度之比,估計目前畫面的復雜度,并且以此復雜度更新該組連續(xù)畫面的瞬間復雜度和統(tǒng)計復雜度,然后計算其瞬間位元率,而根據畫面復雜度、該組連續(xù)畫面的瞬間復雜度及瞬間位元率,分配目標位元額度給目前畫面。在畫面編碼之后,根據目前畫面的全活動量、實際消耗位元數和實際所用量化位階的平均值,計算其活動量對復雜度之比。
文檔編號H04N11/04GK1581975SQ0315318
公開日2005年2月16日 申請日期2003年8月8日 優(yōu)先權日2003年8月8日
發(fā)明者張永清, 姚若壇, 徐國平 申請人:矽統(tǒng)科技股份有限公司
網友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
印江| 宜黄县| 饶河县| 娱乐| 三台县| 桐庐县| 嵩明县| 家居| 乌兰浩特市| 财经| 宝兴县| 寻乌县| 凤台县| 江都市| 铜梁县| 工布江达县| 乌海市| 察隅县| 兴仁县| 顺义区| 天台县| 洛南县| 谢通门县| 双江| 天全县| 江孜县| 辽阳市| 衡阳县| 德安县| 敦煌市| 车致| 宜都市| 苍山县| 乌鲁木齐县| 明水县| 上思县| 三台县| 贵阳市| 兴文县| 友谊县| 广安市|