USRE41095E1 - Video coder employing pixel transportation - Google Patents

Video coder employing pixel transportation Download PDF

Info

Publication number
USRE41095E1
USRE41095E1 US10/124,385 US12438502A USRE41095E US RE41095 E1 USRE41095 E1 US RE41095E1 US 12438502 A US12438502 A US 12438502A US RE41095 E USRE41095 E US RE41095E
Authority
US
United States
Prior art keywords
transposition
blocks
pixels
block
chrominance
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US10/124,385
Inventor
Barin Geoffry Haskell
Atul Puri
Robert Louis Schmidt
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Priority to US10/124,385 priority Critical patent/USRE41095E1/en
Application granted granted Critical
Publication of USRE41095E1 publication Critical patent/USRE41095E1/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/649Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding the transform being applied to non rectangular image segments
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/527Global motion vector estimation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/85Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
    • H04N19/86Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression involving reduction of coding artifacts, e.g. of blockiness

Definitions

  • the present invention relates to block based video coding schemes and, most particularly, to a method of eliminating artifacts at block boundaries by transposing pixels at block boundaries with pixels from boundaries of neighboring blocks before coding.
  • Known systems for coding video information advantageously employ transform coding of a plurality of blocks or macro blocks.
  • image data often are filtered, broken down into a luminance component and two chrominance components, and organized into blocks of image data.
  • image data are organized first into blocks, each containing an 8 pixel by 8 pixel array of data, then into macro blocks including up to four luminance blocks and two chrominance blocks.
  • the blocks of image data are then transform coded from a pixel domain to an array of transform coefficients and scaled by a quantization parameter and transmitted in an output bit stream.
  • Block-based transform coding is preferred over other known coding schemes, such as wavelet coding, because it is relatively less complex to implement.
  • block-based transform coding causes annoying artifacts in the reconstructed image.
  • Quantization parameters may be established for each block or macro block of image data. Differences in quantization parameters among the various blocks or macro blocks result in distortion at the block boundaries. For instance, in flat image areas, such distortions impose a patchwork effect on reconstructed image data. Similar artifacts appear in image areas having heavy texture, but are less noticeable.
  • Block based coding with variable quantization causes additional artifacts to arise, such as chromo-bleeding, “mosquito-noise” and “ringing” artifacts.
  • An encoder transposes pixels across block boundaries in a predetermined direction prior to transform coding. For example, alternate pixels along a boundary of a first block may be transposed with adjacent pixels in a diagonal direction of neighboring blocks. After transposition, each reformed block undergoes transform coding and quantization.
  • a decoder performs reverse operations of those employed by the encoder.
  • Each coded block is dequantized and coded by an inverse transform to reconstruct blocks of pixel information.
  • Pixels that were subject to transposition are returned to the neighboring blocks from which they originated. After transposition, each block may be processed further for display.
  • the pixel transposition reduces image artifacts at block boundaries and improves image quality, particularly in flat image areas.
  • the transform coding and quantization are performed with greater uniformity on image data.
  • FIGS. 1 (a) and 1 (b) respectively illustrate an encoder 100 and a decoder 200 according to an embodiment of the present invention.
  • FIGS. 2 (a) and 2 (b) respectively illustrate the pixel transposition operation of the present invention as applied to blocks and macro blocks of image data.
  • FIG. 1 (a) circuitry of an encoder 100 is illustrated therein constructed in accordance with an embodiment of the present invention.
  • Blocks or macro blocks of image data are input to a pixel transposition circuit 110 .
  • Each block possesses one of luminance or chrominance image data.
  • the pixel transposition circuit 110 transposes specific pixels from the boundary of each block or macro block with pixels from its neighbors.
  • the pixel transposition circuit 110 then outputs reconstituted blocks of pixel data to a transform coder 120 .
  • the transform coder 120 performs a transform of the block data from a pixel domain to a domain of coefficients representative of the pixel data.
  • the transform coder 120 may perform a discrete cosine transform as is known in the art.
  • the transform coder 120 outputs blocks of coefficient data to a quantizer 130 .
  • the quantizer 130 For each block or macro block, the quantizer 130 generates a quantizer parameter (Q p ) based upon the bandwidth of a channel available to transmit the coded image data.
  • the quantizer 130 scales the coefficients of the block by the quantization parameter.
  • the quantizer 130 outputs blocks of scaled coefficient information and the quantization parameters generated for each for further processing and transmission.
  • FIG. 1 (b) illustrates circuitry of a decoder 200 constructed in accordance with an embodiment of the present invention.
  • Blocks of scaled coefficients are isolated from the transmitted bit stream and input to a dequantizer 230 .
  • the dequantizer 230 identifies the quantization parameter for each block and scales the scaled coefficients of the block by the quantization parameter. Where the quantizer 130 may have divided each coefficient by Qp, the dequantizer multiplies the scaled coefficients by the same Qp to obtain the original coefficients.
  • the dequantizer 230 outputs reconstructed coefficient data to an inverse transform coding circuit 220 .
  • the inverse transform coding circuit 220 transforms the coefficients back to the pixel domain, such as by discrete transform coding.
  • the inverse transform coding circuit 220 outputs blocks or macro blocks of reconstructed pixel data to an inverse pixel transposition circuit 210 .
  • the inverse pixel transposition circuit 210 transposes pixels along its boundary with pixels of its neighbors in a direction complementary to the process applied by the pixel transposition circuit 110 .
  • the inverse pixel transposition circuit 210 returns pixels to their original position in the neighboring blocks or macro blocks.
  • the inverse pixel transposition circuit 110 outputs blocks of pixel information for further processing and display.
  • FIG. 2 (a) An example of a pixel transposition process is shown in FIG. 2 (a) applied on a block by block basis.
  • the pixel transposition circuit 110 stores, in memory, pixel information from a plurality of surrounding Blocks 1 - 8 .
  • the pixel transposition circuit 110 transposes pixel information in a predetermined direction.
  • the pixels are transposed along a diagonal direction from high-left to low-right and vice versa.
  • each alternate pixel on the edge of a given block A is transposed with a pixel across the block boundary in the predetermined direction.
  • the pixel in the upper left-hand corner of block A is transposed with a pixel in the lower right-hand corner of block 1 .
  • Three pixels along the upper edge of block A are transposed with pixels on the lower edge of block 2 in the same diagonal direction.
  • Alternate pixels found on the right-hand edge of block A are transposed with pixels on the left-hand edge of block 4 in the diagonal direction.
  • the pixel in the lower right-hand corner of block A is transposed with a pixel in the upper left-hand corner of block 5 .
  • Alternate pixels on the lower edge of block A are transposed with pixels on the upper edge of block 6 in the diagonal direction.
  • alternate pixels on the left hand edge of block 8 are transposed with pixels found on the right-hand edge of block 8 in the diagonal direction.
  • Pixel transposition is performed only on like-kind data.
  • the pixel transposition circuit 110 considers only neighboring luminance blocks for transposition.
  • pixel transposition is performed only with neighboring chrominance image blocks of the same type.
  • FIG. 2 (b) illustrates an example where pixel transposition is performed on a macro block by macro block basis.
  • the quantizer circuit 130 computes quantization parameters for each macro block rather than for each block, it is preferable to perform a pixel transposition on a macro block by macro block basis.
  • a macro block consists of four blocks of image information, Blocks A-D.
  • the macro block is surrounded by twelve neighboring blocks, Blocks 1 - 12 .
  • pixel transposition is performed on alternate pixels on the boundary of the macro block with pixel information of neighboring macro blocks along a pre-determined direction.
  • the predetermined direction is from low-left to high-right and vice versa. As shown in FIG.
  • the pixel in the upper right-hand corner of Block B is transposed with a pixel in the lower left-hand corner of Block 4 .
  • a pixel in a lower left-hand corner of Block C is transposed with a pixel in the upper right-hand corner of Block 10 .
  • Alternate pixels on the top edge of the macro block, the top edges of Blocks A and B, are transposed with pixels on the bottom edges of Blocks 2 and 3 in a diagonal direction. Pixels on the right-hand edge of the macro block, the right-hand edges of Blocks B and D, are transformed on the left-hand edges of Blocks 5 and 6 in the diagonal direction.
  • Blocks on the lower edge of the macro block are transposed with pixels found in the diagonal direction on the upper edges of Blocks 8 and 9 .
  • pixels found on the left-hand edge of the macro block, the left-hand edges of Blocks A and C are transposed with pixels found in a diagonal direction in the right-hand edges of Blocks 11 and 12 .
  • the direction of transposition is arbitrary. Any direction may be applied. In addition to high-left to low-right and low-left to high-right, horizontal (right to left) and vertical (above to below) directions may be applied. The direction may be predetermined by the system or defined for each coded video frame. If the direction of transposition is variable, the pixel transposition circuit 110 includes a transposition keyword in the output bitstream identifying the direction of transposition. The decoder identifies the transposition keyword and identifies a direction of transposition therefrom.
  • the pattern of transposition may varied.
  • every third or every fourth pixel may be selected for transposition.
  • the pattern may varied so as to select pixels at a first rate, such as every other pixel, in a first region of data, then a second rate, such as every fourth pixel, in a second region of data.
  • the encoder 100 and decoder 200 shown in FIGS. 1 (a) and 1 (b) are not full video coders.
  • Preprocessing is generally performed on pixels before they are input to the pixel transposition circuit 110 , which generally involves sampling of image data, conversion to a digital format, filtering, and component isolation. Preprocessing also includes organization of the component signals into blocks. However, in a preferred embodiment, preprocessing functions may be merged into the pixel transposition circuit 110 . In this case, the pixel transposition circuit may be programmed to reorder pixels before they are organized into blocks.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Compression Of Band Width Or Redundancy In Fax (AREA)

Abstract

A video encoding method and apparatus is shown wherein image information is represented as a plurality of pixels, the pixels are organized into blocks, pixels transposition is performed on image information at the boundaries of the blocks, the blocks are transform coded and quantized. Pixel transposition involves transposition of alternate pixels at the boundaries of blocks with pixels of neighboring blocks found in a pre-determined direction. The pre-determined direction may be fixed by a system or may be applied on an image by image basis. In the event that the pre-determined direction is not established by a system, a pixel transposition circuit includes a transposition keyword in the output bit stream which is used by a decoded to determine the direction of pixel transposition.

Description

BACKGROUND OF THE INVENTION
The present invention relates to block based video coding schemes and, most particularly, to a method of eliminating artifacts at block boundaries by transposing pixels at block boundaries with pixels from boundaries of neighboring blocks before coding.
Known systems for coding video information advantageously employ transform coding of a plurality of blocks or macro blocks. In such systems, image data often are filtered, broken down into a luminance component and two chrominance components, and organized into blocks of image data. For example, according to the proposed MPEG-4 video standard, image data are organized first into blocks, each containing an 8 pixel by 8 pixel array of data, then into macro blocks including up to four luminance blocks and two chrominance blocks. The blocks of image data are then transform coded from a pixel domain to an array of transform coefficients and scaled by a quantization parameter and transmitted in an output bit stream.
Block-based transform coding is preferred over other known coding schemes, such as wavelet coding, because it is relatively less complex to implement. However, such block-based transform coding causes annoying artifacts in the reconstructed image. Quantization parameters may be established for each block or macro block of image data. Differences in quantization parameters among the various blocks or macro blocks result in distortion at the block boundaries. For instance, in flat image areas, such distortions impose a patchwork effect on reconstructed image data. Similar artifacts appear in image areas having heavy texture, but are less noticeable. Block based coding with variable quantization causes additional artifacts to arise, such as chromo-bleeding, “mosquito-noise” and “ringing” artifacts.
Prior systems have attempted to ameliorate the effect of such artifacts by low pass filtering reconstructed image data at block boundaries. However, while low pass filtering reduces block artifacts, it also causes blurring of image data. Low pass filtering impairs image quality.
There is a need in the art for an image coder that advantageously employs block-based transform coding and quantization but reduces image artifacts at block boundaries. Further, there is a need in the art for a coding scheme that reduces artifacts without unnecessarily blurring image data.
SUMMARY OF THE INVENTION
The disadvantages of the prior art are alleviated to a great extent by an image coding scheme that employs block-based transform coding and quantization. An encoder transposes pixels across block boundaries in a predetermined direction prior to transform coding. For example, alternate pixels along a boundary of a first block may be transposed with adjacent pixels in a diagonal direction of neighboring blocks. After transposition, each reformed block undergoes transform coding and quantization.
A decoder performs reverse operations of those employed by the encoder. Each coded block is dequantized and coded by an inverse transform to reconstruct blocks of pixel information. At the conclusion of the inverse transform, pixels that were subject to transposition are returned to the neighboring blocks from which they originated. After transposition, each block may be processed further for display.
The pixel transposition reduces image artifacts at block boundaries and improves image quality, particularly in flat image areas. By including cross border pixels in the transform coding and quantization, the transform coding and quantization are performed with greater uniformity on image data.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGS. 1(a) and 1(b) respectively illustrate an encoder 100 and a decoder 200 according to an embodiment of the present invention.
FIGS. 2(a) and 2(b) respectively illustrate the pixel transposition operation of the present invention as applied to blocks and macro blocks of image data.
DETAILED DESCRIPTION
Turning to FIG. 1(a), circuitry of an encoder 100 is illustrated therein constructed in accordance with an embodiment of the present invention. Blocks or macro blocks of image data are input to a pixel transposition circuit 110. Each block possesses one of luminance or chrominance image data. The pixel transposition circuit 110 transposes specific pixels from the boundary of each block or macro block with pixels from its neighbors. The pixel transposition circuit 110 then outputs reconstituted blocks of pixel data to a transform coder 120. The transform coder 120 performs a transform of the block data from a pixel domain to a domain of coefficients representative of the pixel data. For example, the transform coder 120 may perform a discrete cosine transform as is known in the art. The transform coder 120 outputs blocks of coefficient data to a quantizer 130. For each block or macro block, the quantizer 130 generates a quantizer parameter (Qp) based upon the bandwidth of a channel available to transmit the coded image data. The quantizer 130 scales the coefficients of the block by the quantization parameter. The quantizer 130 outputs blocks of scaled coefficient information and the quantization parameters generated for each for further processing and transmission.
FIG. 1(b) illustrates circuitry of a decoder 200 constructed in accordance with an embodiment of the present invention. Blocks of scaled coefficients are isolated from the transmitted bit stream and input to a dequantizer 230. The dequantizer 230 identifies the quantization parameter for each block and scales the scaled coefficients of the block by the quantization parameter. Where the quantizer 130 may have divided each coefficient by Qp, the dequantizer multiplies the scaled coefficients by the same Qp to obtain the original coefficients. The dequantizer 230 outputs reconstructed coefficient data to an inverse transform coding circuit 220. The inverse transform coding circuit 220 transforms the coefficients back to the pixel domain, such as by discrete transform coding. The inverse transform coding circuit 220 outputs blocks or macro blocks of reconstructed pixel data to an inverse pixel transposition circuit 210. For each block or macro block, the inverse pixel transposition circuit 210 transposes pixels along its boundary with pixels of its neighbors in a direction complementary to the process applied by the pixel transposition circuit 110. The inverse pixel transposition circuit 210 returns pixels to their original position in the neighboring blocks or macro blocks. The inverse pixel transposition circuit 110 outputs blocks of pixel information for further processing and display.
An example of a pixel transposition process is shown in FIG. 2(a) applied on a block by block basis. For each block A, the pixel transposition circuit 110 stores, in memory, pixel information from a plurality of surrounding Blocks 1-8. The pixel transposition circuit 110 transposes pixel information in a predetermined direction. In the example of FIG. 2(a), the pixels are transposed along a diagonal direction from high-left to low-right and vice versa.
Under the pixel transposition process, each alternate pixel on the edge of a given block A is transposed with a pixel across the block boundary in the predetermined direction. In the example of FIG. 2(a), the pixel in the upper left-hand corner of block A is transposed with a pixel in the lower right-hand corner of block 1. Three pixels along the upper edge of block A are transposed with pixels on the lower edge of block 2 in the same diagonal direction. Alternate pixels found on the right-hand edge of block A are transposed with pixels on the left-hand edge of block 4 in the diagonal direction. The pixel in the lower right-hand corner of block A is transposed with a pixel in the upper left-hand corner of block 5. Alternate pixels on the lower edge of block A are transposed with pixels on the upper edge of block 6 in the diagonal direction. Finally, alternate pixels on the left hand edge of block 8 are transposed with pixels found on the right-hand edge of block 8 in the diagonal direction.
Pixel transposition is performed only on like-kind data. When performing pixel transposition on a luminance block, the pixel transposition circuit 110 considers only neighboring luminance blocks for transposition. Similarly, for blocks of each of the two chrominance signals, pixel transposition is performed only with neighboring chrominance image blocks of the same type.
FIG. 2(b) illustrates an example where pixel transposition is performed on a macro block by macro block basis. In the event that the quantizer circuit 130 computes quantization parameters for each macro block rather than for each block, it is preferable to perform a pixel transposition on a macro block by macro block basis. In this example, a macro block consists of four blocks of image information, Blocks A-D. The macro block is surrounded by twelve neighboring blocks, Blocks 1-12. For the macro block, pixel transposition is performed on alternate pixels on the boundary of the macro block with pixel information of neighboring macro blocks along a pre-determined direction. In this example, the predetermined direction is from low-left to high-right and vice versa. As shown in FIG. 2(b), the pixel in the upper right-hand corner of Block B is transposed with a pixel in the lower left-hand corner of Block 4. Similarly, a pixel in a lower left-hand corner of Block C is transposed with a pixel in the upper right-hand corner of Block 10. Alternate pixels on the top edge of the macro block, the top edges of Blocks A and B, are transposed with pixels on the bottom edges of Blocks 2 and 3 in a diagonal direction. Pixels on the right-hand edge of the macro block, the right-hand edges of Blocks B and D, are transformed on the left-hand edges of Blocks 5 and 6 in the diagonal direction. Blocks on the lower edge of the macro block, the lower edges of Blocks C and D, are transposed with pixels found in the diagonal direction on the upper edges of Blocks 8 and 9. Finally, pixels found on the left-hand edge of the macro block, the left-hand edges of Blocks A and C, are transposed with pixels found in a diagonal direction in the right-hand edges of Blocks 11 and 12.
The direction of transposition is arbitrary. Any direction may be applied. In addition to high-left to low-right and low-left to high-right, horizontal (right to left) and vertical (above to below) directions may be applied. The direction may be predetermined by the system or defined for each coded video frame. If the direction of transposition is variable, the pixel transposition circuit 110 includes a transposition keyword in the output bitstream identifying the direction of transposition. The decoder identifies the transposition keyword and identifies a direction of transposition therefrom.
So, too, the pattern of transposition may varied. In addition to selection of alternate pixels for transposition, every third or every fourth pixel may be selected for transposition. Further, the pattern may varied so as to select pixels at a first rate, such as every other pixel, in a first region of data, then a second rate, such as every fourth pixel, in a second region of data.
The encoder 100 and decoder 200 shown in FIGS. 1(a) and 1(b) are not full video coders. Preprocessing is generally performed on pixels before they are input to the pixel transposition circuit 110, which generally involves sampling of image data, conversion to a digital format, filtering, and component isolation. Preprocessing also includes organization of the component signals into blocks. However, in a preferred embodiment, preprocessing functions may be merged into the pixel transposition circuit 110. In this case, the pixel transposition circuit may be programmed to reorder pixels before they are organized into blocks.

Claims (80)

1. A video coder, comprising:
a pixel transposition circuit that receives blocks of image data, each block including image data of an array of pixels, said pixel transposition circuit transposing selected pixels on a boundary of a first block with selected boundary pixels of a plurality of blocks neighboring said first block,
a transform circuit that generates coefficients representative of data of the transposed blocks, and
a quantizer that scales the coefficients.
2. The video coder of claim 1, wherein the pixel transposition circuit transposes alternate pixels along the boundary of said first block with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
3. The video coder of claim 2 wherein the transposition direction is a diagonal direction, high-left to low-right.
4. The video coder of claim 2 wherein the transposition direction is a diagonal direction, low-left to high-right.
5. The video coder of claim 2, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block and a horizontal direction for pixels along a horizontal edge of the first block.
6. A video decoder, comprising:
a dequantizer that receives blocks of scaled coefficient information and reconstructing coefficients therefrom,
an inverse transform circuit that reconstructs blocks of pixel data from the blocks of reconstructed coefficients, and
a pixel transposition circuit that transposes pixels on a boundary of a first block with boundary pixels of a plurality of blocks neighboring said first block and generating blocks of image data for display.
7. The video decoder of claim 6, wherein the pixel transposition circuit transposes alternate pixels along the boundary of the first block with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
8. The video decoder of claim 7, wherein the transposition direction is a diagonal direction, high-left to low-right.
9. The video decoder of claim 7, wherein the transposition direction is a diagonal direction, low-left to high-right.
10. The video decoder of claim 7, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block and a horizontal direction for pixels along a horizontal edge of the first block.
11. A method of encoding image data, comprising the steps of:
receiving blocks of image data, each block including data for an array of pixels,
transposing selected pixels on a boundary edge of a first block with selected pixels from a plurality of blocks neighboring said first block,
transforming pixel data of the blocks from the step transposing to coefficients, and
scaling the transformed blocks.
12. The method of claim 11, wherein the transposition step includes transposing alternate pixels along the boundary of the first block with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
13. The method of claim 12, further comprising a step of generating a transposition keyword representative of the transposition direction.
14. The method of claim 12, wherein the transposition direction is a diagonal direction, high-left to low-right.
15. The method of claim 12, wherein the transposition direction is a diagonal direction, low-left to high-right.
16. The method of claim 12, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block and a horizontal direction for pixels along a horizontal edge of the first block.
17. A method of decoding blocks of encoded image data, comprising the steps of:
scaling the coded blocks to obtain blocks of coefficient data,
transforming the coefficient data of the blocks to pixel data, and
transposing selected pixels on a boundary edge of a first block with selected pixels from a plurality of blocks neighboring said first block.
18. The method of claim 17, wherein the transposition step transposes alternate pixels along the boundary of the first block with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
19. The method of claim 18, further comprising a step of receiving a transposition keyword that identifies a transposition direction.
20. The method of claim 18, wherein the transposition direction is a diagonal direction, high-left to low-right.
21. The method of claim 18, wherein the transposition direction is a diagonal direction, low-left to high-right.
22. The method of claim 18, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block and a horizontal direction for pixels along a horizontal edge of the first block.
23. A bitstream generated by a process comprising the steps of:
receiving blocks of image data, each block including data for an array of pixels,
transposing selected pixels on a boundary edge of a first block with selected pixels from blocks neighboring the first block,
transforming pixel data of the transposed blocks to coefficients, and
scaling the transformed blocks.
24. The method of claim 23, wherein the transposition step includes a step of transposing alternate pixels along the boundary of the first block with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
25. The method of claim 24, further comprising a step of generating a transposition keyword representative of the transposition direction.
26. The method of claim 24, wherein the transposition direction is a diagonal direction, high-left to low-right.
27. The method of claim 24, wherein the transposition direction is a diagonal direction, low-left to high-right.
28. The method of claim 24, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block and a horizontal direction for pixels along a horizontal edge of the first block.
29. A method of encoding image data, comprising the steps of:
receiving blocks of image data, each block including an array of pixels;
converting each block of image data into blocks of luminance pixel data and chrominance pixel data;
transposing selected pixel data of adjacent luminance blocks;
transposing selected pixel data of adjacent chrominance blocks;
transforming pixel data of the transposed luminance blocks to luminance coefficients;
transforming pixel data of the transposed chrominance blocks to chrominance coefficients; and
scaling the transformed luminance coefficients and the transformed chrominance coefficients.
30. The method of claim 29, wherein the luminance transposition step includes transposing alternate pixels along a boundary of a first luminance block with pixels from neighboring luminance blocks adjacent to the alternate pixels in a transposition direction.
31. The method of claim 30, further comprising a step of generating a luminance transposition keyword representative of the transposition direction and transmitting the scaled luminance coefficient and the transposition keyword to a channel.
32. The method of claim 30, wherein the transposition direction is a diagonal direction, high-left to low-right.
33. The method of claim 30, wherein the transposition direction is a diagonal direction, low-left to high-right.
34. The method of claim 29, wherein the transposition direction is a vertical direction for pixels along vertical edges of the luminance blocks and a horizontal direction for pixels along horizontal edges of the luminance blocks.
35. The method of claim 29, wherein the chrominance transposition step includes transposing alternate pixels along a boundary of a first chrominance block with pixels from neighboring chrominance blocks adjacent to the alternate pixels in a transposition direction.
36. The method of claim 35, further comprising a step of generating a chrominance transposition keyword representative of the transposition direction and transmitting the scaled chrominance coefficient and the transposition keyword to a channel.
37. The method of claim 35, wherein the transposition direction is a diagonal direction, high-left to low-right.
38. The method of claim 35, wherein the transposition direction is a diagonal direction, low-left to high-right.
39. The method of claim 35, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first chrominance block and a horizontal direction for pixels along a horizontal edge of the first chrominance block.
40. A method of decoding blocks of encoded luminance and chrominance data, comprising:
scaling blocks of encoded luminance data to obtain blocks of coefficient luminance data;
scaling blocks of encoded chrominance data to obtain blocks of coefficient chrominance data;
transforming the blocks of coefficient luminance data to blocks of luminance data;
transforming the blocks of coefficient chrominance data to blocks of chrominance data;
transposing selected alternate pixels of adjacent luminance blocks;
transposing selected alternate pixels of adjacent chrominance blocks; and
converting luminance blocks and chrominance blocks obtained from the transposings into blocks of image data.
41. The method of claim 40, wherein the converting comprises transform decoding.
42. The method of claim 40, wherein the luminance transposition step transposes alternate pixels along a boundary of a first luminance block with pixels from neighboring luminance blocks adjacent to the alternate pixels in a transposition direction.
43. The method of claim 42, further comprising a step of receiving a transposition keyword that identifies the transposition direction, the transposing occurring according to the identified transposition direction.
44. The method of claim 42, wherein the transposition direction is a diagonal direction, high-left to low-right.
45. The method of claim 42, wherein the transposition direction is a diagonal direction, low-left to high-right.
46. The method of claim 42, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first luminance block and a horizontal direction for pixels along a horizontal edge of the first luminance block.
47. The method of claim 40, wherein the chrominance transposition step transposes alternate pixels along a boundary of a first chrominance block with pixels from neighboring chrominance blocks adjacent to the alternate pixels in a transposition direction.
48. The method of claim 47, further comprising a step of receiving a transposition keyword that identifies a transposition direction.
49. The method of claim 47, wherein the transposition direction is a diagonal direction, high-left to low-right.
50. The method of claim 47, wherein the transposition direction is a diagonal direction, low-left to high-right.
51. The method of claim 47, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first chrominance block and a horizontal direction for pixels along a horizontal edge of the first chrominance block.
52. A video coder, comprising:
an image block conversion circuit that receives blocks of image data, each block including image data of an array of pixels, said image block conversion circuit converting the received blocks of image data into luminance blocks and chrominance blocks;
a pixel transposition circuit that transposes selected pixels of adjacent luminance blocks and transposes selected pixels of adjacent chrominance blocks;
a transform circuit that generates luminance coefficients representative of data of the transposed luminance blocks, and generates chrominance coefficients representative of data of the transposed chrominance blocks; and
a quantizer that scales the luminance coefficients and the chrominance coefficients.
53. The video coder of claim 52, wherein the pixel transposition circuit transposes alternate pixels along a boundary of a first luminance block with pixels from neighboring luminance blocks adjacent to the alternate pixels in a transposition direction.
54. The video coder of claim 53 wherein the transposition direction is a diagonal direction, high-left to low-right.
55. The video coder of claim 53 wherein the transposition direction is a diagonal direction, low-left to high-right.
56. The video coder of claim 53, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first luminance block and a horizontal direction for pixels along a horizontal edge of the first luminance block.
57. The video coder of claim 52, wherein the pixel transposition circuit transposes alternate pixels along a boundary of a first chrominance block with pixels from neighboring chrominance blocks adjacent to the alternate pixels in a transposition direction.
58. The video coder of claim 57 wherein the transposition direction is a diagonal direction, high-left to low-right.
59. The video coder of claim 57 wherein the transposition direction is a diagonal direction, low-left to high-right.
60. The video coder of claim 57, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first chrominance block and a horizontal direction for pixels along a horizontal edge of the first chrominance block.
61. A video decoder, comprising:
a dequantizer that receives blocks of scaled luminance coefficient information and reconstructs luminance coefficients therefrom, and also receives blocks of scaled chrominance coefficient information and reconstructs chrominance coefficients therefrom;
an inverse transform circuit that reconstructs blocks of luminance pixel data from the blocks of reconstructed luminance coefficients, and also reconstructs blocks of chrominance pixel data from the blocks of reconstructed chrominance coefficients;
a pixel transposition circuit that generates blocks of luminance image data by transposing pixels on a boundary of a first block of luminance pixel data with boundary pixels of a plurality of blocks of luminance pixel data neighboring said first block of luminance pixel data, and also generates blocks of chrominance image data by transposing pixels on a boundary of a first block of chrominance pixel data with boundary pixels of a plurality of blocks of chrominance pixel data neighboring said first block of chrominance pixel data; and
an image block conversion circuit that generates blocks of image data from blocks of luminance image data and blocks of chrominance image data.
62. The video decoder of claim 61, wherein the pixel transposition circuit transposes alternate pixels along a boundary of the first block of luminance pixel data with pixels from the neighboring blocks of luminance pixel data adjacent to the alternate pixels in a transposition direction.
63. The video decoder of claim 62, wherein the transposition direction is a diagonal direction, high-left to low-right.
64. The video decoder of claim 62, wherein the transposition direction is a diagonal direction, low-left to high-right.
65. The video decoder of claim 62, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block of luminance pixel data and a horizontal direction for pixels along a horizontal edge of the first block of luminance pixel data.
66. The video decoder of claim 61, wherein the pixel transposition circuit transposes alternate pixels along a boundary of the first block of chrominance pixel data with pixels from the neighboring blocks of chrominance pixel data adjacent to the alternate pixels in a transposition direction.
67. The video decoder of claim 66, wherein the transposition direction is a diagonal direction, high-left to low-right.
68. The video decoder of claim 66, wherein the transposition direction is a diagonal direction, low-left to high-right.
69. The video decoder of claim 66, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block of chrominance pixel data and a horizontal direction for pixels along a horizontal edge of the first block of chrominance pixel data.
70. A bitstream generated by a process comprising the steps of:
receiving blocks of image data, each block including an array of pixels;
converting each block of image data into blocks of luminance pixel data and chrominance pixel data;
transposing selected pixels on a boundary edge of a first block of luminance pixel data with selected pixels from blocks neighboring the first block of luminance pixel data;
transposing selected pixels on a boundary edge of a first block of chrominance pixel data with selected pixels from blocks neighboring the first block of chrominance pixel data;
transforming pixel data of the transposed luminance blocks to luminance coefficients;
transforming pixel data of the transposed chrominance blocks to chrominance coefficients; and
scaling the transformed luminance coefficients and the transformed chrominance coefficients.
71. The bitstream of claim 70, wherein the luminance transposition step includes transposing alternate pixels along a boundary of the first block of luminance pixel data with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
72. The bitstream of claim 71, further comprising a step of generating a transposition keyword representative of the transposition direction and transmitting the scaled luminance coefficient and the transposition keyword to a channel.
73. The bitstream of claim 71, wherein the transposition direction is a diagonal direction, high-left to low-right.
74. The bitstream of claim 71, wherein the transposition direction is a diagonal direction, low-left to high-right.
75. The bitstream of claim 71, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block of luminance pixel data and a horizontal direction for pixels along a horizontal edge of the first block of luminance pixel data.
76. The bitstream of claim 70, wherein the chrominance transposition step includes transposing alternate pixels along a boundary of the first block of chrominance pixel data with pixels from the neighboring blocks adjacent to the alternate pixels in a transposition direction.
77. The bitstream of claim 76, further comprising a step of generating a transposition keyword representative of the transposition direction and transmitting the scaled chrominance coefficient and the transposition keyword to a channel.
78. The bitstream of claim 76, wherein the transposition direction is a diagonal direction, high-left to low-right.
79. The bitstream of claim 76, wherein the transposition direction is a diagonal direction, low-left to high-right.
80. The bitstream of claim 76, wherein the transposition direction is a vertical direction for pixels along a vertical edge of the first block of chrominance pixel data and a horizontal direction for pixels along a horizontal edge of the first block of chrominance pixel data.
US10/124,385 1997-02-14 2002-04-18 Video coder employing pixel transportation Expired - Lifetime USRE41095E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/124,385 USRE41095E1 (en) 1997-02-14 2002-04-18 Video coder employing pixel transportation

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US3801797P 1997-02-14 1997-02-14
US08/948,780 US6052490A (en) 1997-02-14 1997-10-10 Video coder employing pixel transposition
US10/124,385 USRE41095E1 (en) 1997-02-14 2002-04-18 Video coder employing pixel transportation

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US08/948,780 Reissue US6052490A (en) 1997-02-14 1997-10-10 Video coder employing pixel transposition

Publications (1)

Publication Number Publication Date
USRE41095E1 true USRE41095E1 (en) 2010-02-02

Family

ID=26714716

Family Applications (5)

Application Number Title Priority Date Filing Date
US08/948,780 Ceased US6052490A (en) 1997-02-14 1997-10-10 Video coder employing pixel transposition
US09/482,019 Expired - Fee Related US6721460B1 (en) 1997-02-14 2000-01-13 Video coder employing pixel transposition
US10/124,385 Expired - Lifetime USRE41095E1 (en) 1997-02-14 2002-04-18 Video coder employing pixel transportation
US11/274,495 Expired - Fee Related US7864867B2 (en) 1997-02-14 2005-11-15 Video coder employing pixel transposition
US12/951,005 Expired - Fee Related US8165222B2 (en) 1997-02-14 2010-11-20 Video coder employing pixel transposition

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US08/948,780 Ceased US6052490A (en) 1997-02-14 1997-10-10 Video coder employing pixel transposition
US09/482,019 Expired - Fee Related US6721460B1 (en) 1997-02-14 2000-01-13 Video coder employing pixel transposition

Family Applications After (2)

Application Number Title Priority Date Filing Date
US11/274,495 Expired - Fee Related US7864867B2 (en) 1997-02-14 2005-11-15 Video coder employing pixel transposition
US12/951,005 Expired - Fee Related US8165222B2 (en) 1997-02-14 2010-11-20 Video coder employing pixel transposition

Country Status (4)

Country Link
US (5) US6052490A (en)
EP (1) EP0859517A3 (en)
CA (1) CA2227495C (en)
MX (1) MX9801191A (en)

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7010173B2 (en) * 2000-01-13 2006-03-07 At&T Corp. Video coder employing pixel transposition
US6052490A (en) * 1997-02-14 2000-04-18 At&T Corp. Video coder employing pixel transposition
US7239755B1 (en) 1997-07-30 2007-07-03 Lg Electronics Inc. Method of reducing a blocking artifact when coding moving picture
KR100244290B1 (en) 1997-09-09 2000-02-01 구자홍 Method for deblocking filtering for low bit rate video
US6614437B1 (en) * 1999-01-25 2003-09-02 Sony Corporation Apparatus and method for efficient memory utilization in an electronic system
US6823087B1 (en) * 2001-05-15 2004-11-23 Advanced Micro Devices, Inc. Parallel edge filters in video codec
GB2378072B (en) * 2001-07-24 2003-10-15 Motorola Inc Image and video coding arrangement and method
US7123655B2 (en) * 2001-08-09 2006-10-17 Sharp Laboratories Of America, Inc. Method for reduced bit-depth quantization
JP4594688B2 (en) * 2004-06-29 2010-12-08 オリンパス株式会社 Image encoding processing method, image decoding processing method, moving image compression processing method, moving image expansion processing method, image encoding processing program, image encoding device, image decoding device, image encoding / decoding system, extended image compression / decompression Processing system
CN100571389C (en) * 2004-06-29 2009-12-16 奥林巴斯株式会社 Be used for the compressed and decompressed method and apparatus of encoding/decoding image and expanded images
US8688671B2 (en) 2005-09-14 2014-04-01 Millennial Media Managing sponsored content based on geographic region
US10592930B2 (en) 2005-09-14 2020-03-17 Millenial Media, LLC Syndication of a behavioral profile using a monetization platform
US7676394B2 (en) 2005-09-14 2010-03-09 Jumptap, Inc. Dynamic bidding and expected value
US8433297B2 (en) 2005-11-05 2013-04-30 Jumptag, Inc. System for targeting advertising content to a plurality of mobile communication facilities
US7702318B2 (en) 2005-09-14 2010-04-20 Jumptap, Inc. Presentation of sponsored content based on mobile transaction event
US9703892B2 (en) 2005-09-14 2017-07-11 Millennial Media Llc Predictive text completion for a mobile communication facility
US10038756B2 (en) 2005-09-14 2018-07-31 Millenial Media LLC Managing sponsored content based on device characteristics
US10911894B2 (en) 2005-09-14 2021-02-02 Verizon Media Inc. Use of dynamic content generation parameters based on previous performance of those parameters
US20110313853A1 (en) 2005-09-14 2011-12-22 Jorey Ramer System for targeting advertising content to a plurality of mobile communication facilities
FR2899744A1 (en) * 2006-04-07 2007-10-12 France Telecom METHOD AND DEVICE FOR ENCODING AND DECODING AN IMAGE, IN PARTICULAR A SEQUENCE OF VIDEO IMAGES, CORRESPONDING SIGNAL AND COMPUTER PROGRAM PRODUCT
KR100843100B1 (en) * 2007-02-07 2008-07-03 삼성전자주식회사 Method and apparatus for reducing block noises of digital image, and encoder/decoder using the same
WO2011047034A2 (en) * 2009-10-13 2011-04-21 Square, Inc. Systems and methods for decoding card swipe signals
GB2491688B (en) 2011-05-05 2014-08-27 Advanced Risc Mach Ltd Method of and apparatus for encoding and decoding data
US9177415B2 (en) 2013-01-30 2015-11-03 Arm Limited Methods of and apparatus for encoding and decoding data

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5367385A (en) * 1992-05-07 1994-11-22 Picturetel Corporation Method and apparatus for processing block coded image data to reduce boundary artifacts between adjacent image blocks
US5454051A (en) 1991-08-05 1995-09-26 Eastman Kodak Company Method of reducing block artifacts created by block transform compression algorithms
US5619591A (en) 1995-08-23 1997-04-08 Vtech Electronics, Ltd. Encoding and decoding color image data based on mean luminance and an upper and a lower color value
US5757969A (en) * 1995-02-28 1998-05-26 Daewoo Electronics, Co., Ltd. Method for removing a blocking effect for use in a video signal decoding apparatus
US5764805A (en) 1995-10-25 1998-06-09 David Sarnoff Research Center, Inc. Low bit rate video encoder using overlapping block motion compensation and zerotree wavelet coding
US5818532A (en) 1996-05-03 1998-10-06 Lsi Logic Corporation Micro architecture of video core for MPEG-2 decoder
US5850294A (en) 1995-12-18 1998-12-15 Lucent Technologies Inc. Method and apparatus for post-processing images
US5852682A (en) * 1995-02-28 1998-12-22 Daewoo Electronics, Co., Ltd. Post-processing method and apparatus for use in a video signal decoding apparatus
US5881180A (en) 1996-02-08 1999-03-09 Sony Corporation Method and apparatus for the reduction of blocking effects in images

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4754492A (en) * 1985-06-03 1988-06-28 Picturetel Corporation Method and system for adapting a digitized signal processing system for block processing with minimal blocking artifacts
GB9204360D0 (en) * 1992-02-28 1992-04-08 Monro Donald M Fractal coding of data
US5696851A (en) * 1993-04-30 1997-12-09 Comsat Corporation Codeword-dependent post-filtering for vector quantization-based image compression
WO1995029541A1 (en) * 1994-04-22 1995-11-02 Thomson Consumer Electronics, Inc. Complexity determining apparatus
JPH08116448A (en) * 1994-10-13 1996-05-07 Fuji Xerox Co Ltd Coder and decoder for image signal
US6052490A (en) * 1997-02-14 2000-04-18 At&T Corp. Video coder employing pixel transposition

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5454051A (en) 1991-08-05 1995-09-26 Eastman Kodak Company Method of reducing block artifacts created by block transform compression algorithms
US5367385A (en) * 1992-05-07 1994-11-22 Picturetel Corporation Method and apparatus for processing block coded image data to reduce boundary artifacts between adjacent image blocks
US5757969A (en) * 1995-02-28 1998-05-26 Daewoo Electronics, Co., Ltd. Method for removing a blocking effect for use in a video signal decoding apparatus
US5852682A (en) * 1995-02-28 1998-12-22 Daewoo Electronics, Co., Ltd. Post-processing method and apparatus for use in a video signal decoding apparatus
US5619591A (en) 1995-08-23 1997-04-08 Vtech Electronics, Ltd. Encoding and decoding color image data based on mean luminance and an upper and a lower color value
US5764805A (en) 1995-10-25 1998-06-09 David Sarnoff Research Center, Inc. Low bit rate video encoder using overlapping block motion compensation and zerotree wavelet coding
US5850294A (en) 1995-12-18 1998-12-15 Lucent Technologies Inc. Method and apparatus for post-processing images
US5881180A (en) 1996-02-08 1999-03-09 Sony Corporation Method and apparatus for the reduction of blocking effects in images
US5818532A (en) 1996-05-03 1998-10-06 Lsi Logic Corporation Micro architecture of video core for MPEG-2 decoder

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
International Organization for Standardisation: MPEG-4 Video Verification Model Version 2.1; ISO/IEC JTC1/SC29/WG11 XXXX of May 3, 1996.
International Organization for Standardisation; Generic Coding of Moving Pictures and Associated Audio Information: Video; Recommendation H.262; ISO/IEC 13818-2 JTC1/SC29/WG11 N0702 (revised) Incorporating N702 Delta of Mar. 24 and Further Editional Corrections May 10, 1994.
International Organization for Standardisation; Working Draft 4.0 of ISO/IEC 14496-2; ISO/IEC JTC1/SC29/WG11 N1797; MPEG97/Stockholm, Jul. 1997.

Also Published As

Publication number Publication date
US20110064139A1 (en) 2011-03-17
MX9801191A (en) 1998-11-30
CA2227495A1 (en) 1998-08-14
US20060062310A1 (en) 2006-03-23
EP0859517A3 (en) 2001-02-28
US7864867B2 (en) 2011-01-04
CA2227495C (en) 2001-07-31
EP0859517A2 (en) 1998-08-19
US6721460B1 (en) 2004-04-13
US6052490A (en) 2000-04-18
US8165222B2 (en) 2012-04-24

Similar Documents

Publication Publication Date Title
US8165222B2 (en) Video coder employing pixel transposition
US6501793B2 (en) Quantization matrix for still and moving picture coding
KR100788220B1 (en) Quality based image compression
EP1230804B1 (en) Variance based adaptive block size dct image compression
US5844614A (en) Video signal decoding apparatus
EP0635985B1 (en) Improved decompression standard for ADCT-compressed document images
EP2285117B1 (en) Video coder providing implicit coefficient prediction and scan adaption for image coding and intra coding of video
EP2157799A1 (en) Interpolation filter with local adaptation based on block edges in the reference frame
EP0479510A2 (en) Image signal coding/decoding system using adaptive quantization
US6665343B1 (en) Methods and arrangements for a converting a high definition image to a lower definition image using wavelet transforms
EP0577350A2 (en) A video signal coding and decoding apparatus with an adaptive edge enhancement filter
US6865229B1 (en) Method and apparatus for reducing the “blocky picture” effect in MPEG decoded images
EP0346637B1 (en) Method for processing and transmitting a picture sequence
EP1134983B1 (en) Method and apparatus for encoding and decoding images
US7010173B2 (en) Video coder employing pixel transposition
EP1691560B1 (en) Video coder providing implicit coefficient prediction for image coding and intra coding of video
JP2901656B2 (en) Image coding device
Westen et al. Adaptive spatial noise shaping for DCT based image compression
JP2004266794A (en) Multi-resolution video coding and decoding
JP3211989B2 (en) Orthogonal transform encoding device and decoding device
JPH0497678A (en) Picture decoding system
JPH09289642A (en) Video signal coding method, video signal decoding method and device therefor
JP3204286B2 (en) Image decoding method and apparatus
JP2891251B2 (en) Image encoding device and image decoding device
JPH07154788A (en) Encoder for video signal

Legal Events

Date Code Title Description
CC Certificate of correction
FPAY Fee payment

Year of fee payment: 12