Method and apparatus for decoding MPEG video data

Pulse or digital communications – Bandwidth reduction or expansion – Television or motion video signal

Reexamination Certificate

Rate now

  [ 0.00 ] – not rated yet Voters 0   Comments 0

Details

Reexamination Certificate

active

06377627

ABSTRACT:

FIELD OF THE INVENTION
The present invention relates to MPEG video data decoders and specifically to a method and apparatus for improving the performance of MPEG video data decoders.
BACKGROUND OF THE INVENTION
MPEG, which stands for Moving Pictures Experts Group, is a standard for compression of video and audio for broadcast video/audio and compact discs. MPEG (video and audio systems) is the exclusive syntax of the United States Grand Alliance HDTV specification, the European Digital Video Broadcasting Group, and the high density compact discs. MPEG-1 and MPEG-2 are well known and documented and referred to respectively as ISO/IEC 11172 Information Technology Coding of Moving Pictures and Associated Audio for Digital Storage Media at up to about 1.5 Mbits/s, 1993 and ISO/IEC 13818 Information Technology—Generic Coding of Moving Pictures and Associated Audio, the disclosures of which are hereby incorporated by reference.
In accordance with the standard, MPEG video provides an efficient way to represent image sequences in the form of more compactly coded data. MPEG also describes a decoding (reconstruction) process whereby coded bits in a transmitted MPEG video bit stream are mapped from the compressed representation into the original raw video signal data format of the image sequence suitable for driving a video display. For example, a flag in the coded bit stream signals whether the following bits are to be decoded with purely a discrete cosine transform (DCT) algorithm or with a prediction algorithm. The header also contains information needed to apply the prediction in algorithm followed by a DCT algorithm. The algorithms comprising the decoding process are regulated by MPEG. MPEG can be applied to exploit common video characteristics such as spatial redundancy, temporal redundancy, uniform motion, spatial masking.
MPEG encodes a video sequence (possible decimated from the original) of, e.g. 720 by 480 pixel frames by 30 frames/s. The images are in color, but are converted to the YUV space, and the two chrominance channels (U and V) are decimated further to 360 by 240 pixels. A coarser resolution in the chrominance channels is acceptable within the bounds of human perception in the decoded reconstructed raw video signal data, at least for “natural” (not computer generated) images. The basic scheme of MPEG is to predict motion from frame to frame in the temporal direction, and then to use discrete cosine transforms, “DCTs” to organize the redundancy in the spatial directions. The DCT's are done on 8×8 blocks, and the motion prediction is done in the luminance (Y) channel on 16x16 blocks, together forming a so-called macroblock.
The encoded data is organized into a video sequence, which consists of a series of Groups of Pictures, each of some finite length. Each picture is broken down into the a series of slices. Each slice is comprised of a series of adjacent macroblocks. Each macroblock consists of four adjacent 8×8 blocks of data each representing one of four picture element (“pel”) values for the Y (luminescence) portion of the video signal (each of the four related to a pixel in the television screen, for example). In addition there are two 8×8 blocks of data, one each for the chrominance values Cb and Cr. Each of the chrominance values is associated with the each of the four Y luminescence values, which relatively are associated with one of the four pixels forming the pel. The six 8×8 blocks of data, therefore, constitute a macroblock. The decoding process utilizes, respectively, frame and filed Inverse Discrete Cosine Transforms (“IDCTs”) to decode the respective frame and field Discrete Cosine Transforms (“DCTs”) and convert the encoded video signal from the frequency mode to the spatial mode in order to produce the reconstruction raw video signal data.
The DCT coefficients (of either the actual data, or the difference between the block being decoded/reconstructed and another closely matching block from another frame) are “quantized”, to form variations around a much shorter average value. The quantization can change for every “macroblock,” i.e., for each 16x16 block (four 8×8 blocks) of Y and the corresponding two 8×8 blocks for the U(Cb) and V(Cr) for example the quantized values can be 8, 9, 10 or 11 bits in length. The result of all of this, which includes DCT coefficients, motion vectors, and quantization parameters (among other elements) is modified-Huffman coded using fixed tables. The DCT coefficients have a special Huffman table that is “two-dimensional.” One code specifies a run-length of zeros and a non-zero value at the end of the run. Motion vectors and the DC DCT components are differential pulse code modulation (“DPCM”) coded.
Video decoders/reconstructors are known in the art. It is known in the art for such video decoders/reconstructors to have a separate co-processor for doing variable length decoding of the MPEG video data input bit stream, along with a core processor, which does the reconstruction of the decoded MPEG video data into raw video signal data. The reconstructed video signal may be provided to an external device including another host computer or a video player for display.
The speed of processing a macroblock is determined by the amount of data in the macroblock, the speed of the variable length decoder, the speed of the processes performed in doing the reconstruction by the core processor (i.e., among other things, the algorithm used to do the Inverse Discrete Cosine Transformations [“IDCTs”] on the DCTs) and the speed of data transfer between the two. For block by block decoding a familiar algorithm involves a two-dimensional IDCT for the 8×8 block which is performed as eight one dimensional IDCTs (“row operations”), one for each of the eight rows followed by eight one dimensional IDCTs (“column operations”) with the result being the IDCT values for each location in the 8×8 block of reconstructed video signal data. A typical algorithm for performing each of the one dimensional row operations or column operations requires 29 additions and 11 multiplications. In some MPEG decoders special purpose microprocessors, referred to as Digital Signal Processors (“DSPs”), are equipped with special purpose circuitry, e.g., for doing multiplies and/or divides in specially dedicated hardware (along with the usual arithmetic and logic units that a microprocessor normally possesses). However, for performing MPEG decoding/reconstruction on a general purpose microprocessor/microcontroller and/or using a general purpose microprocessor/microcontroller as a co-processor with, e.g., a VLD co-processor, there exists a need to streamline the processing of the MPEG reconstruction algorithm. One way of reducing the calculations that takes advantage of the MPEG decoded video data structure is the fact that for a row or column that is all zeros, the IDCT output is also all zeros. MPEG encoding is designed to induce as many zero values into the positions within a block of decoded video data as possible. However, one aspect of MPEG encoding tends to eliminate the advantage of the tendency toward having zero DCTs in much of the decoded video data in each block.
For the purpose of so-called “mismatch control”, MPEG encoding adjusts the encoded value of the last column's last row last column (C
(7,7)
) DCT value depending upon the overall “oddness” of the whole block. In this way, the C
(7,7)
position in each block is, on average, a one or is converted from a zero value to a one. In this event, the row operation on the bottom (7th) row will produce all non-zero values. Therefore, none of the subsequent column operations can take advantage of the “all-zeroes” phenomenon, and all will require the full application of the IDCT algorithm, e.g., the 40 computations noted above. There exists in the art, therefore, a need for a more effective and efficient reconstruction algorithm for transforming the decoded video data DCT components into reconstructed raw video signal data with a microprocessor/microcon

LandOfFree

Say what you really think

Search LandOfFree.com for the USA inventors and patents. Rate them and share your experience with other people.

Rating

Method and apparatus for decoding MPEG video data does not yet have a rating. At this time, there are no reviews or comments for this patent.

If you have personal experience with Method and apparatus for decoding MPEG video data, we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Method and apparatus for decoding MPEG video data will most certainly appreciate the feedback.

Rate now

     

Profile ID: LFUS-PAI-O-2834192

  Search
All data on this website is collected from public sources. Our data reflects the most accurate information available at the time of publication.