|Publication number||US7308029 B2|
|Application number||US 10/744,173|
|Publication date||Dec 11, 2007|
|Filing date||Dec 23, 2003|
|Priority date||Dec 23, 2003|
|Also published as||US8098729, US20050135687, US20080095232|
|Publication number||10744173, 744173, US 7308029 B2, US 7308029B2, US-B2-7308029, US7308029 B2, US7308029B2|
|Inventors||Charles Edward Boice, Charles John Stein, Krishna Chaitanya Ratakonda, Edward Francis Westermann|
|Original Assignee||International Business Machines Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (6), Referenced by (25), Classifications (27), Legal Events (5)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present invention relates generally to the digital video processing field, and more particularly, relates to a method and apparatus for implementing B-picture scene changes.
Various arrangements are known in the art for processing digital video. A video compression standard is the Moving Picture Experts Group (“MPEG”) standard. Within the MPEG standard, video compression is defined both within a given picture and between pictures. Video compression within a picture is accomplished by conversion of the digital image from the time domain to the frequency domain by a discrete cosine transform (DCT), quantization, and variable length coding, all of which are well known in the art. Video compression between pictures is accomplished via a process referred to as motion estimation and compensation, in which a motion vector is used to describe the translation of a set of picture elements (pels) from one picture to another picture. Motion compensation takes advantage of the fact that video sequences are most often highly correlated in time; each frame in any given sequence may be similar to the preceding and following frames. These motion estimation and compensation techniques are also well known in the art.
To carry out the video compression, an encoder scans subsections within each frame, called macro-blocks, and identifies ones that have not changed position from one frame to the next. The encoder also identifies reference macro-blocks while noting their position and direction of motion, and assigns a motion vector, which identifies the motion of the reference block from one frame to another. Only the motion vector and difference data between each reference macro-block and the affected current macro-block is transmitted to the decoder. The decoder stores the information that does not change from frame to frame in its buffer memory and uses it to periodically fill in the macro-blocks of the frame that do not change. The video sequence is subsequently decompressed and displayed.
The MPEG-1 standard was introduced to handle the compressed digital representation of non-video sources of multimedia, and subsequently adapted for the transmission of video signals as long as the video material was first converted from interlaced to progressively scanned format. The MPEG-2 standard was developed to produce higher quality images at higher bit rates for moving images of various applications such as digital storage and communication, and supports both video material in interlaced or progressively scanned formats.
U.S. Pat. No. 5,245,436, issued Sep. 14, 1993 discloses a method and apparatus for detecting a fade within a sequence of digital motion video frames. A first frame and a previous frame are selected from the sequence as first and second regions, respectively, for processing. The mean of the first region and the mean of the second region are each calculated and the relative mean change between the means is determined. A fade is detected if the relative mean change exceeds a first predetermined threshold. Alternatively, a fade is detected if the relative mean change is less than the first predetermined threshold but greater than a second predetermined threshold and the magnitude of the difference between the means is greater than a third predetermined threshold.
U.S. Pat. No. 5,500,689, issued Mar. 19, 1996 discloses a video signal processor including a motion compensated predictive coding data compression system, three adjacent image frames (1, 2, 3) are analyzed to detect a luminance gradient such as is typically associated with image fading. The frames are similarly divided into several segments (A . . . L). The sum of the absolute pixel value differences between corresponding segments from adjacent frames is obtained for each of two pairs adjacent frame segments (DIFF1-2; DIFF2-3). The ratio of the two frame differences (S) is obtained for each segment. Fading is indicated if the ratio remains substantially constant for all or a predetermined number of regions. If fading is detected, any motion vectors generated by the motion coder are assigned a zero value and are not coded.
U.S. Pat. No. 5,771,316, issued Jun. 23, 1998 discloses a rate control algorithm for an MPEG-2 compliant encoder. The rate control algorithm has embodiments useful for constant bit rate and variable bit rate encoding. In particular, the disclosed embodiments relate to fade detection.
U.S. Pat. No. 5,644,504, issued Jul. 1, 1997 and assigned to the present assignee, discloses a digital video encoder processor for discrete cosine transform encoding. The discrete cosine transform encoding includes the encoding steps of (1) determining the discrete cosine transform field or frame type, (2) addressing individual pixels as either (i) vertically adjacent pixels on consecutive Odd and Even field lines, or (ii) vertically adjacent pixels on consecutive Odd field lines, then consecutive Even field lines; or (iii) vertically adjacent pixels on consecutive Even field lines, then consecutive Odd field lines. These subtractions may be performed between (i) consecutive lines, (ii) odd lines, or (iii) even lines. The next step is finding the smallest variance of the above subtractions to determine the discrete cosine transform coding type. The subtractions are carried out in a dynamically partitionable processor having a plurality of datapaths. The datapaths are partitionable by the action of running opcode into (i) a single wide datapath, and (ii) a plurality of narrow datapaths for calculating the absolute value of the difference between two pixels, and accumulating the results of the subtraction.
U.S. Pat. No. 6,040,875, issued Mar. 21, 2000 and assigned to the present assignee, discloses a method to compensate for a fade in a digital video input sequence where the video input sequence is to be compressed according to the MPEG-2 video compression standard. The method comprises a first step of dividing each frame of a current frame into two fields. In a second step, each field of the current frame is divided into at least one field band. In a third step, the luminance and chrominance pixel values are individually summed for the pixels in each field of the current frame. In a fourth step, the luminance pixel values are summed for the pixels in each field band of the current frame. In a fifth step, each respective field band sum and field sum of the current frame is compared with that of the previous frame in the video input sequence. In a sixth step, detection of whether or not a fade has occurred is provided, based upon the comparison in the fifth step. In a seventh step, the encoding algorithm is adjusted if a fade has occurred. Lastly, the first through seventh steps are repeated for at least one subsequent frame in the input video sequence.
In the case of video compression algorithms that use Bi-directionally predicted pictures (B-pictures), a situation encountered where none of the reference or anchor frames yields a good prediction is called a B-picture scene change. When compressing or encoding a video sequence, a need exists for a mechanism to accurately detect B-picture scene changes and to react appropriately to effectively encode the B-picture scene changes to maximize the compressed video stream quality without compromising the output bit rate or the VBV buffer integrity.
Important aspects of the present invention are to provide a method and apparatus for implementing B-picture scene changes. Other important aspects of the present invention are to provide such method and apparatus for implementing B-picture scene changes substantially without negative effect and that overcome some of the disadvantages of prior art arrangements.
In brief, a method and apparatus are provided for implementing B-picture scene changes. A prediction stage predicts a B-picture scene change based upon a sequence of statistical information in an encoder order and a reaction stage is responsive to the prediction stage for modifying a quantization scale of a rate control algorithm.
In accordance with features of the invention, the prediction stage identifies a history of changes in a video sequence; and compares a current image to be encoded with a past reference image and a future reference image in the encoder order. The prediction stage identifies first differences between the current image and the past reference image, and identifies second differences between the current image and the future reference image. The prediction stage identifies minimum differences between the first and second differences, and compares the identified minimum differences to a scene change threshold value.
In accordance with features of the invention, the reaction stage modifies parts of the rate control algorithm to better recognize the potentially increased coding complexity of this picture. The reaction stage identifies an adjusted target bits to be used for an identified B-picture scene change image. The reaction stage fraction identifies a measure of a local standard deviation (PDiff) that is used to calculate the modified quantization scale of the rate control algorithm together with the identified adjusted target bits.
The present invention together with the above and other objects and advantages may best be understood from the following detailed description of the preferred embodiments of the invention illustrated in the drawings, wherein:
Having reference now to the drawings, in
In accordance with features of the preferred embodiment, enhanced more efficient compression is provided for video source material consisting of fades, flash of light from camera flash bulbs, and the like, in such cases, where an abrupt change in video material renders it difficult to compress. In particular, in the case of video compression algorithms that use Bi-directionally predicted pictures (B-pictures), a situation encountered where none of the reference or anchor frames yields a good prediction is called a B-picture scene change. In accordance with features of the invention, higher fidelity compression for such video material is provided through advantageous and novel use of statistical information collected from an input video sequence.
In accordance with features of the preferred embodiment, the prediction stage 106 of the preferred embodiment is particularly suited to practically occurring B-picture scene changes in video sequence and avoids many false alarms and missed detection of B-picture scene changes of prior art arrangements. In the case of B-pictures, the encoder order i.e., the order in which the encoder codes the video frames is different from the order in which the video frames are normally displayed during playback. Noting the changes in encoder order is important in gathering clues as to the nature of the B-picture and categorizing it as a scene change. Some prior art arrangements makes observations using the display order while the present invention uses the encoder order to provide enhanced detection of B-picture scene changes.
In accordance with features of the invention, a history of changes in the video sequence is incorporated into the decision process, thus yielding more reliable scene change information to avoid many false alarms and missed detection of B-picture scene changes of prior art arrangements.
In the prediction stage 106, a sequence of statistical information is relied upon, rather than on individual observations, while at the same time, making these observations in encoder order rather than display order. These new concepts provide advantages over the prior art.
In accordance with features of the preferred embodiment, the reaction stage 108 shifts the emphasis to careful control of the average quantization scale, as this parameter has a better correlation with the perceived compressed video quality than prior art arrangements that place emphasis on the intra/non-intra decision for coding the macro-block. In the reaction stage 108, we rely on adapting the mean quantization scale of the compression scheme that is found to have a better correlation with the compressed video quality. The method of the invention is more successful in both predicting as well as compressing B-picture scene changes.
Referring now to
In accordance with features of the preferred embodiment, if the picture to be encoded is a B-picture, the difficulty of encoding it is compared to its past and future references. If both directions contain poor references for this B-picture, then we designate this picture as a B-picture scene change. Note that these comparisons are made in the encoder order and not in the display order. In the case of B-pictures, past and future frames in encoder order are different from their counterparts in display order. This new method accurately characterizes significantly more sources that visually appear to be fades. In addition, the new method has the ability to characterize video material that is difficult to compress, as Bi-directionally predicted pictures, but is not a part of a fade video sequence. This process of comparison is illustrated in
For a picture “x”, we define:
PSUM(x)=C1*(mean luminance value of the image)+C2*(mean chrominance value of the image)
Further more, we define a scene change threshold as:
SC — T=C3*(number of macro-blocks in a picture)
And, further, we define:
ABS — P=|PSUM(B-picture)−PSUM(past reference)
ABS — F=|PSUM(B-picture)−PSUM(future reference)
ABS — PSUM=MIN(ABS — P, ABS — F)
As indicated in a block 200, differences between the current image and past image are calculated (block 1). Next as indicated in a block 202, differences between the current image and future image are calculated (block 2). Then the minimum differences between block 1 and block 2 are calculated as indicated in a block 204. As indicated in a decision block 206, checking whether the minimum differences are greater than a predetermined threshold is performed.
A B-picture is determined to be a B-picture scene change if the following condition is satisfied:
ABS — PSUM>SC — T
If the minimum differences are not greater than the predetermined threshold SC_T, then a B-picture scene change is not set as indicated in a block 208. When the minimum differences are greater than the predetermined threshold SC_T, then a B-picture scene change is set as indicated in a block 210.
It should be understood that several variations of this algorithm are possible. For example, one may use a linear combination of a measure of the difference data (for example, standard deviation) and mean of the image instead of PSUM. For Gaussian sources, it may be shown that this is equivalent to comparing the histograms of the sources.
It should be understood that the scene change threshold SC_T may be made variable and dependent on an accumulated history of picture-related statistics. For example, the threshold may be constrained to be not less than a fraction, such as one-half, of the average value of ABS_PSUM for the last three B-pictures. ABS_P and ABS_F could be defined as a general function of the difference of the PSUMs; for example, they could be square of the difference of PSUMs. Finally, ABS_PSUM itself may be any monotonically increasing function of ABS_P and ABS_F; for example, reasonable results may be produced also by defining:
ABS — PSUM=MAX(PSUM — F, PSUM — P)+MIN(PSUM — F, PSUM — P)
Referring now to
Once a particular frame is categorized as a B-picture scene change, parts of the rate control algorithm are modified by the reaction stage 108 to better recognize the potentially increased coding complexity of this picture. In the case of most rate control algorithms, a hypothetical reference decoder (HRD) buffer is carefully monitored at the encoder to avoid overflows and underflows. If we are high in the HRD buffer, it may be worthwhile to allocate the B-picture more bits to better account for its complexity. On the other hand, when we are low down in the HRD buffer, it might be better to skimp on the bit allocation and save for the future.
As a result, a fraction of the decoder buffer fullness (FBS) is an important parameter in the rate allocation.
As indicated in a block 300, the fraction of the decoder buffer fullness (FBS) is calculated. As shown at block 300,
E=f(bit rate, bits removed from buffer)
where ID represents initial delay, Sb represents buffer size and E represents excess bits.
As indicated in a block 302, an average bits per picture B_A is calculated, where B_A equals bit rate divided by frame rate. Next a normal, non-scene change target bits per picture T_B is calculated as indicated in a block 304, where T_B=f(pic complexity, B_A, pic type, FBS).
For a normal B, if our target would have been T_B and average bit rate B_A (bits per second/number of frames per second), the adjusted target bits to be used for our newly discovered B-picture scene change (T_A) is:
T — A=Max (2*B — A*FBS)−(B — A/4),T — B)
As indicated in a decision block 306, an adjusted target bits to be used (T_A=Max(2*B_A*FBS)−(B−A/4),T_B)) is determined by comparing (2*B_A*FBS)−(B_A/4) with T_B. If (2*B_A*FBS)−(B_A/4) is less than T_B, the T_A is set equal to T_B as indicated in a block 308. Otherwise when (2*B_A*FBS)−(B_A/4) is less than T_B, the T_A is set equal to (2*B_A*FBS)−(B_A/4) as indicated in a block 310.
Given this allocated bits, we need to choose an average quantization scale Mf that would be a good target for this picture. However, it is clear that due to the change in the picture statistics because of the scene change that Mf cannot be reliably predicted from historical calculations. An average quantization scale Mf is calculated as indicated in a block 312.
Referring now to
We use a measure of the local standard deviation (PDiff) to predict a new large: Mf, as follows:
Min(256*PDiff+B1, 64*PDiff+B2)/T — A
where B1 and B2 are experimentally determined constraints.
Further it should be understood that the adjusted target bits T_A can be obtained through any reasonable function of the average bit rate B_A, the fraction of the decoder buffer fullness FBS and the target bits for a normal B T_B; thus the particular function described above should not be thought of as the only good solution. Also it should be understood that the PDiff employed in determining Mf may be replaced by a more general representative of the statistics of the video sequence and the division could be replaced by a suitable approximation such as a table-lookup operation or multiplication by a suitable scaled representation of the reciprocal of T_A.
In accordance with features of the preferred embodiment, further tuning of the rate control algorithm may involve, for example, one or more of the following operations:
Referring now to
Referring now to
A sequence of program instructions or a logical assembly of one or more interrelated modules defined by the recorded program means 604, 606, 608, 610, direct the video processor system 100 for implementing B-picture scene changes of the preferred embodiment.
While the present invention has been described with reference to the details of the embodiments of the invention shown in the drawing, these details are not intended to limit the scope of the invention as claimed in the appended claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5245436||Feb 14, 1992||Sep 14, 1993||Intel Corporation||Method and apparatus for detecting fades in digital video sequences|
|US5500689||Oct 26, 1994||Mar 19, 1996||Thomson Consumer Electronics, Inc.||System for detecting a video signal image intensity gradient|
|US5644504||Mar 27, 1995||Jul 1, 1997||International Business Machines Corporation||Dynamically partitionable digital video encoder processor|
|US5771316||Dec 26, 1995||Jun 23, 1998||C-Cube Microsystems||Fade detection|
|US6040875||Mar 23, 1998||Mar 21, 2000||International Business Machines Corporation||Method to compensate for a fade in a digital video input sequence|
|US6057893 *||Dec 27, 1996||May 2, 2000||Sony Corporation||Picture encoding method, picture encoding apparatus, picture transmitting method and picture recording medium|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US8155200 *||Oct 31, 2007||Apr 10, 2012||Panasonic Corporation||Motion vector coding and decoding method|
|US8155201 *||Oct 31, 2007||Apr 10, 2012||Panasonic Corporation||Motion vector coding and decoding methods|
|US8160147 *||Oct 31, 2007||Apr 17, 2012||Panasonic Corporation||Motion vector coding and decoding methods|
|US8179968 *||Oct 31, 2007||May 15, 2012||Panasonic Corporation||Motion vector coding and decoding methods|
|US8194745 *||Oct 31, 2007||Jun 5, 2012||Panasonic Corporation||Motion vector coding and decoding methods|
|US8213510 *||Oct 31, 2007||Jul 3, 2012||Panasonic Corporation||Motion vector coding and decoding methods|
|US8363722||Mar 31, 2009||Jan 29, 2013||Sony Corporation||Method and apparatus for hierarchical bi-directional intra-prediction in a video encoder|
|US8526502 *||Aug 5, 2008||Sep 3, 2013||Entropic Communications, Inc.||Method and apparatus for line based vertical motion estimation and compensation|
|US8665961||May 31, 2012||Mar 4, 2014||Panasonic Corporation||Motion vector coding and decoding methods|
|US9020034||Sep 30, 2013||Apr 28, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US9020035||Sep 30, 2013||Apr 28, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US9020036||Sep 30, 2013||Apr 28, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US9020037||Sep 30, 2013||Apr 28, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US9031132||Sep 30, 2013||May 12, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US9118930||Sep 30, 2013||Aug 25, 2015||Tagivan Ii Llc||Motion vector coding and decoding methods|
|US20060239347 *||Apr 25, 2005||Oct 26, 2006||Ashish Koul||Method and system for scene change detection in a video encoder|
|US20070274385 *||May 26, 2006||Nov 29, 2007||Zhongli He||Method of increasing coding efficiency and reducing power consumption by on-line scene change detection while encoding inter-frame|
|US20080063077 *||Oct 31, 2007||Mar 13, 2008||Satoshi Kondo||Motion vector coding and decoding methods|
|US20080069236 *||Oct 31, 2007||Mar 20, 2008||Satoshi Kondo||Motion vector coding and decoding methods|
|US20080069237 *||Oct 31, 2007||Mar 20, 2008||Satoshi Kondo||Motion vector coding and decoding methods|
|US20080084931 *||Oct 31, 2007||Apr 10, 2008||Satoshi Kondo||Motion vector coding and decoding method|
|US20080117979 *||Oct 31, 2007||May 22, 2008||Satoshi Kondo||Motion vector coding and decoding methods|
|US20080260035 *||Oct 31, 2007||Oct 23, 2008||Satoshi Kondo||Motion vector coding and decoding methods|
|US20100238355 *||Aug 5, 2008||Sep 23, 2010||Volker Blume||Method And Apparatus For Line Based Vertical Motion Estimation And Compensation|
|US20100246672 *||Mar 31, 2009||Sep 30, 2010||Sony Corporation||Method and apparatus for hierarchical bi-directional intra-prediction in a video encoder|
|U.S. Classification||375/240.15, 375/E07.148, 375/240, 375/E07.139, 375/E07.163, 375/E07.211, 375/E07.176, 375/240.12, 375/E07.192, 375/240.01|
|International Classification||G06K9/46, H04N7/12, H04N7/50, H04N7/26, G06K9/36|
|Cooperative Classification||H04N19/87, H04N19/176, H04N19/137, H04N19/107, H04N19/124, H04N19/61|
|European Classification||H04N7/26A8B, H04N7/26A6C4, H04N7/26A4Q, H04N7/26A4C2, H04N7/50, H04N7/26P8|
|Apr 23, 2004||AS||Assignment|
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BOICE, CHARLES EDWARD;STEIN, CHARLES JOHN;RATAKONDA, KRISHNA CHAITANYA;AND OTHERS;REEL/FRAME:014550/0246;SIGNING DATES FROM 20030413 TO 20040416
|Apr 13, 2011||FPAY||Fee payment|
Year of fee payment: 4
|Jul 24, 2015||REMI||Maintenance fee reminder mailed|
|Dec 11, 2015||LAPS||Lapse for failure to pay maintenance fees|
|Feb 2, 2016||FP||Expired due to failure to pay maintenance fee|
Effective date: 20151211