The present invention relates to a method and a system for calculating a flag parameter, and more particularly to a method and a system for calculating a flag parameter in a decoding process of a digital image.
The idea of video compression is to omit certain data of an image that are imperceptible to human's eyes, i.e. so-called visual redundancy. The data to be omitted are generally similar to other data in space or time dimension, and thus can be removed according to a compression algorithm. H.264/AVC is one of the mainstream standards of video compression. Compared to conventional digital video compression standards, such as MPEG-2, MPEG-4 or H.263, H.264 exhibits higher compression performance, and nevertheless reaches better image quality under the same compression ratio.
The coding mechanism of H.264/AVC compression is block-based. In brief, an image frame is divided into a plurality of rectangular areas called as macroblocks (MB). The macroblocks are then encoded. First, intra-frame prediction and inter-frame prediction techniques are used to remove the similarities between images so as to obtain the residual differences. Then the residual differences are spatially transformed and quantized to remove the visual redundancy.
An important factor of the high compression efficiency in H.364/AVC is the utilization of context adaptive binary arithmetic coding (CABAC). Please refer to
The decoding operation of the decoder 10 is based on a context ID which includes a base portion and an offset portion. The base portion can be obtained by a lookup table, but the offset portion is calculated from the coded_block_flag. Therefore, a key point to calculate the coded_block_flag parameter is to obtain corresponding offset portion. For calculating the offset operation, the coded_block_flag parameters of neighboring left and top blocks next to the target block have to be determined in advance. For example, as illustrated in
Due to the reason that characteristics of neighboring left or top blocks of each block may be different (e.g. size of each, inter or intra macroblock), H.264 utilizes a universal algorithm for calculating the offset value of all blocks. This would result in huge and complex computation since every block demands repeated processing. Consequently, hardware resource is occupied and causes large consumption of time. It can be realized that there exists a need to solve such deficiency.
Therefore, the present invention provides a simplified method and device for calculating a flag parameter.
The present invention provides a method for calculating a flag parameter in a digital image decoding, wherein the method comprises: receiving a macroblock comprising M×N blocks K11˜Kmn; performing a first operation on M block K11˜Km1 along a first edge in a first direction to obtain corresponding M first parameters A11˜Am1; storing the first parameters A11˜Am1 into corresponding locations in a first buffer array; performing a second operation on N blocks K11˜K1n along a second edge in a second operation to obtain corresponding N second parameters B11˜B1n; storing the second parameters B11˜B1n into corresponding locations in a second buffer array; calculating a flag parameter corresponding to a given block according to corresponding values stored in the first and second buffer arrays according to a third operation; storing the flag parameter into location corresponding to a neighboring right block next to the given block in the first buffer array and location corresponding to a neighboring lower block next to the given block in the second buffer array; repeating steps f and g for each of the M×N blocks in the order from blocks along a left most edge, to blocks along a top most edge, blocks along a second left edge, blocks along a second top edge and so on.
The present invention also provides a system for calculating a flag parameter in a digital image decoding, wherein the system comprises: a buffer configured with a plurality of arrays for storing flag parameters of a plurality of blocks within a macroblock into corresponding locations; and a computation unit coupled to the buffer and configured to perform a plurality of operations to obtain offset values corresponding to the plurality of blocks based on the flag parameters stored in the buffer.
The present invention further provides a method for updating flag parameters in CABAC processing, wherein the method comprises: providing two buffer arrays having locations corresponding to a plurality of blocks respectively; storing with first parameters corresponding to a first plurality of blocks along a left most edge of the macroblock in the first buffer array; storing with second parameters corresponding to a second plurality of blocks along a top most edge of the macroblock in the second buffer array; and updating the first and second buffer arrays with flag parameters corresponding to the plurality of blocks obtained by an operation performed on each of the plurality of blocks within the macroblock in a specific order; wherein the specific order is arranged that neighboring left and upper blocks next to a given block are processed prior to the given block.
The above contents of the present invention will become more readily apparent to those ordinarily skilled in the art after reviewing the following detailed description and accompanying drawings, in which:
The present invention will now be described in more detail with reference to the following embodiments. It is to be noted that the following descriptions of preferred embodiments of this invention are presented herein for purpose of illustration and description only; it is not intended to be exhaustive or to be limited to the precise form disclosed.
Referring to
As previously described, for calculating offset values of the blocks, coded_block_flag parameters of two neighboring left and top blocks have to be determined first. For example, the offset value of block 3 is determined according to coded_block_flag parameters of block 1 and block 2; the offset value of block 6 is determined according to coded_block_flag parameters of block 3 and block 4; offset value of Block 7 is determined according to coded_block_flag parameters of block 5 and block 6; and so on. However, it can be observed that the determination of coded_block_flag parameter for blocks 3, 6, 7, 9, 11, 12, 13, 14 and 15 does not require complex processing and it is easier to obtain necessary information. Thus the present invention makes use of the observation to simplify processing of coded_block_flag parameters.
According to an embodiment of the present invention, when the block processing unit 201 receives a digital image, e.g. image as shown in
The computation unit 203 is coupled to the block processing unit 201 and buffer 202, and is configured to implement various operations. In an embodiment of the present invention, the computation unit 203 may perform a first operation, a second operation and a third operation on the current macroblock being processed to obtain relating coded_flag_parameters. The macroblock comprises M×N blocks K11˜Kmn, such as 4×4 blocks 0˜15 as shown in
As explained, for blocks lying within a macroblock, such as blocks, 3, 6, 7, 9, 11, 12, 13, 14 and 15 in
In the following, procedures of the operations will be described in further detail. For the first operation, M blocks K11˜Km1 on the first edge in the first direction are processed to obtain respective first parameters A11˜Am1. The first parameters A11˜Am1 represent coded_block_paramteters of the neighboring left blocks next to the M blocks K11˜Km1 respectively. In the embodiment of
Next, the second operation is performed on N blocks K11˜K1n on the second edge in the second direction to obtain respective second parameters B11˜B1n. The second parameters B11˜B1n represent coded_block_parameters of the neighboring upper blocks (lying within macroblock B) next to the N blocks K11˜K1n. In the embodiment of
a. In the case that the neighboring upper macroblock B does not exist, the coded_block_flag parameter of the neighboring upper block next to blocks 0, 1, 4, 5 is set to 0, i.e.
nB[0]=nB[1]=nB[4]=nB[5]=0;
b. In the case that macroblock B is an inter-MB, the current macroblock is an intra-MB and is transmitted by data partition, and a constrained intra prediction flag (constrained_intra_pred_flag) corresponding to the given block is set to “1”; the coded_block_flag parameter of the neighboring upper block next to blocks 0, 1, 4, 5 is set to 0, i.e.
nB[0]=nB[1]=nB[4]=nB[5]=0;
c. In the case that macroblock B is encoded in intra-frame pulse code modulation (I-PCM), the coded_block_flag parameter of the neighboring upper block next to blocks 0, 1, 4, 5 is set to 1, i.e.
nB[0]=nB[1]=nB[4]=nB[5]=1;
d. In the case that macroblock B consists of four blocks B0, B1, B2 and B3, each having 8×8 pixels, as illustrated in
For blocks 0 and 1, the coded_block_flag parameter of block B2 is used and written to nB[0] and nB[1] in response to bit 2 of a coded block pattern (CBP) of macroblock B is set to 1; otherwise, the coded_block_parameters are set to 0 (i.e. nB[0]=nB[1]=0); and
For blocks 4 and 5, the coded_block_flag parameter of block B3 is used and written to nB[4] and nB[5] in response to bit 3 of CBP of macroblock B is set to 1; otherwise, the coded_block_parameters are set to 0 (i.e. nB[4]=nB[5]=0); and
e. In the case that none of the above conditions is true and macroblock B consists of four Blocks B0˜B16, each having 4×4 pixels, as illustrated in
For blocks 0 and 1, the coded_block_flag parameters of blocks B10 and B11 are used and written to nB[0] and nB[1] respectively in response to bit 2 of CBP of macroblock B is set to 1; otherwise, the coded_block_parameters are set to 0 (i.e. nB[0]=nB[1]=0); and
For blocks 4 and 5, the coded_block_flag parameters of blocks B14 and B15 are used and written to nB[4] and nB[5] respectively in response to bit 3 of CBP of macroblock B is set to 1; otherwise, the coded_block_flag parameters are set to 0 (i.e. nB[4]=nB[5]=0).
The second operation is much simplified than the conventional first operation due to the reason that in macroblock-adaptive frame/field (MBAFF) encoding, H.264 is more flexible about the format of the neighboring left macroblock. In order to cope with the variety, the first operation adopts the conventional method. However, for an embodiment that needs only meet baseline requirement without using full MBAFF encoding, the first operation can be simplified the same as the second operation so as to reach fast computation.
After the first and second operations are performed, coded_block_flag parameters that would be referenced by blocks on the first and second edges are obtained and stored in corresponding position within the buffer 202. The third operation can proceed on each of the blocks K11˜Kmn by use of the stored parameters. In brief, the order of the third operation is arranged so that a given block will not be processed unless the neighboring left and upper blocks next to the given block have been processed and corresponding coded_block_flag parameters have been written or updated in the buffer arrays nA[16] and nB[16]. Then the offset value is calculated as offset(x)=nA[x]+2×nB[x] for the given block x. Consequently, the context ID of the given block can be determined as context ID(x)=base+offset(x).
The CABAC decoder 10 as shown in
Please refer to
a. Set the offset value of block 0=nA[0]+2×nB[0];
b. Calculate context ID of block 0=base value+offset value of block 0; and
c. The CABAC decoder 10 decodes context ID of block 0 into the coded_block_flag parameter P11 of Block 0.
After the coded_block_flag of block 0 is decoded, it is stored in a corresponding location at nA[1] for block 1 and nB[2] for block 2. As can be observed, block 0 is the neighboring left block next to block 1 and the neighboring upper block next to block 2. Both blocks 1 and 2 will need reference to the coded_block_flag parameter of block 0, thus the value is stored in nA[1] and nB[2] for later use.
Likewise, the coded_block_flag parameter P12 of block 1 can be obtained according to the P11 of block 0 stored in nA[1] and the value in nB[1] determined in the second operation:
offset value of block 1=nA[1]+2×nB[1]; and
context ID of block 1=base value+offset value of block 0.
Then the CABAC decoder 10 decodes context ID of block 1 into coded_block_flag parameter P12 of block 1 and stores the value in nA[4] and nB[3]. As can be understood, block 1 is the neighboring left block to block 4 and the neighboring upper block to block 3.
Similarly, the coded_block_flag parameter P21 of block 2 can be obtained according to the value stored in nA[2] during the first operation and the P11 of block 0 stored in nB[2]:
the offset value of block 2=nA[2]+2×nB[2]; and
context ID of block 2=base value+offset value of block 2.
The CABAC decoder 10 decodes context ID of Block 2 into coded_block_flag parameter P12 of block 2 and store the value in nA[3] and nB[8]. As can be understood, block 2 is the neighboring left block to block 3 and the neighboring upper block to block 8.
Accordingly, after the coded_block_flag parameters of blocks on the left most and top most edges in a current macroblock are calculated through the first and second operations, coded_block_flag parameters of all the blocks in the current macroblock can be obtained based on coded_block_flag parameters of neighboring left and upper blocks. Since the second and third operations are simplified, the efficiency for calculating the coded_block_flag parameters can be improved.
In the embodiment of
While the invention has been described in terms of what is presently considered to be the most practical and preferred embodiments, it is to be understood that the invention needs not to be limited to the disclosed embodiment. On the contrary, it is intended to cover various modifications and similar arrangements included within the spirit and scope of the appended claims which are to be accorded with the broadest interpretation so as to encompass all such modifications and similar structures.
Number | Date | Country | Kind |
---|---|---|---|
096132973 | Sep 2007 | TW | national |