The present invention relates to a system for coding and decoding video data, and more particularly, to a system and method for coding and decoding spatially scalable video data.
Video data is generally processed and transferred in the form of bitstreams. A bitstream is spatially scalable if the bitstream contains at least one independently decodable substream representing video sequence which is less than the full resolution of the bitstream. The conventional standards for processing video data, such as Moving Pictures Experts Group (MPEG) 2, MPEG 4 and H.263+ standards, include spatial scalability modes.
There have been some problems and difficulties in processing video data using the conventional standards. For example, video data processing for spatially scalable video data is inefficient because decoded enhancement-layer sequence has significantly lower video quality than a non-scalable sequence at the same bit rate.
One improved scheme over the conventional video data processing systems and methods is a discrete cosine transform (DCT)-based subband decomposition approach in which subband decomposition is used to create base and enhancement layer data which are then encoded using motion compensated DCT coding. The DCT-based subband decomposition approach is more completely described in “Spatial scalable video coding using a combined subband-DCT approach”, by U. Benzler, October 2000, IEEE, vol. 10, no. 7, pp. 1080-1087.
Although the DCT-based subband decomposition approach provides better efficiency in the spatial scalability mode than the conventional video data processing systems and methods, it still has some disadvantages in processing spatially scalable video data. The disadvantages include the requirement of new quantization matrices for DCT processes. In other words, the DCT-based subband approach creates data whose DCT coefficients are statistically very different from the DCT coefficients of original pixels, and, hence, new quantization matrices for the DCT coefficients must be used to obtain good video quality. The DCT-based subband approach also must be modified to obtain flexibility in varying the relative bit rate allocation between base layer data and enhancement layer data. Thus, an interpolation filter used in the DCT-based subband approach to compute based layer predictions cannot be optimal.
Therefore, a need exists for a video data CODEC system in which DCT-based decimation and interpolation are performed with respect to spatially scalable video data. It would also be advantageous to provide a video data CODEC system that facilitates DCT-based motion compensation scheme for enhancement layer of the video data.
In accordance with the principles of the present invention, there is provided a code-decode (CODEC) system for encoding and decoding spatially scalable video data, including a decimate unit for performing DCT-based down-sampling with respect to macro block data of input video data to produce decimated block data representing the low frequency portion of the macro block data, a first encoder for encoding the decimated block data to produce base layer DCT data having DCT coefficients representing the low frequency portion, a first decoder for decoding the base layer DCT data from the first encoder to produce base layer block data, an interpolate unit for performing DCT-based interpolation with respect to the base layer block data from the first decoder to produce interpolated base layer block data, a second encoder for encoding enhancement layer block data obtained from the macro block data and the interpolated base layer block data to produce enhancement layer DCT data wherein the enhancement layer block data represents the high frequency portion of the macro block data, and a second decoder for decoding the enhancement layer DCT data from the second encoder to produce reconstructed macro block data.
In an exemplary embodiment of the invention, the first encoder includes a first motion compensate unit for compensating the decimated block data from the decimate unit with base layer data of a previous picture and motion vectors for the macro block data to produce compensated base layer block data so that the first encoder performs DCT with respect to the compensated base layer block data to produce the base layer DCT data.
The second encoder may also include a second motion compensation unit for compensating the enhancement layer block data with enhancement layer data of a previous picture and motion vectors for the macro block data to produce compensated enhancement layer block data so that the second encoder performs DCT with respect to the compensated enhancement layer block data to produce the enhancement layer DCT data.
This disclosure will present in detail the following description of preferred embodiment with reference to the following figures wherein:
A video data code-decode (CODEC) system according to the present invention employs discrete cosine transform (DCT)-based manipulation (e.g., decimation and interpolation) of video data. DCT-based sampling puts low frequency DCT contents of a block into low resolution pixels of a base layer and leaves pixels containing high frequency DCT contents to be encoded in an enhancement layer. Horizontal and vertical DCT-based decimation and interpolation of a pixel block can be implemented in the spatial domain as a single matrix multiplication, thereby its complexity can be reduced.
In addition to the new DCT-based decimation/interpolation for spatial scalability, the video data CODEC system of the present invention also employs a new motion compensation scheme that predicts pixels containing low-frequency DCT contents in a base layer and pixels containing high-frequency DCT contents in an enhancement layer from corresponding base layer and enhancement layer, respectively, of the previous reconstructed picture. In this approach of the present invention, a single set of motion vectors is used for both the base layer and the enhancement layer.
The video data CODEC system of the present invention applying to spatial scalability modes does not have the disadvantages of the conventional CODEC systems such as the DCT-based subband approach. Since the DCT-based sample-rate conversion in the present invention is matched to DCT contents used for the subsequent coding of pixels or prediction errors, good performance can be obtained using the same quantization matrices as those used for a non-scalable CODEC. Thus, the quantization matrices can be optimized. The video data CODEC system with new spatial scalability algorithm is described in detail below.
Referring to
The first encoder 13 encodes the decimated block data output from the decimate unit to obtain base layer data containing low frequency contents of the macro block B16×16. The first encoder 13 also performs motion compensation with respect to the block data from the decimate unit 11 using base layer data of the previous picture. The first decoder 15 decodes the encoded data from the first encoder 11 to produce 8×8 block data.
The interpolate unit 17 performs DCT-based interpolation with respect to the 8×8 block data received from the first decoder 15 to produce a 16×16 macro block. The original macro block data B16×16 is subtracted by the macro block data output from the interpolate unit 17 in the adder.
The second encoder 18 encodes the output data of the adder 16 to obtain enhancement layer data containing high frequency contents of the input macro block data B16×16. In the second encoder 18, motion compensation is performed with respect to the output data of the adder 16 using enhancement layer data of the previous reconstructed picture. The second decoder 19 decodes the encoded data received from the second encoder 18 to produce reconstructed 16×16 macro block data. Each block of the CODEC system in
Referring to
B4×4=M1B8×8M2 (1)
Here, M1 is a 4×8 matrix and M2 is an 8×4 matrix. To obtain the base layer 4×4 block B4×4, the 8×8 block B8×8 is vertically down-sampled with matrix M1 and horizontally down-down-sampled with matrix M2.
Referring to
B8×8=H1B4×4H2 (2)
Here, H1 is an 8×4 matrix and H2 is a 4×8 matrix. To obtain the interpolated 8×8 block B8×8, the 4×4 block B4×4 is vertically down-sampled with matrix H1 and horizontally down-sampled with matrix H2.
Referring to
Referring to
An interpolate unit 53 performs DCT-based interpolation with respect to the block of pixels selected by the select unit 51 to produce a prediction block with full resolution. The full resolution prediction block may be subject to half-pixel interpolation 55, if necessary, using simple bilinear interpolation. The motion compensation will be done with half-pixel accuracy by use of the half-pixel interpolation. In other words, a motion vector may point to a location halfway between two pixels in a reference frame, in which case the prediction is computed using interpolation. The need to do half-pixel interpolation is indicated by an odd value for the motion vector. A decimate unit 57 performs DCT-based decimation to down-sample the full resolution prediction block from the interpolate block or the half-pixel interpolated block to produce a base layer prediction block.
Referring again to
Referring to
Such enhancement layer motion compensation process is preferably implemented as a matrix multiplication for each of the horizontal and vertical directions. In other words, to implement the enhancement layer motion compensation, the operations shown in the DCT unit 63, the low frequency remove unit 65, and the IDCT unit 67 can be combined into a pre-multiplication of the DCT unit 63 input by one matrix for vertical processing and a post-multiplication by another matrix for horizontal processing. This is much the same as the implementation of the decimate unit 11 and the interpolate unit 17 in
Referring again to
The second decoder 19 has IQ and IDCT units 191 each for performing inverse quantization and inverse DCT with respect to the enhancement layer DCT data provided from a corresponding one of the DCT and quantization units 183 in the second encoder 18. The IQ and IDCT units 191 produce enhancement layer block data (i.e., 16×16 macro block) by combining four 8×8 blocks each generated from the respective IQ and IDCT units 183. The enhancement layer block data is added to the output of the second motion compensation unit 181, and a result thereof is also added to the output of the interpolate unit 17 to produce a reconstructed macro block data. The two additions in the second decoder 19 correspond to the two subtractions which are the subtraction of the output of the interpolate unit 17 from the input macro block data B16×16 and the subtraction of the output of the second motion compensation unit 181 from the difference obtained by the previous subtraction.
In
In a preferred embodiment of the present invention, there is provided a method for coding and decoding spatially scalable video data, including the steps of decimating macro block data of input video data by performing DCT-based down-sampling to obtain decimated block data representing low frequency part of the macro block data, encoding the decimated block data to obtain base layer DCT data having DCT coefficients representing the low frequency part, decoding the base layer DCT data to obtain base layer block data, interpolating the base layer block data by performing DCT-based up-sampling with respect to the base layer block data to produce interpolated base layer block data, subtracting the interpolated base layer block data from the macro block data to obtain enhancement layer block data representing high frequency part of the macro block data, encoding the enhancement layer block data to obtain enhancement layer DCT data, and decoding the enhancement layer DCT data to obtain reconstructed macro block data.
The encoding the decimated block data step may include performing motion compensation of the decimated block data, wherein the motion compensation includes selecting a block of pixels to be predicted from base layer data of a previous picture using motion vectors for the macro block data, performing DCT-based interpolation with respect to the block of pixels to be predicted to produce full resolution prediction block data, decimating the full resolution prediction block data by performing DCT-based down-sampling to produce base layer prediction block data, and subtracting the base layer prediction block data from the decimated block data to obtain compensated base layer block data which is subject to DCT to produce the base layer DCT data.
The encoding the enhancement layer block data step may also include performing motion compensation of the enhancement layer block data, wherein the motion compensation includes selecting a block of pixels to be predicted from enhancement layer data of a previous picture using motion vectors for the macro block data, performing DCT with respect to the block of pixels to be predicted to produce a block of DCT coefficients, removing low frequency contents of the block of DCT coefficients, performing IDCT with respect to the DCT coefficients in which the low frequency contents are removed, to obtain enhancement layer prediction block data, and subtracting the enhancement layer prediction block data from the enhancement layer block data to obtain compensated enhancement layer block data which is subject to DCT to produce the enhancement layer DCT data.
Having described preferred embodiments of a CODEC system for spatially scalable video data according to the present invention, modifications and variations can be readily made by those skilled in the art in light of the above teachings. It is therefore to be understood that, within the scope of the appended claims, the present invention can be practiced in a manner other than as specifically described herein.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 60/260,598 filed Jan. 9, 2001.
Number | Name | Date | Kind |
---|---|---|---|
5596369 | Chau | Jan 1997 | A |
5742343 | Haskell et al. | Apr 1998 | A |
5745182 | Yukitake et al. | Apr 1998 | A |
5751861 | Astle | May 1998 | A |
5768535 | Chaddha et al. | Jun 1998 | A |
5852565 | Demos | Dec 1998 | A |
5903313 | Tucker et al. | May 1999 | A |
5978032 | Yukitake et al. | Nov 1999 | A |
5991865 | Longhenry et al. | Nov 1999 | A |
6141381 | Sugiyama | Oct 2000 | A |
6148034 | Lipovski | Nov 2000 | A |
6178205 | Cheung et al. | Jan 2001 | B1 |
6185340 | Comer | Feb 2001 | B1 |
6192080 | Sun et al. | Feb 2001 | B1 |
6208692 | Song et al. | Mar 2001 | B1 |
6215823 | Kim et al. | Apr 2001 | B1 |
6219103 | Sugiyama | Apr 2001 | B1 |
6233392 | Comer | May 2001 | B1 |
6269484 | Simsic et al. | Jul 2001 | B1 |
6337881 | Chaddha | Jan 2002 | B1 |
6493387 | Shin et al. | Dec 2002 | B1 |
6728775 | Chaddha | Apr 2004 | B1 |
Number | Date | Country | |
---|---|---|---|
20020090028 A1 | Jul 2002 | US |
Number | Date | Country | |
---|---|---|---|
60260598 | Jan 2001 | US |