US20040150747A1 - HDTV downconversion system - Google Patents
HDTV downconversion system Download PDFInfo
- Publication number
- US20040150747A1 US20040150747A1 US10/672,773 US67277303A US2004150747A1 US 20040150747 A1 US20040150747 A1 US 20040150747A1 US 67277303 A US67277303 A US 67277303A US 2004150747 A1 US2004150747 A1 US 2004150747A1
- Authority
- US
- United States
- Prior art keywords
- display
- display device
- video
- pixel
- filter
- 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.)
- Abandoned
Links
- 238000000034 method Methods 0.000 claims description 67
- 238000006243 chemical reaction Methods 0.000 description 56
- 238000012545 processing Methods 0.000 description 51
- 230000008569 process Effects 0.000 description 41
- 238000001914 filtration Methods 0.000 description 37
- 238000010586 diagram Methods 0.000 description 30
- 239000013598 vector Substances 0.000 description 25
- 238000005070 sampling Methods 0.000 description 21
- 230000000750 progressive effect Effects 0.000 description 17
- 238000012952 Resampling Methods 0.000 description 16
- 239000011159 matrix material Substances 0.000 description 14
- 230000000295 complement effect Effects 0.000 description 10
- 238000013507 mapping Methods 0.000 description 8
- 238000005192 partition Methods 0.000 description 6
- 238000007792 addition Methods 0.000 description 5
- 230000008901 benefit Effects 0.000 description 5
- 230000008859 change Effects 0.000 description 4
- 230000000694 effects Effects 0.000 description 4
- 230000009977 dual effect Effects 0.000 description 3
- 230000005236 sound signal Effects 0.000 description 3
- 238000013519 translation Methods 0.000 description 3
- 239000002131 composite material Substances 0.000 description 2
- 239000013256 coordination polymer Substances 0.000 description 2
- 230000007423 decrease Effects 0.000 description 2
- 238000009795 derivation Methods 0.000 description 2
- 238000003780 insertion Methods 0.000 description 2
- 230000037431 insertion Effects 0.000 description 2
- 230000000737 periodic effect Effects 0.000 description 2
- 238000013139 quantization Methods 0.000 description 2
- 230000009467 reduction Effects 0.000 description 2
- 230000009466 transformation Effects 0.000 description 2
- 230000007704 transition Effects 0.000 description 2
- DNTFEAHNXKUSKQ-RFZPGFLSSA-N (1r,2r)-2-aminocyclopentane-1-sulfonic acid Chemical compound N[C@@H]1CCC[C@H]1S(O)(=O)=O DNTFEAHNXKUSKQ-RFZPGFLSSA-N 0.000 description 1
- NAPPWIFDUAHTRY-XYDRQXHOSA-N (8r,9s,10r,13s,14s,17r)-17-ethynyl-17-hydroxy-13-methyl-1,2,6,7,8,9,10,11,12,14,15,16-dodecahydrocyclopenta[a]phenanthren-3-one;(8r,9s,13s,14s,17r)-17-ethynyl-13-methyl-7,8,9,11,12,14,15,16-octahydro-6h-cyclopenta[a]phenanthrene-3,17-diol Chemical compound O=C1CC[C@@H]2[C@H]3CC[C@](C)([C@](CC4)(O)C#C)[C@@H]4[C@@H]3CCC2=C1.OC1=CC=C2[C@H]3CC[C@](C)([C@](CC4)(O)C#C)[C@@H]4[C@@H]3CCC2=C1 NAPPWIFDUAHTRY-XYDRQXHOSA-N 0.000 description 1
- 238000012935 Averaging Methods 0.000 description 1
- 102100031456 Centriolin Human genes 0.000 description 1
- 101000822695 Clostridium perfringens (strain 13 / Type A) Small, acid-soluble spore protein C1 Proteins 0.000 description 1
- 101000655262 Clostridium perfringens (strain 13 / Type A) Small, acid-soluble spore protein C2 Proteins 0.000 description 1
- 208000037170 Delayed Emergence from Anesthesia Diseases 0.000 description 1
- 238000003775 Density Functional Theory Methods 0.000 description 1
- 101000941711 Homo sapiens Centriolin Proteins 0.000 description 1
- 101000655256 Paraclostridium bifermentans Small, acid-soluble spore protein alpha Proteins 0.000 description 1
- 101000655264 Paraclostridium bifermentans Small, acid-soluble spore protein beta Proteins 0.000 description 1
- 230000006978 adaptation Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 230000006835 compression Effects 0.000 description 1
- 238000007906 compression Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000006073 displacement reaction Methods 0.000 description 1
- 238000007429 general method Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000002156 mixing Methods 0.000 description 1
- 239000000203 mixture Substances 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000003825 pressing Methods 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000026676 system process Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/015—High-definition television systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/60—Memory management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T3/00—Geometric image transformations in the plane of the image
- G06T3/40—Scaling of whole images or parts thereof, e.g. expanding or contracting
- G06T3/4084—Scaling of whole images or parts thereof, e.g. expanding or contracting in the transform domain, e.g. fast Fourier transform [FFT] domain scaling
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/132—Sampling, masking or truncation of coding units, e.g. adaptive resampling, frame skipping, frame interpolation or high-frequency transform coefficient masking
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/162—User input
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/18—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being a set of transform coefficients
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/186—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being a colour or a chrominance component
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/423—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation characterised by memory arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/423—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation characterised by memory arrangements
- H04N19/426—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation characterised by memory arrangements using memory downsizing methods
- H04N19/428—Recompression, e.g. by spatial or temporal decimation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/44—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/46—Embedding additional information in the video signal during the compression process
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/523—Motion estimation or motion compensation with sub-pixel accuracy
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/59—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/60—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
- H04N19/61—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/80—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/80—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
- H04N19/82—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation involving filtering within a prediction loop
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/85—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/85—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
- H04N19/86—Methods 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/41—Structure of client; Structure of client peripherals
- H04N21/426—Internal components of the client ; Characteristics thereof
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/44—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
- H04N21/4402—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
- H04N21/440263—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display by altering the spatial resolution, e.g. for displaying on a connected PDA
- H04N21/440272—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display by altering the spatial resolution, e.g. for displaying on a connected PDA for performing aspect ratio conversion
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/45—Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
- H04N21/462—Content or additional data management, e.g. creating a master electronic program guide from data received from the Internet and a Head-end, controlling the complexity of a video stream by scaling the resolution or bit-rate based on the client capabilities
- H04N21/4621—Controlling the complexity of the content stream or additional data, e.g. lowering the resolution or bit-rate of the video stream for a mobile client with a small screen
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/44—Receiver circuitry for the reception of television signals according to analogue transmission standards
- H04N5/46—Receiver circuitry for the reception of television signals according to analogue transmission standards for receiving on more than one standard at will
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/01—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level
- H04N7/0125—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level one of the standards being a high definition standard
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/01—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level
- H04N7/0135—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving interpolation processes
- H04N7/014—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving interpolation processes involving the use of motion vectors
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/01—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level
- H04N7/0117—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving conversion of the spatial resolution of the incoming video signal
- H04N7/0122—Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving conversion of the spatial resolution of the incoming video signal the input and the output signals having different aspect ratios
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/64—Circuits for processing colour signals
Definitions
- This invention relates to a decoder for receiving, decoding and conversion of frequency domain encoded signals, e.g. MPEG-2 encoded video signals, into standard output video signals, and more specifically to a decoder which converts and formats an encoded high resolution video signal to a decoded lower resolution output video signal.
- frequency domain encoded signals e.g. MPEG-2 encoded video signals
- the Advanced Television System Committee (ATSC) standard defines digital encoding of high definition television (HDTV) signals.
- a portion of this standard is essentially the same as the MPEG-2 standard, proposed by the Moving Picture Experts Group (MPEG) of the International Organization for Standardization (ISO).
- MPEG Moving Picture Experts Group
- ISO International Organization for Standardization
- ISO International Standard
- the MPEG-2 standard is actually several different standards.
- MPEG-2 several different profiles are defined, each corresponding to a different level of complexity of the encoded image.
- different levels are defined, each level corresponding to a different image resolution.
- One of the MPEG-2 standards known as Main Profile, Main Level is intended for coding video signals conforming to existing television standards (i.e., NTSC and PAL).
- Another standard known as Main Profile, High Level is intended for coding high-definition television images. Images encoded according to the Main Profile, High Level standard may have as many as 1,152 active lines per image frame and 1,920 pixels per line.
- the Main Profile, Main Level standard defines a maximum picture size of 720 pixels per line and 567 lines per frame. At a frame rate of 30 frames per second, signals encoded according to this standard have a data rate of 720 *567*30 or 12,247,200 pixels per second. By contrast, images encoded according to the Main Profile, High Level standard have a maximum data rate of 1,152*1,920*30 or 66,355,200 pixels per second. This data rate is more than five times the data rate of image data encoded according to the Main Profile Main Level standard.
- the standard for HDTV encoding in the United States is a subset of this standard, having as many as 1,080 lines per frame, 1,920 pixels per line and a maximum frame rate, for this frame size, of 30 frames per second.
- the maximum data rate for this standard is still far greater than the maximum data rate for the Main Profile, Main Level standard.
- the MPEG-2 standard defines a complex syntax which contains a mixture of data and control information. Some of this control information is used to enable signals having several different formats to be covered by the standard. These formats define images having differing numbers of picture elements (pixels) per line, differing numbers of lines per frame or field and differing numbers of frames or fields per second.
- the basic syntax of the MPEG-2 Main Profile defines the compressed MPEG-2 bit stream representing a sequence of images in five layers, the sequence layer, the group of pictures layer, the picture layer, the slice layer, and the macroblock layer. Each of these layers is introduced with control information.
- other control information also known as side information, (e.g. frame type, macroblock pattern, image motion vectors, coefficient zig-zag patterns and dequantization information) are interspersed throughout the coded bit stream.
- conversion allows replacement of expensive high definition monitors used with Main Profile, High Level encoded pictures with inexpensive existing monitors which have a lower picture resolution to support, for example, Main Profile, Main Level encoded pictures, such as NTSC or 525 progressive monitors.
- One aspect, down conversion converts a high definition input picture into lower resolution picture for display on the lower resolution monitor.
- a decoder should process the video signal information rapidly.
- the decoding systems should be relatively inexpensive and yet have sufficient power to decode these digital signals in real time. Consequently, a decoder which supports conversion into multiple low resolution formats must minimize processor memory.
- the present invention is embodied in a digital video signal processing system which receives, decodes and displays video signals that have been encoded in a plurality of different formats.
- the system includes a digital video decoder which may be controlled to decode the encoded video signal and, optionally, provide a reduced resolution version of the decoded video signal.
- the system processes the received encoded video signal to determine the format and resolution of the image which would be produced if the signal were decoded.
- the system includes a controller which receives the determined format and resolution information and which also receives information concerning the format and resolution of a display device on which the received image will be displayed. The controller then generates signals to cause the digital video decoder to provide an analog video signal having a resolution and aspect ratio that is appropriate for the display device.
- the encoded video signals are encoded using a frequency-domain transform operation and the digital video decoder includes a low-pass filter which operates on the frequency-domain transformed digital video signal.
- digital video decoder is coupled to a programmable spatial filter which is responsive to a control signal provided by the controller to resample the decoded digital video signal provided by the digital video decoder to produce a digital video signal which conforms to the aspect ratio and resolution of the display device.
- the digital video signal is encoded according to using an encoding technique specified by the moving pictures experts group (MPEG) and the aspect ratio and resolution of the encoded video signal are extracted from the header of a packetized elementary stream (PES) packet received by the digital video decoder.
- MPEG moving pictures experts group
- PES packetized elementary stream
- the digital video signal is encoded according to using an encoding technique specified by the moving pictures experts group (MPEG) and the aspect ratio and resolution of the encoded video signal are extracted from a sequence header of a video bit-stream received by the digital video decoder.
- MPEG moving pictures experts group
- the system includes a user input device through which a user may configure the system to produce an output video signal which is compatible with the display device.
- the system includes apparatus which automatically determines the aspect ratio and resolution of the display device.
- the system includes apparatus which sequentially produces video signals corresponding to a plurality of display device types and is responsive to a selection signal provided by a user to identify one of the display types as corresponding in resolution and aspect ratio to the display device.
- FIG. 1A is a high level block diagram of a video decoding and format conversion system according to an exemplary embodiment of the present invention.
- FIG. 1B is a high level block diagram showing the functional blocks of the ATV Video Decoder including an interface to external Memory as employed in an exemplary embodiment of the present invention.
- FIG. 2A is a high level block diagram of a video decoder of the prior art.
- FIG. 2B is a high level block diagram of the down conversion system as employed by an exemplary embodiment of the present invention.
- FIG. 2C is a block diagram which illustrates a configuration of the decoder shown in FIG. 2B which is used to decode a video signal in 1125I format including a downconversion by factor of 3 to 525P/525I format.
- FIG. 2D is a block diagram which illustrates a configuration of the decoder shown in FIG. 2B which is used to decode a video signal in 750P format including a downconversion by factor of 2 to 525P/525I format.
- FIG. 3A is a pixel chart which illustrates subpixel positions and corresponding predicted pixels for the 3:1 and 2:1 exemplary embodiments of the present invention.
- FIG. 3B is a flow-chart diagram which shows the upsampling process which is performed for each row of an input macroblock for an exemplary embodiment of the present invention.
- FIG. 4 is a pixel chart which illustrates the multiplication pairs for the first and second output pixel values of an exemplary embodiment of a block mirror filter.
- FIG. 5 is a block diagram which illustrates an exemplary implementation of the filter for down-conversion for a two-dimensional system processing the horizontal and vertical components implemented as cascaded one-dimensional IDCTs.
- FIG. 6A is a macroblock diagram which shows the input and decimated output pixels for 4:2:0 video signal using 3:1 decimation.
- FIG. 6B is a pixel block diagram which shows the input and decimated output pixels for 4:2:0 video signal using 2:1 decimation.
- FIG. 6C is a macroblock diagram which illustrates a merging process of two macroblocks into a single macroblock for storage in memory for downconversion by 2 horizontally.
- FIG. 6D is a macroblock diagram which illustrates a merging process of three macroblocks into a single macroblock for storage in memory for downconversion by 3 horizontally.
- FIG. 7A is a block diagram illustrating a vertical programmable filter of one embodiment of the present invention.
- FIG. 7B is a pixel diagram which illustrates the spatial relationships between vertical filter coefficients and a pixel sample space of lines of the vertical programmable filter of FIG. 7A.
- FIG. 8A is a block diagram illustrating a horizontal programmable filter of one embodiment of the present invention.
- FIG. 8B is a pixel diagram which illustrates spatial relationships between horizontal filter coefficients and pixel sample values of one embodiment of the present invention.
- FIG. 9A is a graph of pixel number versus resampling ratio which illustrates a resampling ratio profile of an exemplary embodiment of the present invention.
- FIG. 9B is a graph which shows a first ratio profile for mapping a 4:3 picture onto a 16:9 display.
- FIG. 9C is a graph which shows a second ratio profile for mapping a 4:3 picture onto a 16:9 display.
- FIG. 9D is a graph which shows a first ratio profile for mapping a 16:9 picture onto a 4:3 display.
- FIG. 9E is a graph which shows a second ratio profile for mapping a 16:9 picture onto a 4:3 display.
- FIG. 10 is a chart of image diagrams which illustrates the effect of using resampling ratio profiles according to an exemplary embodiment of the present invention.
- FIG. 11A is a high level block diagram illustrating the display section of the ATV Video Decoder of an exemplary embodiment of the present invention.
- FIG. 11B is a block diagram which illustrates a 27 MHz Dual output mode of an exemplary embodiment of the present invention which, for which the video data is 525P or 525I, a first processing chain provides video data to a 27 MHz DAC well as to an NTSC Encoder.
- FIG. 11C is a block diagram which illustrates that, in the 27 MHz single output mode of an exemplary embodiment of the present invention, only a 525I video signal is provided to a NTSC encoder.
- FIG. 11D is a block diagram which illustrates a 74 MHz /27 MHz mode of an exemplary embodiment of the present invention in which the output format matches the input format and the video data is provided to either a 27 MHz DAC or 74 MHz DAC depending on the input format.
- FIG. 12 is a high level block diagram of the video decoder having high bandwidth memory as employed by an exemplary embodiment of the present invention to decode ATSC video signals.
- the exemplary embodiments of the invention decode conventional HDTV signals which have been encoded according to the MPEG-2 standard and in particular, the Main Profile High Level (MP@HL) and the Main Profile Main Level (MP@ML) MPEG-2 standards, and provides the decoded signals as video signals having a lower resolution than that of the received HDTV signals and having a selected one of multiple formats.
- MP@HL Main Profile High Level
- MP@ML Main Profile Main Level
- the MPEG-2 Main Profile standard defines a sequence of images in five levels: the sequence level, the group of pictures level, the picture level, the slice level, and the macroblock level. Each of these levels may be considered to be a record in a data stream, with the later-listed levels occurring as nested sub-levels in the earlier listed levels.
- the records for each level include a header section which contains data that is used in decoding its sub-records.
- Each macroblock of the encoded HDTV signal contains six blocks and each block contains data representing 64 respective coefficient values of a discrete cosine transform (DCT) representation of 64 picture elements (pixels) in the HDTV image.
- DCT discrete cosine transform
- the pixel data may be subject to motion compensated differential coding prior to the discrete cosine transformation and the blocks of transformed coefficients are further encoded by applying run-length and variable length encoding techniques.
- a decoder which recovers the image sequence from the data stream reverses the encoding process. This decoder employs an entropy decoder (e.g. a variable length decoder), an inverse discrete cosine transform processor, a motion compensation processor, and an interpolation filter.
- the video decoder of the present invention is designed to support a number of different picture formats, while requiring a minimum of decoding memory for downconversion of high resolution encoded picture formats, for example, 48 Mb of Concurrent Rambus dynamic random access memory (Concurrent RDRAM).
- Concurrent RDRAM Concurrent Rambus dynamic random access memory
- FIG. 1A shows a system employing an exemplary embodiment of the present invention for receiving and decoding encoded video information at MP@HL or at MP@ML, formatting the decoded information to a user selected output video format (which includes both video and audio information), and interfaces for providing the formatted video output signals to display devices.
- the exemplary embodiments of the present invention are designed to support all ATSC video formats; and in a Down Conversion (DC) mode the present invention receives any MPEG Main Profile video bitstream (constrained by FCC standards) and provides a 525P, 525I or NTSC format picture.
- DC Down Conversion
- the exemplary system of FIG. 1A includes a front end interface 100 , a video decoder section 120 and associated Decoder Memory 130 , a primary video output interface 140 , an audio decoder section 160 , an optional computer interface 110 , and an optional NTSC video processing section 150 .
- the exemplary system includes a front end interface 100 , having a transport decoder and processor 102 with associated memory 103 . Also included may be an optional multiplexer 101 for selecting received control information and computer generated images from the computer interface 110 at, for example, the IEEE 1394 link layer protocol or for recovering an encoded transport stream from a digital television tuner (not shown).
- the transport decoder 102 converts the received compressed data bit stream from the communication channel bit stream into compressed video data, which may be, for example, packetized elementary streams (PES) packets according to MPEG-2 standard.
- PES packetized elementary streams
- the transport decoder may provide either the PES packets directly, or may further convert the PES packets into one or more elementary streams.
- the video decoder section includes an ATV Video Decoder 121 and phase-locked loop (PLL) 122 .
- the ATV video Decoder 121 receives an elementary stream or video (PES) packets from the front end interface 100 , from the front end interface and converts the packets to the elementary stream.
- a front end picture processor of the ATV Video Decoder 121 then decodes the elementary streams according to the encoding method used, to provide luminance and chrominance pixel information for each image picture.
- the PLL 122 synchronizes the audio and video processing performed by the system shown in FIG. 1A.
- the ATV Video Decoder 121 further includes a memory subsystem to control decoding operations using an external memory which provides image picture information and a display section to process decoded picture information into a desired picture format.
- the ATV Video Decoder 121 employs the Decoder Memory 130 to process the encoded video signal.
- the Decoder Memory 130 includes memory units 131 , 132 , 133 , 134 , 135 and 136 , which may each be a 16 Mb RDRAM memory. Exemplary embodiments the present invention are subsequently described with respect to, and implemented within, the video decoder section 120 and Decoder Memory 130 .
- the primary video output interface 140 includes a first Digital to Analog (D/A) converter (DAC) 141 (which actually has three D/A units for the luminance signal and the C R and C B chrominance signals) which may operate at 74 MHz, followed by a filter 142 .
- This interface produces analog video signals having a 1125I or 750P format.
- the interface 140 and also includes a second (D/A) converter (DAC) 143 (also with three D/A units for luminance signal and C R and C B chrominance signals) which may operate at 27 MHz, followed by a filter 142 for video signals having a 525I or 525P format.
- the primary video output interface 140 converts the digitally encoded video signals having a desired format, creates an analog video signal having chrominance and luminance components with the desired format using a (D/A) converter, and filters the analog video signal to remove sampling artifacts of the D/A conversion process.
- the audio decoder section 160 includes an AC3 Audio decoder 162 which provides audio signals at output ports 163 and 164 , and optional 6-2 channel down mixing processor 161 to provide 2 channel audio signals at output port 165 .
- the audio processing of MP@HL MPEG-2 standard audio signal components from encoded digital information to analog output at output ports 163 , 164 and 165 is well known in the art, and an audio decoder suitable for use as the decoder 160 is a ZR38500 Six Channel Dolby Digital Surround Processor, available from the Zoran Corporation of Santa Clara, Calif.
- the optional computer interface 110 transmits and receives computer image signals which conform, for example, to the IEEE 1394 standard.
- the computer interface 110 includes a physical layer processor 111 and link layer processor 112 .
- the physical layer processor 111 converts electrical signals from output port 113 into received computer generated image information and control signals, and provides these signals, for decoding by the link layer processor 112 into IEEE 1394 formatted data.
- the physical layer processor 111 also converts received control signals encoded by the link layer processor 112 originating from the transport decoder 102 into electrical output signals according to the IEEE 1394 standard.
- the NTSC video processing section 150 includes an optional ATV-NTSC Downconversion processor 151 which converts the analog HDTV signal provided by the filter 142 into a 525 I signal.
- This conversion between standards is known in the art and may be accomplished using spatial filtering techniques such as those disclosed in, for example, U.S. Pat. No. 5,613,084 to Hau et al. entitled INTERPOLATION FILTER SELECTION CIRCUIT FOR SAMPLE RATE CONVERSION USING PHASE QUANTIZATION, which is incorporated herein by reference.
- this processing section is used only when the decoder processes a 1080I or 1125I signal.
- the NTSC encoder 152 receives a 525I analog signal either from the processor 151 or directly from the decoder 120 , and converts the signal to the NTSC formatted video signal at output ports 153 (S-video) and 154 (composite video).
- FIG. 1B is a high level block diagram showing the functional blocks of the ATV Video Decoder 121 including an interface to external Memory 130 as employed in an exemplary embodiment of the present invention.
- the ATV Video Decoder 121 includes a Picture Processor 171 , a Macroblock Decoder 172 , a Display section 173 , and a Memory subsystem 174 .
- the Picture processor 171 receives, stores and partially decodes the incoming MPEG-2 video bitstream and provides the encoded bitstream, on-screen display data, and motion vectors, which may be stored in memory 130 under the control of the Memory subsystem 174 .
- the Macroblock Decoder 172 receives the encoded bitstream, motion vectors, and stored motion compensation reference image data, if predictive encoding is used, and provides decoded macroblocks of the encoded video image to the memory subsystem 174 .
- the Display Section 173 retrieves the decoded macroblocks from the Memory subsystem 174 and formats these into the video image picture for display. The operation of these sections is described in detail below.
- the ATV video decoder 121 of the present invention is designed to support all ATSC video formats.
- the operation of the ATV video decoder 121 is termed Down Conversion (DC), and ATV video decoder 121 receives any MPEG Main Profile video bitstreams shown in Table 1 and provides a 525P, 525I or NTSC format video signal.
- DC Down Conversion
- any HDTV or SDTV signal is decoded and a display output signal provided at either of two ports, with port one providing either a progressive or interlaced image, and port two providing an interlaced image.
- DC mode low pass filtering of the high frequency components of the Main Level picture occurs as part of the decoding process to adjust the resolution of the high resolution picture to a format having a lower resolution.
- This operation includes both horizontal and vertical filtering of the high resolution picture.
- the display format conversion may display 16 ⁇ 9 aspect ratio sources on 4 ⁇ 3 displays, and vice-versa. This process is described subsequently with reference to the display section of the video decoder section 120 .
- Table 2 gives the supported primary and secondary output picture formats for the respective input bitstreams of Table 1: TABLE 2 DC Supported Video Formats Number and Primary Output Secondary Output Format Format Format Display Clock (MHz) (1) 1125I 525P 525I 27.00 (2) 1125P 525P 525I 27.00 (3) 750P 525P 525I 27.00 (4) 525P 525P 525I 27.00 (5) 525P 525P 525I 27.00 (6) 525P 525P 525I 27.00 (7) 525I 525P 525I 27.00 (8) 525I 525P 525I 27.00 (9) 525I 525P 525I 27.00
- FIG. 2A is a high level block diagram of a typical video decoding system of the prior art which processes an MPEG-2 encoded picture.
- the general methods used to decode an MPEG-2 encoded picture, without subsequent processing, downconversion or format conversion, are specified by the MPEG-2 standard.
- the video decoding system includes an entropy decoder (ED) 211 , which may include a parser 209 , a variable length decoder (VLD) 210 and run length decoder 212 .
- the system also includes an inverse quantizer 214 , and inverse discrete cosine transform (IDCT) processor 218 .
- ED entropy decoder
- VLD variable length decoder
- IDCT inverse discrete cosine transform
- a Controller 207 controls the various components of the decoding system responsive to the control information retrieved from the input bit stream by the ED 211 .
- the system further includes a memory 199 having reference frame memory 222 , summing network 230 , and Motion Compensation Processor 206 a which may have a motion vector processor 221 and half-pixel generator 228 .
- the controller 207 is coupled to an infrared receiver 208 which receives command signals provided by, for example, a user remote control device.
- the controller 207 decodes these commands and causes the remainder of the system shown in FIG. 2A to perform the specified command.
- the system shown in FIG. 2A includes a set-up mode in which the user may specify a configuration for the system.
- this configuration may include the specification of a display device type. It is contemplated that the display device type may be specified in terms of display resolution and aspect ratio.
- the user may specify the display type by selecting a particular display aspect ratio and resolution from a menu of possible choices or by causing the system to enter a mode in which signals corresponding to different display formats are successively provided to the display device and the user is asked to indicate, via the remote control device, which display is most pleasing.
- the controller 207 also receives information on the resolution and aspect ratio of the encoded video signal from the parser 209 of the ED 211 . Using this information and the stored information relating to the resolution and aspect ratio of the display device, the controller 207 automatically configures the system to process the received encoded signal to produce an analog output signal appropriate for display on the display device.
- the parser 209 scans the received bit stream for MPEG start codes. These codes include a prefix which has a format of 23 consecutive zero-valued bits followed by a single bit having a value of one. The start code value follows this prefix and identifies the type of record that is being received.
- start code value follows this prefix and identifies the type of record that is being received.
- the parser 209 finds a start code in the bit stream, it passes the bit stream onto the memory 199 for storage in the VBV buffer and also stores a pointer to the start code in an area of the memory 199 which is accessed by the controller 207 .
- the controller 207 continually accesses the start code pointers and, through them, the record headers.
- the controller 207 finds a sequence start code, it accesses information in the sequence header which indicates the aspect ratio and resolution of the image sequence that is represented by the encoded sequence. According to the MPEG standard, this information immediately follows the sequence start code in the sequence header.
- Information on the display format of the encoded video signal (i.e. its resolution and aspect ratio) is also contained in the headers of the packetized elementary stream (PES) packets. It is contemplated that in another exemplary embodiment of the invention, the parser 209 may receive PES packets, strip the headers from them to reconstruct the bit stream and pass this header information, including the display format of the received video signal, to the controller 207 .
- PES packetized elementary stream
- the controller 207 uses information on the display format of the received video signal and information on the display format of the display device (not shown) which is connected to the decoder system to automatically or semiautomatically adjust the processing of the received video signal for proper display on the display device.
- the VLD 210 receives the encoded bit stream from the parser 209 via the VBV buffer (not shown) in the memory 199 , and reverses the encoding process to produce macroblocks of quantized frequency-domain (DCT) coefficient values.
- the VLD 210 also provides control information including motion vectors describing the relative displacement of a matching marcoblock in a previously decoded image which corresponds to a macroblock of the predicted picture that is currently being decoded.
- the Inverse Quantizer 214 receives the quantized DCT transform coefficients and reconstructs the quantized DCT coefficients for a particular macroblock.
- the quantization matrix to be used for a particular block is received from the ED 211 .
- the IDCT processor 218 transforms the reconstructed DCT coefficients to pixel values in the spatial domain (for each block of 8 ⁇ 8 matrix values representing luminance or chrominance components of the macroblock, and for each block of 8 ⁇ 8 matrix values representing the differential luminance or differential chrominance components of the predicted macroblock).
- the output matrix values provided by the IDCT Processor 218 are the pixel values of the corresponding macroblock of the current video image. If the macroblock is interframe encoded, the corresponding macroblock of the previous video picture frame is stored in memory 199 for use by the Motion Compensation processor 206 .
- the Motion Compensation Processor 206 receives a previously decoded macroblock from memory 199 responsive to the motion vector, and then adds the previous macroblock to the current IDCT macroblock (corresponding to a residual component of the present predictively encoded frame) in summing network 230 to produce the corresponding macroblock of pixels for the current video image, which is then stored into the reference frame memory 222 .
- FIG. 2B is a high level block diagram of the down conversion system of one exemplary embodiment of the present invention employing such a DCT filtering operation, and which may be employed by an exemplary embodiment of the present invention in DC mode.
- the down conversion system includes a variable length decoder (VLD) 210 , a run-length (R/L) decoder 212 , an inverse quantizer 214 , and inverse discrete cosine transform (IDCT) processor 218 .
- VLD variable length decoder
- R/L run-length
- IDCT inverse discrete cosine transform
- the down conversion system includes a Down Conversion filter 216 for filtering encoded pictures and a Down Sampling processor 232 . While the following describes the exemplary embodiment for a MP@HL encoded input, the present invention may be practiced with any similarly encoded high-resolution image bit stream.
- the down conversion system also includes a Motion Compensation Processor 206 b including a Motion Vector (MV) Translator 220 , a Motion Block Generator 224 including an Up-Sampling Processor 226 , Half-Pixel Generator 228 , and a Reference Frame Memory 222 .
- MV Motion Vector
- a Motion Block Generator 224 including an Up-Sampling Processor 226 , Half-Pixel Generator 228 , and a Reference Frame Memory 222 .
- the system of the first exemplary embodiment of FIG. 2B also includes a Display Conversion Block 280 having a Vertical Programmable Filter (VPF) 282 and Horizontal Programmable Filter (HZPF) 284 .
- the Display Conversion Block 280 converts downsampled images into images for display on a particular display device having a lower resolution than the original image, and is described in detail subsequently in section d)(2) on Display Conversion.
- the Down Conversion Filter 216 performs a lowpass filtering of the high resolution (e.g. Main Profile, High Level DCT) coefficients in the frequency domain.
- the Down Sampling Process 232 eliminates spatial pixels by decimation of the filtered Main Profile, High Level picture to produce a set of pixel values which can be displayed on a monitor having lower resolution than that required to display a MP@HL picture.
- the exemplary Reference Frame Memory 222 stores the spatial pixel values corresponding to at least one previously decoded reference frame having a resolution corresponding to the down-sampled picture.
- the MV Translator 220 scales the motion vectors for each block of the received picture consistent with the reduction in resolution, and the High Resolution Motion Block Generator 224 receives the low resolution motion blocks provided by the Reference Frame Memory 222 , upsamples these motion blocks and performs half-pixel interpolation as needed to provide motion blocks which have pixel positions that correspond to the decoded and filtered differential pixel blocks.
- VLD 210 The MP@HL bit-stream is received and decoded by VLD 210 .
- the VLD 210 provides DCT coefficients for each block and macroblock, and motion vector information.
- the DCT coefficients are run length decoded in the R/L decoder 212 and inverse quantized by the inverse quantizer 214 .
- the exemplary embodiment of the present invention employs lowpass filtering of the DCT coefficients of each block before decimation of the high resolution video image.
- the inverse quantizer 214 provides the DCT coefficients to the DCT filter 216 which performs a lowpass filtering in the frequency domain by weighting the DCT coefficients with predetermined filter coefficient values before providing them to the IDCT processor 218 .
- this filter operation is performed on a block by block basis.
- the IDCT processor 218 provides spatial pixel sample values by performing an inverse discrete cosine transform of the filtered DCT coefficients.
- the Down Sampling processor 232 reduces the picture sample size by eliminating spatial pixel sample values according to a predetermined decimation ratio; therefore, storing the lower resolution picture uses a smaller frame memory compared to that which would be needed to store the higher resolution MP@HL picture.
- the current received image DCT coefficients represent the DCT coefficients of the residual components of the predicted image macroblocks, which is now referred to as a predicted frame (P-frame) for convenience.
- P-frame predicted frame
- the horizontal components of the motion vectors for a predicted frame are scaled since the low resolution reference pictures of previous frames stored in memory do not have the same number of pixels as the high resolution predicted frame (MP@HL).
- the motion vectors of the MP@HL bit stream provided by the VLD 210 are provided to the MV Translator 220 Each motion vector is scaled by the MV Translator 220 to reference the appropriate prediction block of the reference frame of a previous image stored in reference frame memory 222 of memory 199 .
- the size (number of pixel values) in the retrieved block is smaller than block provided by the IDCT processor 218 ; consequently, the retrieved block is upsampled to form a prediction block having the same number of pixels as the residual block provided by the IDCT Processor 218 before the blocks are combined by the summing network 230 .
- the prediction block is upsampled by the Up-Sampling Processor 226 responsive to a control signal from the MV Translator 220 to generate a block corresponding to the original high resolution block of pixels, and then half pixel values are generated—if indicated by the motion vector for the up-sampled prediction block in the Half Pixel Generator 228 —to ensure proper spatial alignment of the prediction block.
- the upsampled and aligned prediction block is added in summing network 230 to the current filtered block, which is, for this example, the reduced resolution residual component from the prediction block. All processing is done on a macroblock by macroblock basis.
- the reconstructed macroblock is decimated accordingly by the Down Sampling Processor 232 . This process does not reduce the resolution of the image but simply removes redundant pixels from the low resolution filtered image.
- the Display Conversion Block 280 adjusts the image for display on a low resolution television display unit by filtering the vertical and horizontal components of the downsampled image in VPF 282 and HZPF 284 respectively.
- the picture processor 171 of FIG. 1B receives the video picture information bitstreams.
- the Macroblock Decoder 172 includes VLD 210 , inverse quantizer 214 , the DCT filter 216 , IDCT 218 , summing network 230 , and the motion compensated predictors 206 a and 206 b.
- the picture processor 171 may share the VLD 210 .
- External Memory 130 corresponds to memory 199 , with 16 Mb RDRAM 131-136 containing the reference frame memory 222 .
- FIG. 2C illustrates the operation of the system in DC mode, converting an 1125I signal to 525P/525I format.
- the system down samples the high resolution signal by a factor of 3, and stores the pictures in the 48 Mb memory as 640H and 1080 V, interlaced.
- the motion compensation process upsamples the stored pictures by a factor of 3 (as well as translation of the received motion vectors) before motion-predictive decoding is accomplished. Also, the picture is filtered horizontally and vertically for display conversion.
- FIG. 2D similarly illustrates the relationship between DC mode format downconversion from 750P to 525P/525I format. This conversion operates in the same way as the 1125I to 525P/525I conversion except that downsampling for memory storage, and upsampling for motion compensation, is by a factor of 2.
- the received motion vectors pointing to these frames may also be translated according to the conversion ratio.
- the following describes the motion translation for the luminance block in the horizontal direction.
- One skilled in the art could easily extend the following discussion to motion translation in the vertical direction if desired.
- Denoting x and y as the current macroblock address in the original image frame, Dx as the horizontal decimation factor and mv x as the half pixel horizontal motion vector of the original image frame, the address of the top left pixel of the motion block in the original image frame, denoted as XH in the half pixel unit, is given by (1):
- the exemplary filter 216 and Down Sampling Processor 232 only reduce the horizontal components of the image, the vertical component of the motion vector is not affected.
- the motion vector is one-half of a luminance motion vector in the original picture. Therefore, definitions for translating the chrominance motion vector may also use the two equations (1) and (2).
- Motion prediction is done by a two step process: first, pixel accuracy motion estimation in the original image frame may be accomplished by upsampling of down-sampled image frame in the Up Sampling Processor 226 of FIGS. 2A and 2B, then the half pixel Generator 228 performs a half pixel interpolation by averaging of nearest pixel values.
- the reference image data is added to output data provided by the IDCT processor 218 . Since the output values of the summing network 230 correspond to an image having a number of pixels consistent with a high resolution format, these values may be downsampled for display on a display having a lower resolution. Downsampling in the Down Sampling processor 232 is substantially equivalent to subsampling of an image frame, but adjustments may be made based upon the conversion ratio. For example, in the case of 3:1 downsampling, the number of horizontally downsampled pixels are 6 or 5 for each input macroblock, and the first downsampled pixels are not always first pixel in the input macroblock.
- FIG. 3A shows subpixel positions and corresponding 17 predicted pixels for the 3:1 and 2:1 examples, and Table 3 gives the legend for FIG. 3A. TABLE 3 Symbol Pixel
- the upsampling filters may be upsampling polyphase filters, and Table 4 gives characteristics of these upsampling polyphase interpolation filters. TABLE 4 3:1 2:1 Upsampling Upsampling Number of Polyphase Filters 3 2 Number of Taps 3 5 Maximum number of horizontal 9 13 downsampled pixels
- the numbers in parenthesis of Table 5 and Table 6 are 2's complement representations in 9 bits with the corresponding double precision numbers are on the left.
- one corresponding phase of the polyphase interpolation filter is used.
- additional pixels on the left and right are used to interpolate 17 horizontal pixels in the original image frame. For example, in the case of 3:1 decimation, a maximum of 6 horizontally downsampled pixels are produced for each input macroblock.
- 9 horizontal pixels are used to produce the corresponding motion prediction block values because an upsampling filter requires more left and right pixels outside of the boundary for the filter to operate.
- a half pixel interpolator performs the interpolation operation which provides the block of pixels with half-pixel resolution.
- Table 7A illustrates an exemplary mapping between subpixel positions and polyphase filter elements, and shows a number of left pixels which are needed in addition to the pixels in the upsampled block for the upsampling process. TABLE 7A Sub Pixel No.
- FIG. 3B summarizes the upsampling process which is performed for each row of an input macroblock.
- the motion vector for the block of the input image frame being processed is received.
- the motion vector is translated to correspond to the downsampled reference frame in memory.
- the scaled motion vector is used to calculate the coordinates of the desired reference image half macroblock stored in memory 130 .
- the subpixel point for the half macroblock is determined and the initial polyphase filter values for upsampling are then determined at step 318 .
- the identified pixels for the reference half macroblock of the stored downsampled reference frame are then retrieved from memory 130 at step 320 .
- the registers of the filter may be initialized at step 322 , which, for the exemplary embodiment includes the step of loading the registers with the initial 3 or 5 pixel values. Then, after the filtering step 324 , the process determines, at step 326 , whether all pixels have been processed, which for the exemplary embodiment is 17 pixels. If all pixels have been processed, the upsampled block is complete. For an exemplary embodiment, a 17 by 9 pixel half macroblock is returned. The system returns upper or lower half macroblocks to allow for motion prediction decoding of both progressive scan and interlaced scan images. If all pixels have not been processed, the phase is updated at step 328 , and the phase is checked, for the 0 value.
- the registers are updated for the next set of pixel values. Updating the phase at step 328 updates the phase value to 0, 1, and 2 for the filter loop period for exemplary 3:1 upsampling and to 0, and 1 for the filter loop period for 2:1 upsampling. Where the left-most pixel is outside of a boundary of the image picture, the first pixel value in the image picture may be repeated.
- the upsample filtering operation may be implemented in accordance with the following guidelines. First, several factors may be used: 1) the half-pixel motion prediction operation averages two full pixels, and corresponding filter coefficients are also averaged to provide the half-pixel filter coefficient; 2) a fixed number of filter coefficients, five for example, which may be equivalent to the number of filter taps, may be employed regardless of the particular downconversion; 3) five parallel input ports may be provided to the upsampling block for each forward and backward lower and upper block, with five input pixels LWR( 0 )-LWR( 4 ) for each clock transition for each reference block being combined with corresponding filter coefficients to provide one output pixel, and 4) the sum of filter coefficients h( 0 )-h( 4 ) combined with respective pixels LWR( 0 )-LWR( 4 ) provide the output pixel of the sampling block.
- Filter coefficients are desirably reversed because the multiplication ordering is opposite to the normal ordering of filter coefficients, and it may be desirable to zero some coefficients.
- Table 7B gives exemplary coefficients for the 3:1 upsampling filter
- Table 7C gives exemplary coefficients for the 2:1 upsampling filter: TABLE 7B Sub- Sub- Sub- Sub- Sub- Sub- Sub- pixel 0 pixel 1 pixel 2 pixel 3 pixel 4 pixel 5 Filter 6 ⁇ 18 ⁇ 42 ⁇ 21 96 51 Coeff.
- x* is the downsampled pixel position defined in equations (1) and (2), and subpixel position, x s , is redefined from equation (3) as equation (3′)
- phase and half pixel information (coded as two bits and one bit, respectively) is used by motion compensation processor 220 and half-pixel generator 228 of FIG. 2B.
- reference block pixels are provided as U pixels first, V pixels next, and finally Y pixels.
- U and V pixels are clocked in for 40 cycles and Y pixels are clocked in for 144 cycles.
- Reference blocks may be provided for 3:1 decimation by providing the first five pixels, repeating twice, shifting the data by one, and repeating until a row is finished. The same method may be used for 2:1 decimation except that it is repeated once rather than twice. Input pixels are repeated since decimation follows addition of the output from motion compensation and half-pixel generation with the residual value. Consequently, for 3:1 decimation, two of three pixels are deleted, and dummy pixels for these pixel values do not matter.
- the exemplary embodiment of the present invention includes the DCT filter 216 of FIG. 2A processing the DCT coefficients in the frequency domain, which replaces a lowpass filter in the spatial domain.
- DCT domain filtering instead of spatial domain filtering for DCT coded pictures, such as contemplated by the MPEG or JPEG standards.
- a DCT domain filter is computationally more efficient and requires less hardware than a spatial domain filter applied to the spatial pixel sample values.
- a spatial filter having N taps may use as many as N additional multiplications and additions for each spatial pixel sample value. This compares to only one additional multiplication in the DCT domain filter.
- the simplest DCT domain filter of the prior art is a truncation of the high frequency DCT coefficients.
- truncation of high frequency DCT coefficients does not result in a smooth filter and has drawbacks such as “ringing” near edges in the decoded picture.
- the DCT domain lowpass filter of the exemplary embodiment of the present invention is derived from a block mirror filter in the spatial domain.
- the filter coefficient values for the block mirror filter are, for example, optimized by numerical analysis in the spatial domain, and these values are then converted into coefficients of the DCT domain filter.
- DCT domain filtering can be done in either horizontal or vertical direction or both by combining horizontal and vertical filters.
- One exemplary filter of the present invention is derived from two constraints: first, that the filter process image data on a block by block basis for each block of the image without using information from previous blocks of a picture; and second, that the filter reduce the visibility of block boundaries which occur when the filter processes boundary pixel values.
- the exemplary embodiment of the present invention implements a DCT domain filter which only processes a current block of the received picture.
- a horizontal block mirror filter that lowpass filters 8 input spatial pixel sample values of a block. If the size of input block is an 8 ⁇ 8 block matrix of pixel sample values, then a horizontal filtering can be done by applying the block mirror filter to each row of 8 pixel sample values. It will be apparent to one skilled in the art that the filtering process can be implemented by applying the filter coefficients columnwise to the block matrix, or that multidimensional filtering may be accomplished by filtering the rows and then filtering the columns of the block matrix.
- FIG. 4 shows an exemplary correspondence between the input pixel values x 0 through x 7 (group X 0 ) and filter taps for an exemplary mirror filter for 8 input pixels which employs a 15 tap spatial filter represented by tap values h 0 through h 14 .
- the input pixels are mirrored on the left side of group X 0 , shown as group X 1 , and on the right side of group X 0 , shown as group X 2 .
- the output pixel value of the filter is the sum of 15 multiplications of the filer tap coefficient values with the corresponding pixel sample values.
- FIG. 4 illustrates the multiplication pairs for the first and second output pixel values.
- x ′ ( x 0, x 1, x 2, x 3, x 4, x 5, x 6, x 7, x 7, x 6, x 5, x 4, x 3, x 2, x 1, x 0)
- h ′ ( h 7, h 8, h 9, h 10, h 11, h 12, h 13, h 14, 0, h 0, h 1, h 2, h 3, h 4, h 5, h 6)
- the mirror filtered output y(n) is a circular convolution of x′(n) and h′(n) which is given by equation (5).
- x′[n] x′ ( n+ 2 N ) for n ⁇ 0.
- Equation (5) corresponds to the scalar multiplication in the Discrete Fourier Transform (DFT) domain. Defining Y(k) as the DFT of y(n), then equation (5) becomes equation (7) in the DFT domain.
- DFT Discrete Fourier Transform
- X′(k) and H′(k) are the DFTs of x′(n) and h′(n) respectively.
- Equations (4) through (7) are valid for a filter with a number of taps less than 2N.
- the filter is limited to be a symmetric filter with an odd number of taps, with these constraints H′(k) is a real number. Therefore, X′(k), the DFT of x′(n), can be weighed with a real number H′(k) in the DFT frequency-domain instead of 2N multiplication and 2N addition operations in the spatial domain to implement the filtering operation.
- X′(k) are very closely related to the DCT coefficients of the original N-point x(n), because an N-point DCT of x(n) is obtained by the 2N-point DFT of x′(n) which is the joint sequence composed of x(n) and its mirror, x(2N ⁇ 1 ⁇ n).
- H′(k) DFT coefficients of the spatial filter
- X′(k), the DFF coefficients of x′(n) can be expressed by C(k), the DCT coefficients of x′(n) by the matrix of equation (11).
- the values y(n) of equation (13) are the spatial values of the IDCT of C(k)H′(k). Therefore, the spatial filtering can be replaced by the DCT weighting of the input frequency-domain coefficients representing the image block with H′(k) and then performing the IDCT of the weighted values to reconstruct the filtered pixel values in the spatial domain.
- One embodiment of the exemplary block mirror filtering of the present invention is derived as by the following steps: 1) a one dimensional lowpass symmetric filter is chosen with an odd number of taps, which is less than 2N taps; 2) the filter coefficients are increased to 2N values by padding with zero's; 3) the filter coefficients are rearranged so that the original middle coefficient goes to the zeroth position by a left circular shift; 4) the DFT coefficients of the rearranged filter coefficients are determined; 5) the DCT coefficients are multiplied with the real number DFT coefficients of the filter; and 6) an inverse discrete cosine transform (IDCT) of the filtered DCT coefficients is performed to provide a block of lowpass-filtered pixels prepared for decimation.
- IDCT inverse discrete cosine transform
- the cutoff frequency of the lowpass filter is determined by the decimation ratio.
- the cutoff frequency is ⁇ /3 for a 3:1 decimation and ⁇ /2 for a 2:1 decimation, where ⁇ corresponds to one-half of sampling frequency.
- a DCT domain filter in MPEG and JPEG decoders allows memory requirements to be reduced because the inverse quantizer and IDCT processing of blocks already exists in the decoder of the prior art, and only the additional scalar multiplication of DCT coefficients by the DCT domain filter is required. Therefore, a separate DCT domain filter block multiplication is not physically required in a particular implementation; another embodiment of the present invention simply combines the DCT domain filter coefficients with the IDCT processing coefficients and applies the combined coefficients to the IDCT operation.
- Table 8 shows the DCT block mirror filter (weighting) coefficients; in Table 8 the numbers in the parenthesis are 10 bit 2's complementary representations.
- the “*” of Table 8 indicates an out of bound value for the 10 bit 2's complement representation because the value is more than 1; however, as is known by one skilled in the art, the multiplication of the column coefficients of the block by the value indicated by the * can be easily implemented by adding the coefficient value to the coefficient multiplied by the fractional value (remainder) of the filter value.
- These horizontal DCT filter coefficients weight each column in the 8 ⁇ 8 block of DCT coefficients of the encoded video image. For example, the DCT coefficients of column zero are weighted by H[0], and the DCT coefficients of the first column are weighted by H[1] and so on.
- Equation (12) illustrates the IDCT for the one-dimensional case
- f(x,y) is the spatial domain representation
- x and y are spatial coordinates in the sample domain
- u,v are the coordinates in the transform domain. Since the coefficients C(u), C(v) are known, as are the values of the cosine terms, only the transform domain coefficients need to be provided for the processing algorithms.
- the input sequence is now represented as a matrix of values, each representing the respective coordinate in the transform domain, and the matrix may be shown to have sequences periodic in the column sequence with period M, and periodic in the row sequence with period N, N and M being integers.
- a two-dimensional DCT can be implemented as a one dimensional DCT performed on the columns of the input sequence, and then a second one dimensional DCT performed on the rows of the DCT processed input sequence.
- a two-dimensional IDCT can be implemented as a single process.
- FIG. 5 shows an exemplary implementation of the filter for down-conversion for a two-dimensional system processing the horizontal and vertical components implemented as cascaded one-dimensional IDCTs.
- the DCT Filter Mask 216 and IDCT 218 of FIG. 2 may be implemented by a Vertical Processor 510 , containing a Vertical DCT Filter 530 and a Vertical IDCT 540 , and a Horizontal Processor 520 , containing a horizontal DCT Filter and horizontal IDCT which are the same as those implemented for the vertical components.
- the order of implementing these processes can be rearranged (e.g, horizontal and vertical DCT filtering first and horizontal and vertical IDCTs second, or vise-versa, or Vertical Processor 520 first and Horizontal Processor 510 (second)).
- the Vertical Processor 510 is followed by a block Transpose Operator 550 , which switches the rows and columns of the block of vertical processed values provided by the Vertical Processor. This operation may be used to increase the efficiency of computation by preparing the block for processing by the Horizontal Processor 520 .
- the encoded video block for example an 8 ⁇ 8 block of matrix values, is received by the Vertical DCT filter 530 , which weights each row entry of the block by the DCT filter values corresponding to the desired vertical decimation.
- the Vertical IDCT 540 performs the inverse DCT for the vertical components of the block.
- the DCT LPF coefficients can be combined with the vertical DCT coefficients for matrix multiplications and addition operations.
- the Vertical Processor 510 then provides the vertically processed blocks to the Transpose Operator 550 , which provides the transposed block of vertically processed values to the Horizontal Processor 520 .
- the Transpose Operator 550 is not necessary unless the IDCT operation is only done by row or by column.
- the Horizontal Processor 520 performs the weighting of each column entry of the block by the DCT filter values corresponding to the desired horizontal filtering, and then performs the inverse DCT for the horizontal components of the block.
- the DCT filter operation may be combined with the inverse DCT (IDCT) operation.
- IDCT inverse DCT
- the filter coefficients may be combined with the coefficients of the IDCT to form a modified IDCT.
- the modified IDCT and hence the combined IDCT and DCT downconversion filtering, may be performed through a hardware implementation similar to that of the simple IDCT operation.
- the exemplary embodiment of the present invention employs an ATV Video Decoder 121 having a Memory Subsystem 174 which controls the storage and reading of information to and from Memory 130 .
- Memory Subsystem 174 provides picture data and bitstream data to Memory 130 for video decoding operations, and in the preferred embodiment, at least 2 pictures, or frames, are used for proper decoding of MPEG-2 encoded video data.
- An optional On-Screen Display (OSD) section in the Memory 130 may be available to support OSD data.
- the interface between the Memory Subsystem 174 and Memory 130 may be a Concurrent RDRAM interface providing a 500 Mbps channel, and three RAMBUS channels may be used to support the necessary bandwidth.
- FIG. 12 is a high level block diagram of such system of a video decoder having high bandwidth memory as employed by an exemplary embodiment of the present invention to decode MP@ML MPEG-2 pictures.
- U.S. Pat. No. 5,623,311 describes a single, high bandwidth memory having a single memory port.
- the memory 130 holds input bitstream, first and second reference frames used for motion compensated processing, and image data representing the field currently being decoded.
- the decoder includes 1) circuitry (picture processor 171 ) which stores and fetches the bitstream data, 2) circuitry that fetches the reference frame data and stores the image data for the currently decoded field in block format (Macroblock decoder 172 ), and fetches the image data for conversion to raster-scan format (display section 173 ).
- the memory operations are time division multiplexed using a single common memory port with a defined memory access time period, called Macroblock Time (MblkT) for control operations.
- a digital phase locked loop (DPLL) 122 counts pulses of a 27 MHz system clock signal, defined in the MPEG-2 standard, to generate a count value. The count value is compared to a succession of externally supplied system clock reference (SCR) values to generate a phase difference signal that is used to adjust the frequency of the signal produced by the digital phase locked loop.
- SCR system clock reference
- Table 9 summarizes the picture storage requirements for DC configurations to support multiple formats: TABLE 9 Pixels Macroblocks Pixels Macroblocks Bits per Storage Format (H) (H) (V) (V) Picture (3 Pictures) 1920 ⁇ 1088 DC 640 40 1088 68 8,355,840 25,067,520 1280 ⁇ 720 DC 640 40 720 45 5,529,600 16,588,800 704 ⁇ 480 704 44 480 30 4,055,040 12,165,120 640 ⁇ 480 640 40 480 30 3,686,400 12,165,120
- Accommodating multiple DC pictures in Memory 130 also requires supporting respective decoding operations according to corresponding picture display timing. For example, progressive pictures occur at twice the rate of interlaced pictures (60 or 59.94 Hz progressive vs. 30 or 29.97 Hz interlace) and, as a result, progressive pictures are decoded faster than interlaced pictures (60 or 59.94 Frames per second progressive vs. 30 or 29.97 Frames per second interlace). Consequently, the decoding rate is constrained by the display rate for the format, and if the less stringent 59.97 or 29.97 frames per second decoding rates are used rather than the 60 or 30 frames per second, one frame out of every 1001 frames may be dropped from the conversion.
- decoding operations for a format may be measured in units of “Macroblock Time” (MblkT) defined as the period during which all decoding operations for a macroblock may be completed (clock cycles per macroblock decoding). Using this period as a measure, as defined in equation 14, control signals and memory access operations can be defined during the regularly occurring MblkT period.
- Mcroblock Time MblkT
- a blanking interval may not be used for picture decoding of interlaced pictures, and an 8-line margin to the time period is added to account for decoding 8 lines simultaneously (interlaced) and 16 lines simultaneously (progressive). Therefore, an adjustment factor (AdjFact) may be added to the MblkT, as given in equations (15) and (16).
- AdjFact (interlace) (total lines ⁇ vertical blank lines ⁇ 8)/total lines (15)
- AdjFact (progressive) (total lines ⁇ 16)/total lines (16)
- Table 10 lists MblkT for each of the supported formats: TABLE 10 Mblk Frame Adjust- Active per Time MblkT ment Decoding Format frame (msec) (clks) factor MblkT 1920 ⁇ 1080 8160 33.33 255.3 0.9729 248.4 1280 ⁇ 720 3600 16.67 289.4 0.9787 283.2 704 ⁇ 480 P 1320 16.67 789.1 0.9695 765.1 704 ⁇ 480 I 1320 33.33 1578 0.9419 1486.6 640 ⁇ 480 P 1200 16.67 868 0.9695 841.6 640 ⁇ 480 I 1200 33.33 1736 0.9419 1635.3
- a MblkT of 241 clocks is employed for all formats to meet the requirement of the fastest decode time including a small margin.
- slower format decoding includes periods in which no decoding activities occur; consequently, a counter may be employed to reflect the linear decoding rate with a stall generated to stop decoding in selected MblkT intervals.
- the Memory Subsystem 174 may provide internal picture data interfaces to the Macroblock decoder 172 and display section 173 .
- a decoded macroblock interface accepts decoded macroblock data and stores it in correct memory address locations of Memory 130 according to a memory map defined for the given format.
- Memory addresses may be derived from the macroblock number and picture number.
- the macroblocks may be received as a macroblock row on three channels, one channel per 16 Mb memory device ( 131 - 136 of FIG. 1A) at the system clock rate.
- Each memory device may have two partitions for each picture, each partition using an upper and lower address.
- the one partition carries Field 0 data and the other partition carries Field 1 data
- both upper and lower partitions are treated as a single partition and carry data for the entire frame.
- Every macroblock is decoded and stored for every picture, except for 3:2 pull down mode where decoding is paused for an entire field time period.
- 3:2 pulldown mode a signal having a frame rate of 24 frames per second is displayed at 60 frames (or fields) per second by displaying one frame twice and the next frame three times.
- a reference macroblock interface supplies stored, previously decoded picture data to the macroblock decoder 172 for motion compensation.
- the interface may supply two, one or no macroblocks corresponding to bi-directional predictive (B) encoding, uni-directional predictive (P) encoding or intra (I) encoding.
- B bi-directional predictive
- P uni-directional predictive
- I intra
- Each reference block is supplied using two channels, and each channel contains one-half of a macroblock.
- each retrieved half macroblock is 14 ⁇ 9 (Y), 10 ⁇ 5 (C R ) and 10 ⁇ 5 (C B ) to allow for up-sampling and half-pixel resolution.
- a display interface provides retrieved pixel data to the display section 173 , multiplexing Y, C R , and C B pixel data on a single channel.
- Two display channels may be provided to support conversion from/to interlaced to/from progressive formats.
- a first channel may provide up to 4 lines of interlaced or progressive data simultaneously and a second channel may provide up to 4 lines of interlaced data.
- FIG. 6C illustrates a merging process of two macroblocks into a single macroblock for storage in memory 130 for downconversion by 2 horizontally.
- FIG. 6D illustrates a merging process of three macroblocks into a single macroblock for storage in memory 130 for downconversion by 3 horizontally.
- FIG. 6A shows the input and decimated output pixels for a 4:2:0 signal format for 3:1 decimation.
- FIG. 6B shows the input and decimated output pixels for 4:2:0 chrominance type 2:1 decimation.
- Table 11 gives the legend identification for the Luminance and Chrominance pixels of FIG. 6A and FIG. 6B.
- the pixel positions before and after the down conversion of FIGS. 6A and 6B are the interlaced (3:1 decimation) and progressive (2:1 decimation) cases respectively.
- TABLE 11 Symbol Pixel + Luminance Before Decimation ⁇ Chrominance Before Decimation
- MB 0 there are 6 down-sampled pixels horizontally, but 5 pixels in MB 1 and MB 2 . These three MB types are repeating, therefore Modulo 3 arithmetic is to be applied.
- Table 12 summarizes the number of downsampling pixels and offsets for each input macroblock MB 0 , MB 1 , MB 2 . TABLE 12 MB0 MB1 MB2 No. of Down Sampled 6 5 5 Luminance Pixels No. of Down Sampled 3 3 2 Chrominance Pixels Offset of 1st Down 0 2 1 Sampled Luminance Pixel Offset of 1st Down 0 1 2 Sampled Chrominance Pixel
- the luminance signal is subsampled for every second sample horizontally.
- the down-sampled pixel has a spatial position that is one-half pixel below the pixel position in the original image.
- FIG. 11A is a high level block diagram illustrating the display section of the ATV Video Decoder 121 for an exemplary embodiment of the present invention.
- FIG. 11A two output video signals are supported, a first output signal VID out1 which supports any selected video format, and a second output signal VID out2 which supports 525I (CCIR-601) only.
- Each output signal is processed by separate sets of display processing elements 1101 and 1102 , respectively, which perform horizontal and vertical upsampling/downsampling. This configuration may be preferred when the display aspect ratio does not match the aspect ratio of the input picture.
- An optional On Screen Display (OSD) section 1104 may be included to provide on screen display information to one of the supported output signals VID out1 and VID out2 to form display signals V out1 or V out2 .
- OSD On Screen Display
- the pixel clock rate may be at the luminance pixel rate or at twice the luminance pixel rate.
- the display sets of processing elements 1101 and 1102 operate similarly, only the operation of the display processing set 1101 is described.
- the display processing set 1101 four lines of pixel data are provided from the memory 130 (shown in FIG. 1A) to the vertical processing block 282 (shown in FIG. 2B) in raster order. Each line supplies C R ,Y,C B ,Y data 32 bits at a time.
- Vertical Processing block 282 then filters the four lines down to one line and provides the filtered data in 32 bit C R YC B Y format to horizontal processing block 284 (also shown in FIG. 2B).
- the horizontal processing block 284 provides the correct number of pixels for the selected raster format as formatted pixel data.
- the filtered data rate entering the horizontal processing block 284 is not necessarily equal to the output data rate.
- the input data rate will be lower than the output data rate.
- the input data rate will be higher than the output data rate.
- the formatted pixel data may have background information inserted by optional background processing block 1110 .
- the elements of the display section 173 are controlled by a controller 1150 , which is set up by parameters read from and written to the microprocessor interface.
- the controller generates signal CNTRL, and such control is necessary to coordinate and to effect proper circuit operation, loading and transfer of pixels, and signal processing.
- Data from the horizontal processing block 284 , data from a second horizontal processing block 284 a, and HD (non processed) Video data on HD Bypass 1122 are provided to Multiplexer 118 which selects, under processor control (not shown), one video data stream which is provided to mixer 116 to combine the video data stream and optional OSD data from OSD processor 1104 into mixed output video data. The mixed video output data is then provided to MUXs 1120 and 1124 .
- MUX 1120 may select from mixed output video data, HD data provided on HD bypass 1122 , or data from background insertion block 1110 .
- the selected data is provided to output control processor 1126 which also receives the pixel clock.
- Output control processor 1126 then changes the data clock rate from the internal processing domain to the pixel clock rate according to the output mode desired.
- MUX 1124 may select from mixed output video data or data from background insertion block 1110 a. The selected data is provided to output control processor 1128 which also receives the pixel clock. Output control processor 1128 then changes the data clock rate from the internal processing domain to the pixel clock rate according to the output mode desired. MUX 1132 provides either the received selected data (601 Data Out) of MUX 1124 or optional OSD data from OSD processor 1104 .
- Raster Generation and Control processor 1130 also receives the pixel clock and includes counters (not shown) which generate the raster space, allowing control commands to be sent on a line by line basis to Display Control Processor 1140 .
- Display Control processor 1140 coordinates timing with the external memory 130 and starts the processing for each processing chain 1101 and 1102 on a line by line basis synchronized with the raster lines.
- Processor 1130 also generates the horizontal, vertical and field synchronization signals (H, V and F).
- FIG. 11B illustrates a 27 MHz Dual output mode which, for which the video data is 525P or 525I, first processor 1101 (shown in FIG. 11A) provides 525P video data to 27 MHz DAC 143 as well as 525I data (601 Data Out) to NTSC Encoder 152 .
- FIG. 11C illustrates that in 27 MHz single output mode, only 525I data (601 Data Out) is provided to NTSC encoder 152 .
- FIG. 11B illustrates a 27 MHz Dual output mode which, for which the video data is 525P or 525I
- first processor 1101 shown in FIG. 11A
- FIG. 11C illustrates that in 27 MHz single output mode, only 525I data (601 Data Out) is provided to NTSC encoder 152 .
- 11D illustrates a 74 MHz/27 MHz mode in which the output mode matches the input format and the video data is provided to either the 27 MHz DAC 143 or 74 MHz DAC 141 depending on the output format.
- the 74 MHz DAC is used for 1920 ⁇ 1088 and 1280 ⁇ 720 pictures; the 27 MHz DAC is used for all other output formats.
- Display conversion of the downsampled image frames is used for display the image in a particular format.
- the Display Conversion block 280 shown in FIG. 2B includes the vertical processing block (VPF) 282 and horizontal processing block (HZPF) 284 which adjust the down converted and down sampled images for display on the lower resolution screen.
- VPF vertical processing block
- HZPF horizontal processing block
- VPF 282 which, for the exemplary embodiment, is a vertical line interpolation processor implemented as a programmable polyphase vertical filter
- HZPF 284 which, for the exemplary embodiment, is a horizontal line interpolation processor also implemented as a programmable horizontal polyphase filter.
- the filters are programmable, which is a design option in order to accommodate display conversion for a number of display formats.
- VPF 282 four lines of downsampled pixel data enter the VPF 282 in raster order.
- this data includes luminance (Y) and chrominance (C R and C B ) pixel pairs which enter VPF 282 32 bits at a time.
- VPF 282 filters the four lines of data into one line and passes this line to the HZPF 284 as 32 bit values each containing luminance and chrominance data in a YC R YC B , and HZPF 284 then generates the correct number of pixels to match the desired raster format.
- FIG. 7A is a high level block diagram illustrating an exemplary filter suitable for use as the VPF 282 of one embodiment of the present invention.
- the VPF 282 is described as processing pairs of input pixels (each pair includes two luminance pixels, Y, pixel and a chrominance C R or C B , pixel) to produce a pair of output pixels. This facilitates processing of the 4:2:0 format because color pixels may be easily associated with their corresponding luminance pixels. One skilled in the art, however, would realize that only luminance pixels or only chrominance pixels may be so processed.
- the VPF 282 as described produces lines in progressive format.
- a second VPF 282 may be added.
- VPF 282 includes a VPF Controller 702 ; first muliplexer network including Luminance Pixel MUXs (LP MUXs) 706 , 708 , 710 , and 712 and Chrominance Pixel MUXs (CP MUXs) 714 , 716 , 718 , and 720 ; second multiplexer network including Luminance Filter MUXs (LF MUXs) 726 , 728 , 730 and 732 and Chrominance Filter MUXs (CF MUXs) 734 , 736 , 738 and 740 ; Luminance Coefficient RAM 704 ; Chrominance Coefficient RAM 724 ; Luminance Coefficient Multipliers 742 , 744 , 746 , and 748 ; Chrominance Coefficient Multipliers 750 , 752 , 754 , and 756 ; Luminance Adders 760 , 762 and 764 ; Chrominance Adders 760 , 762
- VPF 282 The operation of the VPF 282 is now described. Vertical resampling is accomplished with two 4-Tap polyphase filters, one for the Luminance pixels and one for the Chrominance pixels. The following details operation of the filter for the Luminance pixels only, since the operation for the Chrominance pixels is similar, but points out those differences in the paths as they occur. Vertical filtering of Luminance pixels can use up to 8 phases in the 4-Tap polyphase filter and filtering of Chrominance pixels can use up to 16 phases in the 4-Tap polyphase filter for the exemplary embodiment.
- the VPF Controller 702 at the beginning of a field or frame, resets the vertical polyphase filter, provides control timing to the first and second multiplexer networks, selects coefficient sets from Luminance Coefficient RAM 704 and Chrominance Coefficient RAM 724 for the polyphase filter phases, and includes a counter which counts each line of the field or frame as it is processed.
- the VPF Controller 702 in addition to coordinating the operation of the network of MUXs and the polyphase filters, keeps track of display lines by tracking the integer and fractional parts of the vertical position in the decoded picture.
- the integer part indicates which lines should be accessed and the fractional part indicates which filter phase should be used.
- use of modulo N arithmetic when calculating the fractional part allows less than 16 phases to be used, which may be efficient for exact downsampling ratios such as 9 to 5.
- the fractional part is always truncated to one of the modulo N phases that are being used.
- luminance and chrominance pixel pairs from the four image lines are separated into a chrominance path and a luminance path.
- the 16 bit pixel pair data in the luminance path may be further multiplexed into an 8-bit even (Y-even) and 8-bit odd (Y-odd) format by LP MUXs 706 , 708 , 710 , and 712 , and the 16 bit pixel pair in the chrominance path into an 8-bit C R and 8-bit C B format by CP MUXs 714 , 716 , 718 and 720 .
- the luminance filter MUXs 706 , 708 , 710 and 712 are used to repeat pixel values of a line at the top and a line at the bottom at the boundaries of a decoded image in order to allow filter pixel boundary overlap in the polyphase filter operation.
- Pixel pairs for the four lines corresponding to luminance pixel information and chrominance pixel information are then passed through the respective polyphase filters.
- Coefficients used by Multipliers 742 , 744 , 746 and 748 for weighting of pixel values for a filter phase are selected by the VPF Controller 702 based on a programmed up or down sampling factor. After combining the weighted luminance pixel information in Adders 760 , 762 and 764 , the value is applied to the Round and Clip processor 772 which provides eight bit values (since the coefficient multiplication occurs with higher accuracy).
- DEMUX register 774 receives the first 8 bit value corresponding to an interpolated 8 bit even (Y-even) luminance value and second 8-bit value corresponding to the interpolated 8-bit odd (Y-odd) value, and provides a vertical filtered luminance pixel pair in 16 bits.
- Register 780 collects and provides the vertical filtered pixels in the luminance and chrominance paths and provides them as vertically filtered 32 bit values containing a luminance and chrominance pixel pair.
- FIG. 7B shows the spatial relationships between the coefficients and pixel sample space of the lines.
- the coefficients for the luminance and chrominance polyphase filter paths each have 40 bits allocated to each coefficient set, and there is one coefficient set for each phase.
- the coefficients are interpreted as fractions with a denominator of 512 .
- the coefficients are placed in the 40-bit word from left to right, C0 to C3.
- C0 and C3 are signed ten bit 2's complement values
- C1 and C2 are 10 bits which have a given range, for example, from ⁇ 256 to 767, which are each subsequently converted to 11-bit 2's complement values.
- FIG. 7A includes an optional luminance coefficient adjustment 782 and chrominance coefficient adjustment 784 . These coefficient adjustments 782 and 784 are used to derive the 11 bit 2's complement number for C1 and C2. If bits 8 and 9(the most significant bit) are both 1, then the sign of the eleven bit number is 1 (negative), otherwise the value is positive.
- FIG. 8A is a high level block diagram illustrating an exemplary filter suitable for use as the HZPF 284 of one embodiment of the present invention.
- HZPF 284 receives a luminance and chrominance pixel information pair, which may be 32-bit data, from the VPD 282 .
- the HZPF 284 includes a HZPF Controller 802 ; C R latches 804 ; C B latches 806 ; Y latches 808 ; Selection MUXs 810 ; Horizontal Filter Coefficient RAM 812 ; Multiplying network 814 ; Adding network 816 ; Round and Clip processor 818 , DEMUX register 820 and output register 822 .
- Horizontal resampling is accomplished by employing an 8 tap, 8 phase polyphase filter.
- Generation of display pixels is coordinated by the HZPF Controller 802 by tracking the integer and fractional parts of the horizontal position in the decoded and downsampled picture.
- the integer part indicates which pixels are to be accessed and the fractional part indicates which filter phase should be used.
- modulo N arithmetic when calculating the fractional part may allow for less than 8 phases to be used. For example, this may be useful if an exact downsampling ratio such as 9 to 5 is used. If the down-sampling ratio cannot be expressed as a simple fraction, the fractional part is truncated to one of the N phases.
- the HZPF 284 of the exemplary embodiment of the present invention filters pixel pairs, and uses alignment on even pixel boundaries to facilitate processing of the 4:2:0 formatted picture and to keep the C R and C B pixels (the color pixels) together with the corresponding Y pixels.
- the HZPF Controller 802 at the beginning of a horizontal line, resets the horizontal polyphase filter, provides control timing to the first and second multiplexer networks, selects coefficient sets from Horizontal Coefficient RAM 812 for the C R , C B and Y filter coefficients for each of the polyphase filter phases, and selects each set of C R , C B and Y values for processing.
- the HZPF Controller 802 forces the edge pixel values to be repeated or set to 0 for use by the 8-tap polyphase filter. Any distortion in the image caused by this simplification is usually hidden in the overscan portion of the displayed image.
- the pixel data received from the VPF 282 is separated into Y, C R and C B values, and these values are individually latched into C R latches 804 ; C B latches 806 ; and Y latches 808 for filtering.
- the HZPF Controller 802 selects the Y, C R and C B values by an appropriate signal to the selection MUXs 810 .
- the HZPF Controller 802 selects the appropriate filter coefficients for the filter phase, and for the C R or C B or Y values, based on a programmed upsampling or downsampling value by a control signal to Horizontal Filter Coefficient RAM 812 .
- Horizontal Filter Coefficient RAM 812 then outputs the coefficients to the respective elements of the Multiplying Network 814 for multiplication with the input pixel values to produce weighted pixel values, and the weighted pixel values are combined in Adding Network 816 to provide a horizontally filtered C R , C B or Y value.
- the horizontally filtered pixel value is applied to the Round and Clip processor which provides eight-bit values (since the coefficient multiplication occurs with higher accuracy).
- DEMUX register 820 receives a series of 8 bit values corresponding to a C R value, an 8 bit even (Y-even) Y value, an eight-bit C B value, and finally an eight-bit value corresponding to an 8-bit odd (Y-odd) Y value; and the DEMUX register 820 multiplexes the values into a horizontally filtered luminance and chrominance pixel pair having a 32 bit value (Y even, C R , Y odd, C B ).
- Register 822 stores and provides the pixel pair as a vertically and horizontally filtered 32 bit pixel luminance and chrominance pixel pair.
- FIG. 8B illustrates the spatial relationships between coefficients stored in Horizontal Filter Coefficient RAM 812 and used in the polyphase filter and the pixel sample values of the down sampled image for a horizontal line.
- the coefficients for the exemplary embodiment are placed in a 64 bit word from left to right, C0 to C7.
- the coefficients C0, C1, C6 and C7 are signed 7-bit 2's complement values
- C2 and C5 are signed 8-bit 2's complement
- C3 and C4 are signed 10-bit 2's complement values representing a range from ⁇ 256 to 767.
- C3 and C4 are adjusted to derive the 11-bit 2's complement values. If both bit 8 and bit 9 (the most significant bit) are 1, then the sign of the 11-bit value is 1 (negative), otherwise the value is 0 (positive). All coefficients can be interpreted as fractions with a denominator of 512.
- Table 13 lists coefficient for the VPF 282 and HZPF 284 for exemplary embodiments of the present invention performing the indicated format conversion. TABLE 13 Coefficients for 750P to 525P or 750P to 525I 4 tap and 2 polyphase Luminance Vertical Filter Tap 0 Tap 1 Tap 2 Tap 3 Phase 0 103 306 103 0 Phase 1 10 246 246 10
- horizontal conversion is, in part performed by the DCT domain filter 216 , and the downsampling Processor 232 shown in FIG. 2B. These provide the same number of horizontal pixels ( 640 ) whether the conversion is from 1125I or 750P. Accordingly, the HZPF 284 upsamples these signals to provide 720 active pixels per line and passes 525P or 525I signals unmodified, as these signals have 720 active pixels per line as set forth above in Tables 1 and 2, the values of the coefficients of the Horizontal Filter do not change for conversion to 480P/480I/525P/525I. These Horizontal filter coefficients are given in Table 14.
- FIG. 9A illustrates a resampling ratio profile which may be employed with the present invention.
- the resampling ratio of the HZPF 284 may be varied across the horizontal scan line and may be changed in piecewise linear fashion.
- the resampling ratio increases (or decreases) linearly until a first point on the scan line, where the resampling ration is held constant until a second point is reached where the resampling ratio decreases (or increases) linearly.
- h_initial_resampling ratio is the initial resampling ratio for a picture
- h_resampling_ratio_change is the first change per pixel in the resampling ratio
- —h_resampling_ratio_change is the second change per pixel in the resampling ratio
- h_resampling_ratio_hold column and h_resampling_ratio_reverse_column are the display column pixel points between which the resampling ratio is held constant.
- the value display_width is the last pixel (column) of the picture line.
- FIGS. 9B and 9C show ratio profiles for mapping a 4:3 picture onto a 16:9 display.
- the ratios are defined in terms of input value to output value, so 4/3 is downsampling by 4 to 3 and 1/3 is up sampling 1 to 3.
- the ratio profiles shown in FIGS. 9B and 9C map an input picture image having 720 active pixels to a display having 720 active pixels.
- mapping a 4:3 aspect ratio display to a 16 ⁇ 9 aspect ratio display uses a 4/3 downsampling, but to fill all the samples of the display requires a 1/1 average across the horizontal line. Consequently, the profile of FIG.
- FIGS. 9B and 9E illustrate the profiles used for resizing from a 16 ⁇ 9 display image to a 4:3 display which is the inverse of the profiles shown in FIGS. 9B and 9C.
- FIG. 10 The effect of using resampling ratio profiles according to an exemplary embodiment of the present invention may be seen pictorially in FIG. 10.
- a video transmission format having either a 16 ⁇ 9 or 4 ⁇ 3 aspect ratio may be displayed as either 16 ⁇ 9 or 4 ⁇ 3, but the original video picture may be adjusted to fit within the display area. Consequently, the original video picture may be shown in full, zoom, squeeze, or variable expand/shrink.
- the system allows users to select a preferred mapping between the aspect ratio of the received video signal and the aspect ratio of the display device, when these aspect ratios are incompatible.
- the control processor 207 receives the aspect ratio of the received image from the parser 209 .
- the control processor 207 also determines the aspect ratio of the display device (not shown) which is connected to receive the output signal of the system. If, for example, the display device is connected to the S-video output 153 or the composite video output 154 (both shown in FIG. 1A), then the aspect ratio of the display device must be 4 by 3. If, however, the display device is connected to the primary video output port 146 , the aspect ratio may be either 4 by 3 or 16 by 9.
- the user specifies the aspect ratio of the display device as a part of a start-up process which may be invoked through the remote control IR receiver 208 (shown in FIG. 2A).
- the start up process may only be run if the video decoder system includes a primary output port and the system senses that there is a display device coupled to the primary output port.
- the start-up process may determine the display format of the display device (i.e. aspect ratio and maximum video resolution) in several ways. First, the process may present the user with a menu of possible display devices, each represented, for example, by a manufacturer name and model number. The user may then use the remote control device to select one of these display devices.
- the decoder system may be configured with a modem to periodically contact a central location to receive an updated list of display types as well as other updates to the programming of the controller 207 .
- this type of information may be encoded in the user data of a received ATSC video signal and the decoder may be programmed to access this information to update its internal programming.
- the user may be presented with a menu showing a 4 by 3 rectangle and a 16 by 9 rectangle and asked to indicate which is more like their display device.
- the user may asked to choose two menu choices, one listing possible video display resolutions and another listing possible aspect ratios.
- control processor 207 may program the on-screen display generator to produce a figure, for example a circle, in several different signal resolutions (e.g. 525I, 525P, 750P, 1180I and 1180P) and several different aspect ratios (e.g. 4 by 3 and 16 by 9), with text asking the viewer to press a button on the remote control device (not shown) when the best circle is displayed.
- the system may sequentially provide each of these images for a few seconds at the primary output to correlate the pressing of the button on the remote control device with the display of a particular image. This will provide the system with the needed information on image resolution and aspect ratio for the display device.
- the system may automatically adapt the received video signal for the best possible presentation on the display device.
- this may be indicated to the viewer and the viewer may be allowed, by invoking a command using the remote control device (not shown), to sequentially see all of the possible conversions between the two aspect ratios, as shown in FIGS. 9A through 9E and FIG. 10, and to select one of these conversions to be used.
- the aspect ratio of the received video signal is 4 by 3 and the aspect ratio of the display device is 16 by 9 as well as when the aspect ratio of the received video signal is 16 by 9 and the aspect ratio of the display device is 4 by 3.
- the system may be configured to sense information provided by the display device in order to determine the display format.
- a two-way data path may be provided via one of the output signal lines (Y, CR, CB) of the decoder system by which data in a digital register in the display device may be read.
- the data in this register may indicate a manufacturer and model number or a maximum resolution and aspect ratio for the display device.
- the display device may impose a direct-current (DC) signal on one or more of these lines and this signal may be sensed by the decoder system as an indication of the display format of the display device.
- DC direct-current
- a multi-sync monitor which is capable of displaying video signals having several different display formats may be connected to the primary output port of the video decoder.
- the video resolution component of the display type information recovered by the control processor 207 desirably includes an indication that the display is a multi-sync device so that the only format conversion that occurs is the aspect ratio adaptation shown in FIGS. 9A through 9E and FIG. 10, when the aspect ratio of the received video signal does not match that of the display device.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
A video monitor including circuitry that provides information regarding characteristics of the monitor to an external video source. The circuitry may be a register that holds data from which the aspect ratio and resolution of the display may be derived.
Description
- This patent application is a divisional of U.S. patent application Ser. No. 09/180,243, filed Apr. 5, 1999 which claims the benefit PCT Application number US98/04749, filed Mar. 11, 1998 which claim the benefit of of U.S. Provisional Application No. 60/040,517 filed Mar. 12, 1997.
- This invention relates to a decoder for receiving, decoding and conversion of frequency domain encoded signals, e.g. MPEG-2 encoded video signals, into standard output video signals, and more specifically to a decoder which converts and formats an encoded high resolution video signal to a decoded lower resolution output video signal.
- In the United States a standard, the Advanced Television System Committee (ATSC) standard defines digital encoding of high definition television (HDTV) signals. A portion of this standard is essentially the same as the MPEG-2 standard, proposed by the Moving Picture Experts Group (MPEG) of the International Organization for Standardization (ISO). The standard is described in an International Standard (IS) publication entitled, “Information Technology—Generic Coding of Moving Pictures and Associated Audio, Recommendation H.626”, ISO/IEC 13818-2, IS, 11/94 which is available from the ISO and which is hereby incorporated by reference for its teaching on the MPEG-2 digital video coding standard.
- The MPEG-2 standard is actually several different standards. In MPEG-2 several different profiles are defined, each corresponding to a different level of complexity of the encoded image. For each profile, different levels are defined, each level corresponding to a different image resolution. One of the MPEG-2 standards, known as Main Profile, Main Level is intended for coding video signals conforming to existing television standards (i.e., NTSC and PAL). Another standard, known as Main Profile, High Level is intended for coding high-definition television images. Images encoded according to the Main Profile, High Level standard may have as many as 1,152 active lines per image frame and 1,920 pixels per line.
- The Main Profile, Main Level standard, on the other hand, defines a maximum picture size of 720 pixels per line and 567 lines per frame. At a frame rate of 30 frames per second, signals encoded according to this standard have a data rate of 720 *567*30 or 12,247,200 pixels per second. By contrast, images encoded according to the Main Profile, High Level standard have a maximum data rate of 1,152*1,920*30 or 66,355,200 pixels per second. This data rate is more than five times the data rate of image data encoded according to the Main Profile Main Level standard. The standard for HDTV encoding in the United States is a subset of this standard, having as many as 1,080 lines per frame, 1,920 pixels per line and a maximum frame rate, for this frame size, of 30 frames per second. The maximum data rate for this standard is still far greater than the maximum data rate for the Main Profile, Main Level standard.
- The MPEG-2 standard defines a complex syntax which contains a mixture of data and control information. Some of this control information is used to enable signals having several different formats to be covered by the standard. These formats define images having differing numbers of picture elements (pixels) per line, differing numbers of lines per frame or field and differing numbers of frames or fields per second. In addition, the basic syntax of the MPEG-2 Main Profile defines the compressed MPEG-2 bit stream representing a sequence of images in five layers, the sequence layer, the group of pictures layer, the picture layer, the slice layer, and the macroblock layer. Each of these layers is introduced with control information. Finally, other control information, also known as side information, (e.g. frame type, macroblock pattern, image motion vectors, coefficient zig-zag patterns and dequantization information) are interspersed throughout the coded bit stream.
- Format conversion of encoded high resolution Main Profile, High Level pictures to lower resolution Main Profile, High Level pictures; Main Profile, Main Level pictures, or other lower resolution picture formats, has gained increased importance for a) providing a single decoder for use with multiple existing video formats, b) providing an interface between Main Profile, high level signals and personal computer monitors or existing consumer television receivers, and c) reducing implementation costs of HDTV. For example, conversion allows replacement of expensive high definition monitors used with Main Profile, High Level encoded pictures with inexpensive existing monitors which have a lower picture resolution to support, for example, Main Profile, Main Level encoded pictures, such as NTSC or 525 progressive monitors. One aspect, down conversion, converts a high definition input picture into lower resolution picture for display on the lower resolution monitor.
- To effectively receive the digital images, a decoder should process the video signal information rapidly. To be optimally effective, the decoding systems should be relatively inexpensive and yet have sufficient power to decode these digital signals in real time. Consequently, a decoder which supports conversion into multiple low resolution formats must minimize processor memory.
- The present invention is embodied in a digital video signal processing system which receives, decodes and displays video signals that have been encoded in a plurality of different formats. The system includes a digital video decoder which may be controlled to decode the encoded video signal and, optionally, provide a reduced resolution version of the decoded video signal. The system processes the received encoded video signal to determine the format and resolution of the image which would be produced if the signal were decoded. The system includes a controller which receives the determined format and resolution information and which also receives information concerning the format and resolution of a display device on which the received image will be displayed. The controller then generates signals to cause the digital video decoder to provide an analog video signal having a resolution and aspect ratio that is appropriate for the display device.
- According to one aspect of the invention, the encoded video signals are encoded using a frequency-domain transform operation and the digital video decoder includes a low-pass filter which operates on the frequency-domain transformed digital video signal.
- According to another aspect of the invention, digital video decoder is coupled to a programmable spatial filter which is responsive to a control signal provided by the controller to resample the decoded digital video signal provided by the digital video decoder to produce a digital video signal which conforms to the aspect ratio and resolution of the display device.
- According to another aspect of the invention, the digital video signal is encoded according to using an encoding technique specified by the moving pictures experts group (MPEG) and the aspect ratio and resolution of the encoded video signal are extracted from the header of a packetized elementary stream (PES) packet received by the digital video decoder.
- According to another aspect of the invention, the digital video signal is encoded according to using an encoding technique specified by the moving pictures experts group (MPEG) and the aspect ratio and resolution of the encoded video signal are extracted from a sequence header of a video bit-stream received by the digital video decoder.
- According to another aspect of the invention, the system includes a user input device through which a user may configure the system to produce an output video signal which is compatible with the display device.
- According to another aspect of the invention, the system includes apparatus which automatically determines the aspect ratio and resolution of the display device.
- According to another aspect of the invention, the system includes apparatus which sequentially produces video signals corresponding to a plurality of display device types and is responsive to a selection signal provided by a user to identify one of the display types as corresponding in resolution and aspect ratio to the display device.
- These and other features and advantages of the present invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, wherein:
- FIG. 1A is a high level block diagram of a video decoding and format conversion system according to an exemplary embodiment of the present invention.
- FIG. 1B is a high level block diagram showing the functional blocks of the ATV Video Decoder including an interface to external Memory as employed in an exemplary embodiment of the present invention.
- FIG. 2A is a high level block diagram of a video decoder of the prior art.
- FIG. 2B is a high level block diagram of the down conversion system as employed by an exemplary embodiment of the present invention.
- FIG. 2C is a block diagram which illustrates a configuration of the decoder shown in FIG. 2B which is used to decode a video signal in 1125I format including a downconversion by factor of 3 to 525P/525I format.
- FIG. 2D is a block diagram which illustrates a configuration of the decoder shown in FIG. 2B which is used to decode a video signal in 750P format including a downconversion by factor of 2 to 525P/525I format.
- FIG. 3A is a pixel chart which illustrates subpixel positions and corresponding predicted pixels for the 3:1 and 2:1 exemplary embodiments of the present invention.
- FIG. 3B is a flow-chart diagram which shows the upsampling process which is performed for each row of an input macroblock for an exemplary embodiment of the present invention.
- FIG. 4 is a pixel chart which illustrates the multiplication pairs for the first and second output pixel values of an exemplary embodiment of a block mirror filter.
- FIG. 5 is a block diagram which illustrates an exemplary implementation of the filter for down-conversion for a two-dimensional system processing the horizontal and vertical components implemented as cascaded one-dimensional IDCTs.
- FIG. 6A is a macroblock diagram which shows the input and decimated output pixels for 4:2:0 video signal using 3:1 decimation.
- FIG. 6B is a pixel block diagram which shows the input and decimated output pixels for 4:2:0 video signal using 2:1 decimation.
- FIG. 6C is a macroblock diagram which illustrates a merging process of two macroblocks into a single macroblock for storage in memory for downconversion by 2 horizontally.
- FIG. 6D is a macroblock diagram which illustrates a merging process of three macroblocks into a single macroblock for storage in memory for downconversion by 3 horizontally.
- FIG. 7A is a block diagram illustrating a vertical programmable filter of one embodiment of the present invention.
- FIG. 7B is a pixel diagram which illustrates the spatial relationships between vertical filter coefficients and a pixel sample space of lines of the vertical programmable filter of FIG. 7A.
- FIG. 8A is a block diagram illustrating a horizontal programmable filter of one embodiment of the present invention.
- FIG. 8B is a pixel diagram which illustrates spatial relationships between horizontal filter coefficients and pixel sample values of one embodiment of the present invention.
- FIG. 9A is a graph of pixel number versus resampling ratio which illustrates a resampling ratio profile of an exemplary embodiment of the present invention.
- FIG. 9B is a graph which shows a first ratio profile for mapping a 4:3 picture onto a 16:9 display.
- FIG. 9C is a graph which shows a second ratio profile for mapping a 4:3 picture onto a 16:9 display.
- FIG. 9D is a graph which shows a first ratio profile for mapping a 16:9 picture onto a 4:3 display.
- FIG. 9E is a graph which shows a second ratio profile for mapping a 16:9 picture onto a 4:3 display.
- FIG. 10 is a chart of image diagrams which illustrates the effect of using resampling ratio profiles according to an exemplary embodiment of the present invention.
- FIG. 11A is a high level block diagram illustrating the display section of the ATV Video Decoder of an exemplary embodiment of the present invention.
- FIG. 11B is a block diagram which illustrates a 27 MHz Dual output mode of an exemplary embodiment of the present invention which, for which the video data is 525P or 525I, a first processing chain provides video data to a 27 MHz DAC well as to an NTSC Encoder.
- FIG. 11C is a block diagram which illustrates that, in the 27 MHz single output mode of an exemplary embodiment of the present invention, only a 525I video signal is provided to a NTSC encoder.
- FIG. 11D is a block diagram which illustrates a 74 MHz /27 MHz mode of an exemplary embodiment of the present invention in which the output format matches the input format and the video data is provided to either a 27 MHz DAC or 74 MHz DAC depending on the input format.
- FIG. 12 is a high level block diagram of the video decoder having high bandwidth memory as employed by an exemplary embodiment of the present invention to decode ATSC video signals.
- System Overview
- The exemplary embodiments of the invention decode conventional HDTV signals which have been encoded according to the MPEG-2 standard and in particular, the Main Profile High Level (MP@HL) and the Main Profile Main Level (MP@ML) MPEG-2 standards, and provides the decoded signals as video signals having a lower resolution than that of the received HDTV signals and having a selected one of multiple formats.
- The MPEG-2 Main Profile standard defines a sequence of images in five levels: the sequence level, the group of pictures level, the picture level, the slice level, and the macroblock level. Each of these levels may be considered to be a record in a data stream, with the later-listed levels occurring as nested sub-levels in the earlier listed levels. The records for each level include a header section which contains data that is used in decoding its sub-records.
- Each macroblock of the encoded HDTV signal contains six blocks and each block contains data representing 64 respective coefficient values of a discrete cosine transform (DCT) representation of 64 picture elements (pixels) in the HDTV image.
- In the encoding process, the pixel data may be subject to motion compensated differential coding prior to the discrete cosine transformation and the blocks of transformed coefficients are further encoded by applying run-length and variable length encoding techniques. A decoder which recovers the image sequence from the data stream reverses the encoding process. This decoder employs an entropy decoder (e.g. a variable length decoder), an inverse discrete cosine transform processor, a motion compensation processor, and an interpolation filter.
- The video decoder of the present invention is designed to support a number of different picture formats, while requiring a minimum of decoding memory for downconversion of high resolution encoded picture formats, for example, 48 Mb of Concurrent Rambus dynamic random access memory (Concurrent RDRAM).
- FIG. 1A shows a system employing an exemplary embodiment of the present invention for receiving and decoding encoded video information at MP@HL or at MP@ML, formatting the decoded information to a user selected output video format (which includes both video and audio information), and interfaces for providing the formatted video output signals to display devices. The exemplary embodiments of the present invention are designed to support all ATSC video formats; and in a Down Conversion (DC) mode the present invention receives any MPEG Main Profile video bitstream (constrained by FCC standards) and provides a 525P, 525I or NTSC format picture.
- The exemplary system of FIG. 1A includes a
front end interface 100, avideo decoder section 120 and associatedDecoder Memory 130, a primaryvideo output interface 140, anaudio decoder section 160, anoptional computer interface 110, and an optional NTSCvideo processing section 150. - Referring to FFIG. 1A, the exemplary system includes a
front end interface 100, having a transport decoder andprocessor 102 with associatedmemory 103. Also included may be anoptional multiplexer 101 for selecting received control information and computer generated images from thecomputer interface 110 at, for example, theIEEE 1394 link layer protocol or for recovering an encoded transport stream from a digital television tuner (not shown). Thetransport decoder 102 converts the received compressed data bit stream from the communication channel bit stream into compressed video data, which may be, for example, packetized elementary streams (PES) packets according to MPEG-2 standard. The transport decoder may provide either the PES packets directly, or may further convert the PES packets into one or more elementary streams. - The video decoder section includes an
ATV Video Decoder 121 and phase-locked loop (PLL) 122. TheATV video Decoder 121 receives an elementary stream or video (PES) packets from thefront end interface 100, from the front end interface and converts the packets to the elementary stream. A front end picture processor of theATV Video Decoder 121 then decodes the elementary streams according to the encoding method used, to provide luminance and chrominance pixel information for each image picture. ThePLL 122 synchronizes the audio and video processing performed by the system shown in FIG. 1A. - The
ATV Video Decoder 121 further includes a memory subsystem to control decoding operations using an external memory which provides image picture information and a display section to process decoded picture information into a desired picture format. TheATV Video Decoder 121 employs theDecoder Memory 130 to process the encoded video signal. TheDecoder Memory 130 includesmemory units 131, 132, 133, 134, 135 and 136, which may each be a 16 Mb RDRAM memory. Exemplary embodiments the present invention are subsequently described with respect to, and implemented within, thevideo decoder section 120 andDecoder Memory 130. - The primary
video output interface 140 includes a first Digital to Analog (D/A) converter (DAC) 141 (which actually has three D/A units for the luminance signal and the CR and CB chrominance signals) which may operate at 74 MHz, followed by afilter 142. This interface produces analog video signals having a 1125I or 750P format. Theinterface 140 and also includes a second (D/A) converter (DAC) 143 (also with three D/A units for luminance signal and CR and CB chrominance signals) which may operate at 27 MHz, followed by afilter 142 for video signals having a 525I or 525P format. The primaryvideo output interface 140 converts the digitally encoded video signals having a desired format, creates an analog video signal having chrominance and luminance components with the desired format using a (D/A) converter, and filters the analog video signal to remove sampling artifacts of the D/A conversion process. - The
audio decoder section 160 includes anAC3 Audio decoder 162 which provides audio signals atoutput ports processor 161 to provide 2 channel audio signals atoutput port 165. The audio processing of MP@HL MPEG-2 standard audio signal components from encoded digital information to analog output atoutput ports decoder 160 is a ZR38500 Six Channel Dolby Digital Surround Processor, available from the Zoran Corporation of Santa Clara, Calif. - The
optional computer interface 110 transmits and receives computer image signals which conform, for example, to theIEEE 1394 standard. Thecomputer interface 110 includes aphysical layer processor 111 andlink layer processor 112. Thephysical layer processor 111 converts electrical signals fromoutput port 113 into received computer generated image information and control signals, and provides these signals, for decoding by thelink layer processor 112 intoIEEE 1394 formatted data. Thephysical layer processor 111 also converts received control signals encoded by thelink layer processor 112 originating from thetransport decoder 102 into electrical output signals according to theIEEE 1394 standard. - The NTSC
video processing section 150 includes an optional ATV-NTSC Downconversion processor 151 which converts the analog HDTV signal provided by thefilter 142 into a 525 I signal. This conversion between standards is known in the art and may be accomplished using spatial filtering techniques such as those disclosed in, for example, U.S. Pat. No. 5,613,084 to Hau et al. entitled INTERPOLATION FILTER SELECTION CIRCUIT FOR SAMPLE RATE CONVERSION USING PHASE QUANTIZATION, which is incorporated herein by reference. In the exemplary embodiment of the invention, this processing section is used only when the decoder processes a 1080I or 1125I signal. - The
NTSC encoder 152 receives a 525I analog signal either from theprocessor 151 or directly from thedecoder 120, and converts the signal to the NTSC formatted video signal at output ports 153 (S-video) and 154 (composite video). - Video Decoder Section Employing Decoder Memory
- FIG. 1B is a high level block diagram showing the functional blocks of the
ATV Video Decoder 121 including an interface toexternal Memory 130 as employed in an exemplary embodiment of the present invention. TheATV Video Decoder 121 includes aPicture Processor 171, aMacroblock Decoder 172, aDisplay section 173, and aMemory subsystem 174. ThePicture processor 171 receives, stores and partially decodes the incoming MPEG-2 video bitstream and provides the encoded bitstream, on-screen display data, and motion vectors, which may be stored inmemory 130 under the control of theMemory subsystem 174. TheMacroblock Decoder 172 receives the encoded bitstream, motion vectors, and stored motion compensation reference image data, if predictive encoding is used, and provides decoded macroblocks of the encoded video image to thememory subsystem 174. TheDisplay Section 173 retrieves the decoded macroblocks from theMemory subsystem 174 and formats these into the video image picture for display. The operation of these sections is described in detail below. - Main Profile Format Support for Picture Processing
- The
ATV video decoder 121 of the present invention is designed to support all ATSC video formats. For simplicity, the operation of theATV video decoder 121 is termed Down Conversion (DC), andATV video decoder 121 receives any MPEG Main Profile video bitstreams shown in Table 1 and provides a 525P, 525I or NTSC format video signal. For the exemplary video decoder of FIG. 1A, in DC mode, any HDTV or SDTV signal is decoded and a display output signal provided at either of two ports, with port one providing either a progressive or interlaced image, and port two providing an interlaced image.TABLE 1 Video Bitstream Formats Number and Format Horizontal Vertical Aspect Ratio Frame rate (Hz) (1) 1125I 1920 1080 16 × 9 30, 29.97 (2) 1125P 1920 1080 16 × 9 30, 29.97, 24, 23.98 (3) 750P 1280 720 16 × 9 60, 59.94, 30, 29.97, 24, 23.98 (4) 525P 704 480 16 × 9 60, 59.94, 30, 29.97, 24, 23.98 (5) 525P 704 480 4 × 3 60, 59.94, 30, 29.97, 24, 23.98 (6) 525P 640 480 4 × 3 60, 59.94, 30, 29.97, 24, 23.98 (7) 525I 704 480 16 × 9 30, 29.97 (8) 525I 704 480 4 × 3 30, 29.97 (9) 525I 640 480 4 × 3 30, 29.97 - In DC mode, low pass filtering of the high frequency components of the Main Level picture occurs as part of the decoding process to adjust the resolution of the high resolution picture to a format having a lower resolution. This operation includes both horizontal and vertical filtering of the high resolution picture. Note that in DC Mode, the display format conversion may display 16×9 aspect ratio sources on 4×3 displays, and vice-versa. This process is described subsequently with reference to the display section of the
video decoder section 120. Table 2 gives the supported primary and secondary output picture formats for the respective input bitstreams of Table 1:TABLE 2 DC Supported Video Formats Number and Primary Output Secondary Output Format Format Format Display Clock (MHz) (1) 1125I 525P 525I 27.00 (2) 1125P 525P 525I 27.00 (3) 750P 525P 525I 27.00 (4) 525P 525P 525I 27.00 (5) 525P 525P 525I 27.00 (6) 525P 525P 525I 27.00 (7) 525I 525P 525I 27.00 (8) 525I 525P 525I 27.00 (9) 525I 525P 525I 27.00 - b) Decoding, Downconversion and Downsampling
- 1) Overview
- FIG. 2A is a high level block diagram of a typical video decoding system of the prior art which processes an MPEG-2 encoded picture. The general methods used to decode an MPEG-2 encoded picture, without subsequent processing, downconversion or format conversion, are specified by the MPEG-2 standard. The video decoding system includes an entropy decoder (ED)211, which may include a
parser 209, a variable length decoder (VLD) 210 and runlength decoder 212. The system also includes aninverse quantizer 214, and inverse discrete cosine transform (IDCT)processor 218. AController 207 controls the various components of the decoding system responsive to the control information retrieved from the input bit stream by theED 211. For processing of prediction images, the system further includes amemory 199 havingreference frame memory 222, summingnetwork 230, andMotion Compensation Processor 206 a which may have amotion vector processor 221 and half-pixel generator 228. - The
controller 207 is coupled to aninfrared receiver 208 which receives command signals provided by, for example, a user remote control device. Thecontroller 207 decodes these commands and causes the remainder of the system shown in FIG. 2A to perform the specified command. In the exemplary embodiment of the invention, the system shown in FIG. 2A includes a set-up mode in which the user may specify a configuration for the system. In one exemplary embodiment of the invention, this configuration may include the specification of a display device type. It is contemplated that the display device type may be specified in terms of display resolution and aspect ratio. The user may specify the display type by selecting a particular display aspect ratio and resolution from a menu of possible choices or by causing the system to enter a mode in which signals corresponding to different display formats are successively provided to the display device and the user is asked to indicate, via the remote control device, which display is most pleasing. During normal operation, thecontroller 207 also receives information on the resolution and aspect ratio of the encoded video signal from theparser 209 of theED 211. Using this information and the stored information relating to the resolution and aspect ratio of the display device, thecontroller 207 automatically configures the system to process the received encoded signal to produce an analog output signal appropriate for display on the display device. - The
parser 209 scans the received bit stream for MPEG start codes. These codes include a prefix which has a format of 23 consecutive zero-valued bits followed by a single bit having a value of one. The start code value follows this prefix and identifies the type of record that is being received. In the exemplary embodiment of the invention, when theparser 209 stores the bit stream into thememory 199 and the bit stream is then supplied from thememory 199 to the VLD for further processing. In the block diagram shown in FIG. 2A, this has been shortened to show the parser providing the bit stream directly to the VLD. - When the
parser 209 finds a start code in the bit stream, it passes the bit stream onto thememory 199 for storage in the VBV buffer and also stores a pointer to the start code in an area of thememory 199 which is accessed by thecontroller 207. Thecontroller 207 continually accesses the start code pointers and, through them, the record headers. When thecontroller 207 finds a sequence start code, it accesses information in the sequence header which indicates the aspect ratio and resolution of the image sequence that is represented by the encoded sequence. According to the MPEG standard, this information immediately follows the sequence start code in the sequence header. - Information on the display format of the encoded video signal (i.e. its resolution and aspect ratio) is also contained in the headers of the packetized elementary stream (PES) packets. It is contemplated that in another exemplary embodiment of the invention, the
parser 209 may receive PES packets, strip the headers from them to reconstruct the bit stream and pass this header information, including the display format of the received video signal, to thecontroller 207. - As described below, the
controller 207 uses information on the display format of the received video signal and information on the display format of the display device (not shown) which is connected to the decoder system to automatically or semiautomatically adjust the processing of the received video signal for proper display on the display device. - The
VLD 210 receives the encoded bit stream from theparser 209 via the VBV buffer (not shown) in thememory 199, and reverses the encoding process to produce macroblocks of quantized frequency-domain (DCT) coefficient values. TheVLD 210 also provides control information including motion vectors describing the relative displacement of a matching marcoblock in a previously decoded image which corresponds to a macroblock of the predicted picture that is currently being decoded. TheInverse Quantizer 214 receives the quantized DCT transform coefficients and reconstructs the quantized DCT coefficients for a particular macroblock. The quantization matrix to be used for a particular block is received from theED 211. - The
IDCT processor 218 transforms the reconstructed DCT coefficients to pixel values in the spatial domain (for each block of 8×8 matrix values representing luminance or chrominance components of the macroblock, and for each block of 8×8 matrix values representing the differential luminance or differential chrominance components of the predicted macroblock). - If the current macroblock is not predictively encoded, then the output matrix values provided by the
IDCT Processor 218 are the pixel values of the corresponding macroblock of the current video image. If the macroblock is interframe encoded, the corresponding macroblock of the previous video picture frame is stored inmemory 199 for use by the Motion Compensation processor 206. The Motion Compensation Processor 206 receives a previously decoded macroblock frommemory 199 responsive to the motion vector, and then adds the previous macroblock to the current IDCT macroblock (corresponding to a residual component of the present predictively encoded frame) in summingnetwork 230 to produce the corresponding macroblock of pixels for the current video image, which is then stored into thereference frame memory 222. - FIG. 2B is a high level block diagram of the down conversion system of one exemplary embodiment of the present invention employing such a DCT filtering operation, and which may be employed by an exemplary embodiment of the present invention in DC mode. As shown in FIG. 2B, the down conversion system includes a variable length decoder (VLD)210, a run-length (R/L)
decoder 212, aninverse quantizer 214, and inverse discrete cosine transform (IDCT)processor 218. In addition, the down conversion system includes aDown Conversion filter 216 for filtering encoded pictures and aDown Sampling processor 232. While the following describes the exemplary embodiment for a MP@HL encoded input, the present invention may be practiced with any similarly encoded high-resolution image bit stream. - The down conversion system also includes a
Motion Compensation Processor 206 b including a Motion Vector (MV)Translator 220, aMotion Block Generator 224 including an Up-Sampling Processor 226, Half-Pixel Generator 228, and aReference Frame Memory 222. - The system of the first exemplary embodiment of FIG. 2B also includes a
Display Conversion Block 280 having a Vertical Programmable Filter (VPF) 282 and Horizontal Programmable Filter (HZPF) 284. TheDisplay Conversion Block 280 converts downsampled images into images for display on a particular display device having a lower resolution than the original image, and is described in detail subsequently in section d)(2) on Display Conversion. - The
Down Conversion Filter 216 performs a lowpass filtering of the high resolution (e.g. Main Profile, High Level DCT) coefficients in the frequency domain. TheDown Sampling Process 232 eliminates spatial pixels by decimation of the filtered Main Profile, High Level picture to produce a set of pixel values which can be displayed on a monitor having lower resolution than that required to display a MP@HL picture. The exemplaryReference Frame Memory 222 stores the spatial pixel values corresponding to at least one previously decoded reference frame having a resolution corresponding to the down-sampled picture. For interframe encoding, theMV Translator 220 scales the motion vectors for each block of the received picture consistent with the reduction in resolution, and the High ResolutionMotion Block Generator 224 receives the low resolution motion blocks provided by theReference Frame Memory 222, upsamples these motion blocks and performs half-pixel interpolation as needed to provide motion blocks which have pixel positions that correspond to the decoded and filtered differential pixel blocks. - Note that in the down conversion system of FIG. 1B the downsampled images are stored rather than high definition images, resulting in a considerable reduction of memory required for storing reference images.
- The operation of an exemplary embodiment of the down-conversion system of the present invention for intra-frame encoding is now described. The MP@HL bit-stream is received and decoded by
VLD 210. In addition to header information used by the HDTV system, theVLD 210 provides DCT coefficients for each block and macroblock, and motion vector information. The DCT coefficients are run length decoded in the R/L decoder 212 and inverse quantized by theinverse quantizer 214. - Since the received video image represented by the DCT coefficients is a high resolution picture, the exemplary embodiment of the present invention employs lowpass filtering of the DCT coefficients of each block before decimation of the high resolution video image. The
inverse quantizer 214 provides the DCT coefficients to theDCT filter 216 which performs a lowpass filtering in the frequency domain by weighting the DCT coefficients with predetermined filter coefficient values before providing them to theIDCT processor 218. For one exemplary embodiment of the present invention, this filter operation is performed on a block by block basis. - The
IDCT processor 218 provides spatial pixel sample values by performing an inverse discrete cosine transform of the filtered DCT coefficients. TheDown Sampling processor 232 reduces the picture sample size by eliminating spatial pixel sample values according to a predetermined decimation ratio; therefore, storing the lower resolution picture uses a smaller frame memory compared to that which would be needed to store the higher resolution MP@HL picture. - The operation of an exemplary embodiment of the down-conversion system of the present invention for predicted frames of the encoding standard is now described. In this example, the current received image DCT coefficients represent the DCT coefficients of the residual components of the predicted image macroblocks, which is now referred to as a predicted frame (P-frame) for convenience. In the described exemplary embodiment, the horizontal components of the motion vectors for a predicted frame are scaled since the low resolution reference pictures of previous frames stored in memory do not have the same number of pixels as the high resolution predicted frame (MP@HL).
- Referring to FIG. 2B, the motion vectors of the MP@HL bit stream provided by the
VLD 210 are provided to theMV Translator 220 Each motion vector is scaled by theMV Translator 220 to reference the appropriate prediction block of the reference frame of a previous image stored inreference frame memory 222 ofmemory 199. The size (number of pixel values) in the retrieved block is smaller than block provided by theIDCT processor 218; consequently, the retrieved block is upsampled to form a prediction block having the same number of pixels as the residual block provided by theIDCT Processor 218 before the blocks are combined by the summingnetwork 230. - The prediction block is upsampled by the Up-
Sampling Processor 226 responsive to a control signal from theMV Translator 220 to generate a block corresponding to the original high resolution block of pixels, and then half pixel values are generated—if indicated by the motion vector for the up-sampled prediction block in theHalf Pixel Generator 228—to ensure proper spatial alignment of the prediction block. The upsampled and aligned prediction block is added in summingnetwork 230 to the current filtered block, which is, for this example, the reduced resolution residual component from the prediction block. All processing is done on a macroblock by macroblock basis. After the motion compensation process is complete for the current high-resolution macroblock, the reconstructed macroblock is decimated accordingly by theDown Sampling Processor 232. This process does not reduce the resolution of the image but simply removes redundant pixels from the low resolution filtered image. - Once the downsampled macroblocks for an image are available, the
Display Conversion Block 280 adjusts the image for display on a low resolution television display unit by filtering the vertical and horizontal components of the downsampled image inVPF 282 andHZPF 284 respectively. - The relationship between the functional blocks of the
ATV Video Decoder 121 of FIG. 1A and FIG. 1B is now described. Thepicture processor 171 of FIG. 1B receives the video picture information bitstreams. TheMacroblock Decoder 172 includesVLD 210,inverse quantizer 214, theDCT filter 216,IDCT 218, summingnetwork 230, and the motion compensatedpredictors picture processor 171 may share theVLD 210.External Memory 130 corresponds tomemory 199, with 16 Mb RDRAM 131-136 containing thereference frame memory 222. - FIG. 2C illustrates the operation of the system in DC mode, converting an 1125I signal to 525P/525I format. In this scenario, after low pass filtering by
DCT filter 216 as described above with reference to FIG. 2B, the system down samples the high resolution signal by a factor of 3, and stores the pictures in the 48 Mb memory as 640H and 1080 V, interlaced. For this system, the motion compensation process upsamples the stored pictures by a factor of 3 (as well as translation of the received motion vectors) before motion-predictive decoding is accomplished. Also, the picture is filtered horizontally and vertically for display conversion. - FIG. 2D similarly illustrates the relationship between DC mode format downconversion from 750P to 525P/525I format. This conversion operates in the same way as the 1125I to 525P/525I conversion except that downsampling for memory storage, and upsampling for motion compensation, is by a factor of 2.
- 2) Macroblock Prediction for Downconversion
- For the exemplary downconversion process, since the reference frames of the previous images are down sized in the horizontal direction, the received motion vectors pointing to these frames may also be translated according to the conversion ratio. The following describes the motion translation for the luminance block in the horizontal direction. One skilled in the art could easily extend the following discussion to motion translation in the vertical direction if desired. Denoting x and y as the current macroblock address in the original image frame, Dx as the horizontal decimation factor and mvx as the half pixel horizontal motion vector of the original image frame, the address of the top left pixel of the motion block in the original image frame, denoted as XH in the half pixel unit, is given by (1):
- XH=2x+mv x (1)
-
- The division of equation (2) is an integer division with truncation.
- Because the
exemplary filter 216 andDown Sampling Processor 232 only reduce the horizontal components of the image, the vertical component of the motion vector is not affected. For the chrominance data, the motion vector is one-half of a luminance motion vector in the original picture. Therefore, definitions for translating the chrominance motion vector may also use the two equations (1) and (2). - Motion prediction is done by a two step process: first, pixel accuracy motion estimation in the original image frame may be accomplished by upsampling of down-sampled image frame in the
Up Sampling Processor 226 of FIGS. 2A and 2B, then thehalf pixel Generator 228 performs a half pixel interpolation by averaging of nearest pixel values. - The reference image data is added to output data provided by the
IDCT processor 218. Since the output values of the summingnetwork 230 correspond to an image having a number of pixels consistent with a high resolution format, these values may be downsampled for display on a display having a lower resolution. Downsampling in theDown Sampling processor 232 is substantially equivalent to subsampling of an image frame, but adjustments may be made based upon the conversion ratio. For example, in the case of 3:1 downsampling, the number of horizontally downsampled pixels are 6 or 5 for each input macroblock, and the first downsampled pixels are not always first pixel in the input macroblock. - After acquiring the correct motion prediction block from the down-sampled image, upsampling is used to get the corresponding prediction block in the high resolution picture. Consequently, subpixel accuracy in motion block prediction is desirable in the down sampled picture. For example, using 3:1 decimation, it is desirable to have ⅓ (or ⅙) subpixel accuracy in the down-converted picture for proper motion prediction. The subpixel which is a first pixel required by the motion vector, in addition to the down-sampled motion block, is determined. Then, subsequent subpixel positions are determined using modulo arithmetic as described in the following. The subpixel positions are denoted as xs as given in equation (3):
- where “%” represents modulo division.
- For example, the ranges of xs are 0, 1, 2 for 3:1 upsampling and 0, 1 for 2:1 upsampling. FIG. 3A shows subpixel positions and corresponding 17 predicted pixels for the 3:1 and 2:1 examples, and Table 3 gives the legend for FIG. 3A.
TABLE 3 Symbol Pixel | Downsampled Pixel Δ Upsampled Pixel ∘ Prediction Pixel □□ Extra Right and Left Pixels for Upsampling - As previously described, the upsampling filters may be upsampling polyphase filters, and Table 4 gives characteristics of these upsampling polyphase interpolation filters.
TABLE 4 3:1 2:1 Upsampling Upsampling Number of Polyphase Filters 3 2 Number of Taps 3 5 Maximum number of horizontal 9 13 downsampled pixels - Next two tables, Table 5 and Table 6, show polyphase filter coefficients for the exemplary 3:1 and 2:1 upsampling polyphase filters.
TABLE 5 3:1 Upsampling Filter Phase 0 Phase 1Phase 2Double −0.1638231735591 0.0221080691070 0.3737642376078 Precision 0.7900589359512 0.9557838617858 0.7900589359512 0.3737642376078 0.0221080691070 −0.1638231735591 Fixed −0.1640625 (−42) 0.0234375 (6) 0.3750000 (96) Point 0.7890625 (202) 0.95703125 (244) 0.7890625 (202) (9 bits) 0.3750000 (96) 0.0234375 (6) −0.1640625 (−42) -
TABLE 6 2:1 Upsampling Filter Phase 0 Phase 1Double Precision 0.0110396839260 −0.1433363887113 0.0283886402920 0.6433363887113 0.9211433515636 0.6433363887113 0.0283886402920 −0.1433363887113 0.0110396839260 0.0000000000000 Fixed Point (9 bits) 0.01718750 (3) −0.14453125 (−37) 0.02734375 (7) 0.64453125 (165) 0.92187500 (236) 0.64453125 (165) 0.02734375 (7) −0.14453125 (−37) 0.01718750 (3) 0.00000000 (0) - In a fixed point representation, the numbers in parenthesis of Table 5 and Table 6 are 2's complement representations in 9 bits with the corresponding double precision numbers are on the left. Depending upon the subpixel position of the motion prediction block in the downsampled reference image frame, one corresponding phase of the polyphase interpolation filter is used. Also, for the exemplary embodiment additional pixels on the left and right are used to interpolate 17 horizontal pixels in the original image frame. For example, in the case of 3:1 decimation, a maximum of 6 horizontally downsampled pixels are produced for each input macroblock. However, when upsampling, 9 horizontal pixels are used to produce the corresponding motion prediction block values because an upsampling filter requires more left and right pixels outside of the boundary for the filter to operate. Since the exemplary embodiment employs half pixel motion estimation, 17 pixels are needed to get 16 half pixels which are the average values of nearest two pixel samples. A half pixel interpolator performs the interpolation operation which provides the block of pixels with half-pixel resolution. Table 7A illustrates an exemplary mapping between subpixel positions and polyphase filter elements, and shows a number of left pixels which are needed in addition to the pixels in the upsampled block for the upsampling process.
TABLE 7A Sub Pixel No. of Extra Coordinate Position Polyphase Left Pixels Change 3:1 0 1 1 x* − > x* − 1 Upsampling 1 2 1 x* − > x* − 1 2 0 0 2:1 0 0 2 x* − > x* − 2 Upsampling 1 1 2 x* − > x* − 2 - FIG. 3B summarizes the upsampling process which is performed for each row of an input macroblock. First, in
step 310, the motion vector for the block of the input image frame being processed is received. Atstep 312, the motion vector is translated to correspond to the downsampled reference frame in memory. Atstep 314, the scaled motion vector is used to calculate the coordinates of the desired reference image half macroblock stored inmemory 130. Atstep 316 the subpixel point for the half macroblock is determined and the initial polyphase filter values for upsampling are then determined atstep 318. The identified pixels for the reference half macroblock of the stored downsampled reference frame are then retrieved frommemory 130 atstep 320. - Before the first pass at the
filtering step 324, the registers of the filter may be initialized atstep 322, which, for the exemplary embodiment includes the step of loading the registers with the initial 3 or 5 pixel values. Then, after thefiltering step 324, the process determines, atstep 326, whether all pixels have been processed, which for the exemplary embodiment is 17 pixels. If all pixels have been processed, the upsampled block is complete. For an exemplary embodiment, a 17 by 9 pixel half macroblock is returned. The system returns upper or lower half macroblocks to allow for motion prediction decoding of both progressive scan and interlaced scan images. If all pixels have not been processed, the phase is updated atstep 328, and the phase is checked, for the 0 value. If the phase is zero, the registers are updated for the next set of pixel values. Updating the phase atstep 328 updates the phase value to 0, 1, and 2 for the filter loop period for exemplary 3:1 upsampling and to 0, and 1 for the filter loop period for 2:1 upsampling. Where the left-most pixel is outside of a boundary of the image picture, the first pixel value in the image picture may be repeated. - For an exemplary embodiment, the upsample filtering operation may be implemented in accordance with the following guidelines. First, several factors may be used: 1) the half-pixel motion prediction operation averages two full pixels, and corresponding filter coefficients are also averaged to provide the half-pixel filter coefficient; 2) a fixed number of filter coefficients, five for example, which may be equivalent to the number of filter taps, may be employed regardless of the particular downconversion; 3) five parallel input ports may be provided to the upsampling block for each forward and backward lower and upper block, with five input pixels LWR(0)-LWR(4) for each clock transition for each reference block being combined with corresponding filter coefficients to provide one output pixel, and 4) the sum of filter coefficients h(0)-h(4) combined with respective pixels LWR(0)-LWR(4) provide the output pixel of the sampling block.
- Filter coefficients are desirably reversed because the multiplication ordering is opposite to the normal ordering of filter coefficients, and it may be desirable to zero some coefficients. Table 7B gives exemplary coefficients for the 3:1 upsampling filter, and Table 7C gives exemplary coefficients for the 2:1 upsampling filter:
TABLE 7B Sub- Sub- Sub- Sub- Sub- Sub- pixel 0pixel 1pixel 2pixel 3pixel 4pixel 5Filter 6 −18 −42 −21 96 51 Coeff. 244 223 202 149 202 223 6 51 96 149 −42 −18 0 0 0 −21 0 0 0 0 0 0 0 0 Reference x* − 1 x* − 1 x* − 1 x* − 1 x* x* Phase 01 00 10 01 00 10 Half 0 1 0 1 0 1 Pixel -
TABLE 7C Subpixel 0 Subpixel 1Subpixel 2Subpixel 3Filter Coeff. 3 2 −37 −17 7 −15 165 86 236 200 165 200 7 86 −37 −15 3 −17 0 2 Reference x* − 2 x* − 2 x* − 1 x* − 1 Phase 00 00 01 01 Half Pixel 0 1 0 1 - In Tables 7B and 7C, x* is the downsampled pixel position defined in equations (1) and (2), and subpixel position, xs, is redefined from equation (3) as equation (3′)
- x s=(XH)%(2Dx) (3′)
- For chrominance values of the exemplary implementation, XH is scaled by two and equations (1),(2) and (3′) are applied. In one embodiment, phase and half pixel information (coded as two bits and one bit, respectively) is used by
motion compensation processor 220 and half-pixel generator 228 of FIG. 2B. For example, reference block pixels are provided as U pixels first, V pixels next, and finally Y pixels. U and V pixels are clocked in for 40 cycles and Y pixels are clocked in for 144 cycles. Reference blocks may be provided for 3:1 decimation by providing the first five pixels, repeating twice, shifting the data by one, and repeating until a row is finished. The same method may be used for 2:1 decimation except that it is repeated once rather than twice. Input pixels are repeated since decimation follows addition of the output from motion compensation and half-pixel generation with the residual value. Consequently, for 3:1 decimation, two of three pixels are deleted, and dummy pixels for these pixel values do not matter. - 3) DCT Domain Filtering Employing Weighting of DCT Coefficients
- The exemplary embodiment of the present invention includes the
DCT filter 216 of FIG. 2A processing the DCT coefficients in the frequency domain, which replaces a lowpass filter in the spatial domain. There are several advantages in DCT domain filtering instead of spatial domain filtering for DCT coded pictures, such as contemplated by the MPEG or JPEG standards. Most notably, a DCT domain filter is computationally more efficient and requires less hardware than a spatial domain filter applied to the spatial pixel sample values. For example, a spatial filter having N taps may use as many as N additional multiplications and additions for each spatial pixel sample value. This compares to only one additional multiplication in the DCT domain filter. - The simplest DCT domain filter of the prior art is a truncation of the high frequency DCT coefficients. However, truncation of high frequency DCT coefficients does not result in a smooth filter and has drawbacks such as “ringing” near edges in the decoded picture. The DCT domain lowpass filter of the exemplary embodiment of the present invention is derived from a block mirror filter in the spatial domain. The filter coefficient values for the block mirror filter are, for example, optimized by numerical analysis in the spatial domain, and these values are then converted into coefficients of the DCT domain filter.
- Although the exemplary embodiment shows DCT domain filtering in only the horizontal direction, DCT domain filtering can be done in either horizontal or vertical direction or both by combining horizontal and vertical filters.
- 4) Derivation of the DCT Domain Filter Coefficients
- One exemplary filter of the present invention is derived from two constraints: first, that the filter process image data on a block by block basis for each block of the image without using information from previous blocks of a picture; and second, that the filter reduce the visibility of block boundaries which occur when the filter processes boundary pixel values.
- According to the first constraint, in the DCT based compression of an MPEG image sequence, for example, N×N DCT coefficients yield N×N spatial pixel values. Consequently, the exemplary embodiment of the present invention implements a DCT domain filter which only processes a current block of the received picture.
- According to the second constraint, if the filter is simply applied to a block of spatial frequency coefficients, there is a transition of the filtering operation at the block boundary which is caused by an insufficient number spatial pixel values beyond the boundary to fill the residual of the filter. That is to say, coefficient values at the edge of a block cannot be properly filtered because the N-tap filter has values for only N/2 taps, the remaining values are beyond the boundary of the block. Several methods of supplying the missing pixel values exist: 1) repeat a predetermined constant pixel value beyond a boundary; 2) repeat the same pixel value as the boundary pixel value; and 3) mirror the pixel values of the block to simulate previous and subsequent blocks of pixel values adjacent to the processed block. Without prior information on the contents of the previous or subsequent block, the mirroring method of repeating pixel values is considered as a preferred method. Therefore, one embodiment of the present invention employs this mirroring method for the filter and is termed a “block mirror filter.”
- The following describes an exemplary embodiment which implements a horizontal block mirror filter that lowpass filters 8 input spatial pixel sample values of a block. If the size of input block is an 8×8 block matrix of pixel sample values, then a horizontal filtering can be done by applying the block mirror filter to each row of 8 pixel sample values. It will be apparent to one skilled in the art that the filtering process can be implemented by applying the filter coefficients columnwise to the block matrix, or that multidimensional filtering may be accomplished by filtering the rows and then filtering the columns of the block matrix.
- FIG. 4 shows an exemplary correspondence between the input pixel values x0 through x7 (group X0) and filter taps for an exemplary mirror filter for 8 input pixels which employs a 15 tap spatial filter represented by tap values h0 through h14. The input pixels are mirrored on the left side of group X0, shown as group X1, and on the right side of group X0, shown as group X2. The output pixel value of the filter is the sum of 15 multiplications of the filer tap coefficient values with the corresponding pixel sample values. FIG. 4 illustrates the multiplication pairs for the first and second output pixel values.
- The following shows that the block mirror filter in the spatial domain is equivalent to DCT domain filter. The mirror filtering is related to a circular convolution with 2N points (N=8).
- Define the vector x′ as shown in equation (4).
- x′(n)=x(n)+x(2N−1−n); 0<=n<=2N−1 (4)
- In the case of N=8,
- x′=(x0, x1, x2, x3, x4, x5, x6, x7, x7, x6, x5, x4, x3, x2, x1, x0)
- Rearranging the filter tap values h0 through h14, and denoting the rearranged values by h′
- h′=(h7, h8, h9, h10, h11, h12, h13, h14, 0, h0, h1, h2, h3, h4, h5, h6)
- Therefore, the mirror filtered output y(n) is a circular convolution of x′(n) and h′(n) which is given by equation (5).
-
- where x′[n−k] is a circular modulo of x′(n) and
- x′[n]=x′(n) for n>=0
- x′[n]=x′(n+2N) for n<0.
- The circular convolution in the spatial domain shown in equation (5) corresponds to the scalar multiplication in the Discrete Fourier Transform (DFT) domain. Defining Y(k) as the DFT of y(n), then equation (5) becomes equation (7) in the DFT domain.
- Y(k)=X′(k)·H′(k) (7)
- where X′(k) and H′(k) are the DFTs of x′(n) and h′(n) respectively.
- Equations (4) through (7) are valid for a filter with a number of taps less than 2N. In addition, the filter is limited to be a symmetric filter with an odd number of taps, with these constraints H′(k) is a real number. Therefore, X′(k), the DFT of x′(n), can be weighed with a real number H′(k) in the DFT frequency-domain instead of 2N multiplication and 2N addition operations in the spatial domain to implement the filtering operation. The values of X′(k) are very closely related to the DCT coefficients of the original N-point x(n), because an N-point DCT of x(n) is obtained by the 2N-point DFT of x′(n) which is the joint sequence composed of x(n) and its mirror, x(2N−1−n).
-
- where W2N kn=exp{−2πkn/(2N)}; and H′(k)=H′(2N−k).
-
-
- and C(k)=0 elsewhere.
-
-
- where α(k)=½ for k=0 and 1 otherwise.
-
- The values y(n) of equation (13) are the spatial values of the IDCT of C(k)H′(k). Therefore, the spatial filtering can be replaced by the DCT weighting of the input frequency-domain coefficients representing the image block with H′(k) and then performing the IDCT of the weighted values to reconstruct the filtered pixel values in the spatial domain.
- One embodiment of the exemplary block mirror filtering of the present invention is derived as by the following steps: 1) a one dimensional lowpass symmetric filter is chosen with an odd number of taps, which is less than 2N taps; 2) the filter coefficients are increased to 2N values by padding with zero's; 3) the filter coefficients are rearranged so that the original middle coefficient goes to the zeroth position by a left circular shift; 4) the DFT coefficients of the rearranged filter coefficients are determined; 5) the DCT coefficients are multiplied with the real number DFT coefficients of the filter; and 6) an inverse discrete cosine transform (IDCT) of the filtered DCT coefficients is performed to provide a block of lowpass-filtered pixels prepared for decimation.
- The cutoff frequency of the lowpass filter is determined by the decimation ratio. For one exemplary embodiment, the cutoff frequency is π/3 for a 3:1 decimation and π/2 for a 2:1 decimation, where π corresponds to one-half of sampling frequency.
- A DCT domain filter in MPEG and JPEG decoders allows memory requirements to be reduced because the inverse quantizer and IDCT processing of blocks already exists in the decoder of the prior art, and only the additional scalar multiplication of DCT coefficients by the DCT domain filter is required. Therefore, a separate DCT domain filter block multiplication is not physically required in a particular implementation; another embodiment of the present invention simply combines the DCT domain filter coefficients with the IDCT processing coefficients and applies the combined coefficients to the IDCT operation.
- For the exemplary down conversion system of the present invention, the horizontal filtering and decimations of the DCT coefficients were considered; and the following are two exemplary implementations for:
- 1. 1920H by 1080V interlace to 640 by 1080 interlace conversion (Horizontal 3:1 decimation).
- 2. 1280H by 720V progressive to 640 by 720 progressive conversion (Horizontal 2:1 Decimation)
- Table 8 shows the DCT block mirror filter (weighting) coefficients; in Table 8 the numbers in the parenthesis are 10
bit 2's complementary representations. The “*” of Table 8 indicates an out of bound value for the 10bit 2's complement representation because the value is more than 1; however, as is known by one skilled in the art, the multiplication of the column coefficients of the block by the value indicated by the * can be easily implemented by adding the coefficient value to the coefficient multiplied by the fractional value (remainder) of the filter value.TABLE 8 3:1 Decimation 2:1 Decimation H[0] 1.000000000000000 (511) 1.0000000000000000 (511) H[1] 0.986934590759779 (505) 1.0169628157945179 (*) H[2] 0.790833583171840 (405) 1.0000000000000000 (511) H[3] 0.334720213357461 (171) 0.82247656390475166 (421) H[4] −0.0323463361027473 (−17) 0.46728234862006007 (239) H[5] −0.0377450036954524 (−19) 0.10634261847436199 (54) H[6] −0.0726889747390758 (37) −0.052131780559049545 (−27) H[7] 0.00954287167337307 (5) −0.003489737967467715 (−2) - These horizontal DCT filter coefficients weight each column in the 8×8 block of DCT coefficients of the encoded video image. For example, the DCT coefficients of column zero are weighted by H[0], and the DCT coefficients of the first column are weighted by H[1] and so on.
- The above description illustrates a horizontal filter implementation using one-dimensional DCTs. As is known in the digital signal processing art, such processing can be extended to two-dimensional systems. Equation (12) illustrates the IDCT for the one-dimensional case, consequently, equation (12′) gives the more general two dimensional IDCT:
- where f(x,y) is the spatial domain representation, x and y are spatial coordinates in the sample domain, and u,v are the coordinates in the transform domain. Since the coefficients C(u), C(v) are known, as are the values of the cosine terms, only the transform domain coefficients need to be provided for the processing algorithms.
- For a two-dimensional system, the input sequence is now represented as a matrix of values, each representing the respective coordinate in the transform domain, and the matrix may be shown to have sequences periodic in the column sequence with period M, and periodic in the row sequence with period N, N and M being integers. A two-dimensional DCT can be implemented as a one dimensional DCT performed on the columns of the input sequence, and then a second one dimensional DCT performed on the rows of the DCT processed input sequence. Also, as is known in the art, a two-dimensional IDCT can be implemented as a single process.
- FIG. 5 shows an exemplary implementation of the filter for down-conversion for a two-dimensional system processing the horizontal and vertical components implemented as cascaded one-dimensional IDCTs. As shown in FIG. 5, the
DCT Filter Mask 216 andIDCT 218 of FIG. 2 may be implemented by aVertical Processor 510, containing aVertical DCT Filter 530 and aVertical IDCT 540, and aHorizontal Processor 520, containing a horizontal DCT Filter and horizontal IDCT which are the same as those implemented for the vertical components. Since the filtering and IDCT processes are linear, the order of implementing these processes can be rearranged (e.g, horizontal and vertical DCT filtering first and horizontal and vertical IDCTs second, or vise-versa, orVertical Processor 520 first and Horizontal Processor 510 (second)). - In the particular implementation shown in FIG. 5, the
Vertical Processor 510 is followed by ablock Transpose Operator 550, which switches the rows and columns of the block of vertical processed values provided by the Vertical Processor. This operation may be used to increase the efficiency of computation by preparing the block for processing by theHorizontal Processor 520. - The encoded video block, for example an 8×8 block of matrix values, is received by the
Vertical DCT filter 530, which weights each row entry of the block by the DCT filter values corresponding to the desired vertical decimation. Next, theVertical IDCT 540 performs the inverse DCT for the vertical components of the block. As described previously, since both processes simply perform a matrix multiplication and addition, the DCT LPF coefficients can be combined with the vertical DCT coefficients for matrix multiplications and addition operations. TheVertical Processor 510 then provides the vertically processed blocks to theTranspose Operator 550, which provides the transposed block of vertically processed values to theHorizontal Processor 520. TheTranspose Operator 550 is not necessary unless the IDCT operation is only done by row or by column. TheHorizontal Processor 520 performs the weighting of each column entry of the block by the DCT filter values corresponding to the desired horizontal filtering, and then performs the inverse DCT for the horizontal components of the block. - As described with reference to equation (12′), only coefficients in the transform domain are provided to the processing algorithms; and the operations are linear which allows mathematical operations on these coefficients only. The operations for the IDCT, as is readily apparent from equation (12′), form a sum of products. Consequently, a hardware implementation requires known coefficients to be stored in memory, such as a ROM (not shown), and a group of multiply and add circuits (not shown) which receives these coefficients from the ROM as well as selected coefficients from the matrix of input transform coordinates. For more advanced systems, a ROM-accumulator method may be used if the order of mathematical operations is modified according to distributed arithmetic to convert from a sum of products implementation to a bit-serial implementation. Such techniques are described in, for example, Stanley A. White, Applications of Distributed Arithmetic to Digital Signal Processing: A Tutorial Review, IEEE ASSP Magazine, July, 1989, which take advantage of symmetries in the computations to reduce a total gate count of the sum of products implementation.
- In an alternative embodiment of the present invention, the DCT filter operation may be combined with the inverse DCT (IDCT) operation. For such an embodiment, since the filtering and inverse transform operations are linear, the filter coefficients may be combined with the coefficients of the IDCT to form a modified IDCT. As is known in the art, the modified IDCT, and hence the combined IDCT and DCT downconversion filtering, may be performed through a hardware implementation similar to that of the simple IDCT operation.
- c) Memory Subsystem
- 1) Memory Access and Storage of Bitstream and Picture Data
- As shown in FIG. 1B, the exemplary embodiment of the present invention employs an
ATV Video Decoder 121 having aMemory Subsystem 174 which controls the storage and reading of information to and fromMemory 130.Memory Subsystem 174 provides picture data and bitstream data toMemory 130 for video decoding operations, and in the preferred embodiment, at least 2 pictures, or frames, are used for proper decoding of MPEG-2 encoded video data. An optional On-Screen Display (OSD) section in theMemory 130 may be available to support OSD data. The interface between theMemory Subsystem 174 andMemory 130 may be a Concurrent RDRAM interface providing a 500 Mbps channel, and three RAMBUS channels may be used to support the necessary bandwidth. An embodiment of the present invention havingPicture processor 171,Macroblock decoder 172, andMemory subsystem 174 operating withexternal memory 130 may employ a system as described in U.S. Pat. No. 5,623,311 entitled MPEG VIDEO DECODER HAVING A HIGH BANDWIDTH MEMORY to Phillips et al., which is incorporated herein by reference. FIG. 12 is a high level block diagram of such system of a video decoder having high bandwidth memory as employed by an exemplary embodiment of the present invention to decode MP@ML MPEG-2 pictures. - In summary, and described with relation to FIG. 1A and FIG. 1B, U.S. Pat. No. 5,623,311 describes a single, high bandwidth memory having a single memory port. The
memory 130 holds input bitstream, first and second reference frames used for motion compensated processing, and image data representing the field currently being decoded. The decoder includes 1) circuitry (picture processor 171) which stores and fetches the bitstream data, 2) circuitry that fetches the reference frame data and stores the image data for the currently decoded field in block format (Macroblock decoder 172), and fetches the image data for conversion to raster-scan format (display section 173). The memory operations are time division multiplexed using a single common memory port with a defined memory access time period, called Macroblock Time (MblkT) for control operations. A digital phase locked loop (DPLL) 122 counts pulses of a 27 MHz system clock signal, defined in the MPEG-2 standard, to generate a count value. The count value is compared to a succession of externally supplied system clock reference (SCR) values to generate a phase difference signal that is used to adjust the frequency of the signal produced by the digital phase locked loop. - Table 9 summarizes the picture storage requirements for DC configurations to support multiple formats:
TABLE 9 Pixels Macroblocks Pixels Macroblocks Bits per Storage Format (H) (H) (V) (V) Picture (3 Pictures) 1920 × 1088 DC 640 40 1088 68 8,355,840 25,067,520 1280 × 720 DC 640 40 720 45 5,529,600 16,588,800 704 × 480 704 44 480 30 4,055,040 12,165,120 640 × 480 640 40 480 30 3,686,400 12,165,120 - For DC mode, 1920×1080 pictures are reduced by a factor of 3 horizontally, yielding a 640×1080 picture; 1280×720 pictures are reduced by a factor of 2 horizontally yielding a 640×720 picture. The 704×480 and 640×480 pictures are not required to be reduced in DC mode.
- Accommodating multiple DC pictures in
Memory 130 also requires supporting respective decoding operations according to corresponding picture display timing. For example, progressive pictures occur at twice the rate of interlaced pictures (60 or 59.94 Hz progressive vs. 30 or 29.97 Hz interlace) and, as a result, progressive pictures are decoded faster than interlaced pictures (60 or 59.94 Frames per second progressive vs. 30 or 29.97 Frames per second interlace). Consequently, the decoding rate is constrained by the display rate for the format, and if the less stringent 59.97 or 29.97 frames per second decoding rates are used rather than the 60 or 30 frames per second, one frame out of every 1001 frames may be dropped from the conversion. For convenience, decoding operations for a format may be measured in units of “Macroblock Time” (MblkT) defined as the period during which all decoding operations for a macroblock may be completed (clock cycles per macroblock decoding). Using this period as a measure, as defined in equation 14, control signals and memory access operations can be defined during the regularly occurring MblkT period. - MblkT (clock cycles/macroblock)=system clock rate (clock cycles/sec.)/Frame rate (frames/sec.)/Picture Size (macroblocks/frame) (14)
- In addition, a blanking interval may not be used for picture decoding of interlaced pictures, and an 8-line margin to the time period is added to account for decoding 8 lines simultaneously (interlaced) and 16 lines simultaneously (progressive). Therefore, an adjustment factor (AdjFact) may be added to the MblkT, as given in equations (15) and (16).
- AdjFact (interlace)=(total lines−vertical blank lines−8)/total lines (15)
- AdjFact (progressive)=(total lines−16)/total lines (16)
- Table 10 lists MblkT for each of the supported formats:
TABLE 10 Mblk Frame Adjust- Active per Time MblkT ment Decoding Format frame (msec) (clks) factor MblkT 1920 × 1080 8160 33.33 255.3 0.9729 248.4 1280 × 720 3600 16.67 289.4 0.9787 283.2 704 × 480 P 1320 16.67 789.1 0.9695 765.1 704 × 480 I 1320 33.33 1578 0.9419 1486.6 640 × 480 P 1200 16.67 868 0.9695 841.6 640 × 480 I 1200 33.33 1736 0.9419 1635.3 - In an exemplary embodiment of the present invention, a MblkT of 241 clocks is employed for all formats to meet the requirement of the fastest decode time including a small margin. For such chosen MblkT period, slower format decoding includes periods in which no decoding activities occur; consequently, a counter may be employed to reflect the linear decoding rate with a stall generated to stop decoding in selected MblkT intervals.
- Referring to FIG. 1B, the
Memory Subsystem 174 may provide internal picture data interfaces to theMacroblock decoder 172 anddisplay section 173. A decoded macroblock interface accepts decoded macroblock data and stores it in correct memory address locations ofMemory 130 according to a memory map defined for the given format. Memory addresses may be derived from the macroblock number and picture number. The macroblocks may be received as a macroblock row on three channels, one channel per 16 Mb memory device (131-136 of FIG. 1A) at the system clock rate. Each memory device may have two partitions for each picture, each partition using an upper and lower address. For interlaced pictures, the one partition carriesField 0 data and the other partition carriesField 1 data, and for progressive pictures, both upper and lower partitions are treated as a single partition and carry data for the entire frame. Every macroblock is decoded and stored for every picture, except for 3:2 pull down mode where decoding is paused for an entire field time period. In 3:2 pulldown mode, a signal having a frame rate of 24 frames per second is displayed at 60 frames (or fields) per second by displaying one frame twice and the next frame three times. - A reference macroblock interface supplies stored, previously decoded picture data to the
macroblock decoder 172 for motion compensation. The interface may supply two, one or no macroblocks corresponding to bi-directional predictive (B) encoding, uni-directional predictive (P) encoding or intra (I) encoding. Each reference block is supplied using two channels, and each channel contains one-half of a macroblock. For DC mode employing a decimation factor of 2, each retrieved half macroblock is 14×9 (Y), 10×5 (CR) and 10×5 (CB) to allow for up-sampling and half-pixel resolution. - A display interface provides retrieved pixel data to the
display section 173, multiplexing Y, CR, and CB pixel data on a single channel. Two display channels may be provided to support conversion from/to interlaced to/from progressive formats. In DC mode, a first channel may provide up to 4 lines of interlaced or progressive data simultaneously and a second channel may provide up to 4 lines of interlaced data. - For downconversion, downsampled macroblocks are merged into a single macroblock for storage. The downsampling process of the DC mode is described subsequently with reference to FIG. 6A and FIG. 6B. FIG. 6C illustrates a merging process of two macroblocks into a single macroblock for storage in
memory 130 for downconversion by 2 horizontally. FIG. 6D illustrates a merging process of three macroblocks into a single macroblock for storage inmemory 130 for downconversion by 3 horizontally. - d) Downsampling and Display Conversion of the Display Section
- 1) Down Sampling for Low Resolution Formats
- Down sampling is accomplished by the
Down Sampling process 232 of FIG. 2B to reduce the number of pixels in the downconverted image. FIG. 6A shows the input and decimated output pixels for a 4:2:0 signal format for 3:1 decimation. FIG. 6B shows the input and decimated output pixels for 4:2:0 chrominance type 2:1 decimation. Table 11 gives the legend identification for the Luminance and Chrominance pixels of FIG. 6A and FIG. 6B. The pixel positions before and after the down conversion of FIGS. 6A and 6B are the interlaced (3:1 decimation) and progressive (2:1 decimation) cases respectively.TABLE 11 Symbol Pixel + Luminance Before Decimation × Chrominance Before Decimation | Luminance After decimation Δ Chrominance After Decimation - For down sampling of the interlaced image, which may be the conversion from a 1920 by 1080 pixel image to a 640 by 1080 pixel horizontally compressed image, two out of every three pixels are decimated on the horizontal axis. For the exemplary 3:1 decimation, there are three different macroblock types after the down conversion process. In FIG. 6A, original macroblocks were denoted by MB0, MB1, MB2. The down sampled luminance pixels in MB0 start at the first pixel in the original macroblock, but in MB1 and MB2 the down-sampled pixels start at the third and the second pixels. Also the number of down-sampled pixels in each macroblock are not the same. In MB0, there are 6 down-sampled pixels horizontally, but 5 pixels in MB1 and MB2. These three MB types are repeating, therefore Modulo 3 arithmetic is to be applied. Table 12 summarizes the number of downsampling pixels and offsets for each input macroblock MB0, MB1, MB2.
TABLE 12 MB0 MB1 MB2 No. of Down Sampled 6 5 5 Luminance Pixels No. of Down Sampled 3 3 2 Chrominance Pixels Offset of 1st Down 0 2 1 Sampled Luminance Pixel Offset of 1st Down 0 1 2 Sampled Chrominance Pixel - For downsampling of the progressive format image the luminance signal is subsampled for every second sample horizontally. For the chrominance signal, the down-sampled pixel has a spatial position that is one-half pixel below the pixel position in the original image.
- 2) Display Conversion
- The
display section 173 of theATV Decoder 121 of FIG. 1B is used to format the stored picture information (the decoded picture information) for a particular display format. FIG. 11A is a high level block diagram illustrating the display section of theATV Video Decoder 121 for an exemplary embodiment of the present invention. - Referring to FIG. 11A, two output video signals are supported, a first output signal VIDout1 which supports any selected video format, and a second output signal VIDout2 which supports 525I (CCIR-601) only. Each output signal is processed by separate sets of
display processing elements section 1104 may be included to provide on screen display information to one of the supported output signals VIDout1 and VIDout2 to form display signals Vout1 or Vout2. All processing is performed at the internal clock rate except for control of the output signals Vout1 or Vout2 atOutput Controllers - Because the display sets of
processing elements display processing set 1101, four lines of pixel data are provided from the memory 130 (shown in FIG. 1A) to the vertical processing block 282 (shown in FIG. 2B) in raster order. Each line supplies CR,Y,CB,Y data 32 bits at a time. Vertical Processing block 282 then filters the four lines down to one line and provides the filtered data in 32 bit CRYCBY format to horizontal processing block 284 (also shown in FIG. 2B). Thehorizontal processing block 284 provides the correct number of pixels for the selected raster format as formatted pixel data. Consequently, the filtered data rate entering thehorizontal processing block 284 is not necessarily equal to the output data rate. In an upsampling case, the input data rate will be lower than the output data rate. In a down sampling case, the input data rate will be higher than the output data rate. The formatted pixel data may have background information inserted by optionalbackground processing block 1110. - As would be known to one skilled in the art, the elements of the
display section 173 are controlled by acontroller 1150, which is set up by parameters read from and written to the microprocessor interface. The controller generates signal CNTRL, and such control is necessary to coordinate and to effect proper circuit operation, loading and transfer of pixels, and signal processing. - Data from the
horizontal processing block 284, data from a second horizontal processing block 284 a, and HD (non processed) Video data onHD Bypass 1122 are provided to Multiplexer 118 which selects, under processor control (not shown), one video data stream which is provided to mixer 116 to combine the video data stream and optional OSD data fromOSD processor 1104 into mixed output video data. The mixed video output data is then provided toMUXs - For the first set of
processing elements 1101,MUX 1120 may select from mixed output video data, HD data provided onHD bypass 1122, or data frombackground insertion block 1110. The selected data is provided tooutput control processor 1126 which also receives the pixel clock.Output control processor 1126 then changes the data clock rate from the internal processing domain to the pixel clock rate according to the output mode desired. - For the
second processing elements 1102,MUX 1124 may select from mixed output video data or data frombackground insertion block 1110 a. The selected data is provided tooutput control processor 1128 which also receives the pixel clock.Output control processor 1128 then changes the data clock rate from the internal processing domain to the pixel clock rate according to the output mode desired.MUX 1132 provides either the received selected data (601 Data Out) ofMUX 1124 or optional OSD data fromOSD processor 1104. - Raster Generation and
Control processor 1130 also receives the pixel clock and includes counters (not shown) which generate the raster space, allowing control commands to be sent on a line by line basis toDisplay Control Processor 1140.Display Control processor 1140 coordinates timing with theexternal memory 130 and starts the processing for eachprocessing chain Processor 1130 also generates the horizontal, vertical and field synchronization signals (H, V and F). - FIGS. 11B through 11D relate the output modes provided by
Display section 173 shown in FIG. 11A of theVideo Decoder 121 to the active blocks of FIG. 1A. FIG. 11B illustrates a 27 MHz Dual output mode which, for which the video data is 525P or 525I, first processor 1101 (shown in FIG. 11A) provides 525P video data to 27MHz DAC 143 as well as 525I data (601 Data Out) toNTSC Encoder 152. FIG. 11C illustrates that in 27 MHz single output mode, only 525I data (601 Data Out) is provided toNTSC encoder 152. FIG. 11D illustrates a 74 MHz/27 MHz mode in which the output mode matches the input format and the video data is provided to either the 27MHz DAC 143 or 74MHz DAC 141 depending on the output format. The 74 MHz DAC is used for 1920×1088 and 1280×720 pictures; the 27 MHz DAC is used for all other output formats. - Display conversion of the downsampled image frames is used for display the image in a particular format. As noted previously, the Display Conversion block280 shown in FIG. 2B includes the vertical processing block (VPF) 282 and horizontal processing block (HZPF) 284 which adjust the down converted and down sampled images for display on the lower resolution screen.
-
VPF 282 which, for the exemplary embodiment, is a vertical line interpolation processor implemented as a programmable polyphase vertical filter, andHZPF 284 which, for the exemplary embodiment, is a horizontal line interpolation processor also implemented as a programmable horizontal polyphase filter. The filters are programmable, which is a design option in order to accommodate display conversion for a number of display formats. - As shown in FIG. 2B, four lines of downsampled pixel data enter the
VPF 282 in raster order. For the exemplary embodiment this data includes luminance (Y) and chrominance (CR and CB) pixel pairs which enterVPF 282 32 bits at a time.VPF 282 filters the four lines of data into one line and passes this line to theHZPF 284 as 32 bit values each containing luminance and chrominance data in a YCRYCB, andHZPF 284 then generates the correct number of pixels to match the desired raster format. - FIG. 7A is a high level block diagram illustrating an exemplary filter suitable for use as the
VPF 282 of one embodiment of the present invention. In the following, theVPF 282 is described as processing pairs of input pixels (each pair includes two luminance pixels, Y, pixel and a chrominance CR or CB, pixel) to produce a pair of output pixels. This facilitates processing of the 4:2:0 format because color pixels may be easily associated with their corresponding luminance pixels. One skilled in the art, however, would realize that only luminance pixels or only chrominance pixels may be so processed. In addition, theVPF 282 as described produces lines in progressive format. In another embodiment employing a dual output and supporting both a main output channel and a secondary output channel, asecond VPF 282 may be added. - Referring to FIG. 7A,
VPF 282 includes aVPF Controller 702; first muliplexer network including Luminance Pixel MUXs (LP MUXs) 706, 708, 710, and 712 and Chrominance Pixel MUXs (CP MUXs) 714, 716, 718, and 720; second multiplexer network including Luminance Filter MUXs (LF MUXs) 726, 728, 730 and 732 and Chrominance Filter MUXs (CF MUXs) 734, 736, 738 and 740;Luminance Coefficient RAM 704;Chrominance Coefficient RAM 724;Luminance Coefficient Multipliers Chrominance Coefficient Multipliers Luminance Adders Chrominance Adders Clip processors Output Register 780. - The operation of the
VPF 282 is now described. Vertical resampling is accomplished with two 4-Tap polyphase filters, one for the Luminance pixels and one for the Chrominance pixels. The following details operation of the filter for the Luminance pixels only, since the operation for the Chrominance pixels is similar, but points out those differences in the paths as they occur. Vertical filtering of Luminance pixels can use up to 8 phases in the 4-Tap polyphase filter and filtering of Chrominance pixels can use up to 16 phases in the 4-Tap polyphase filter for the exemplary embodiment. TheVPF Controller 702, at the beginning of a field or frame, resets the vertical polyphase filter, provides control timing to the first and second multiplexer networks, selects coefficient sets fromLuminance Coefficient RAM 704 andChrominance Coefficient RAM 724 for the polyphase filter phases, and includes a counter which counts each line of the field or frame as it is processed. - The
VPF Controller 702, in addition to coordinating the operation of the network of MUXs and the polyphase filters, keeps track of display lines by tracking the integer and fractional parts of the vertical position in the decoded picture. The integer part indicates which lines should be accessed and the fractional part indicates which filter phase should be used. Furthermore, use of modulo N arithmetic when calculating the fractional part allows less than 16 phases to be used, which may be efficient for exact downsampling ratios such as 9 to 5. The fractional part is always truncated to one of the modulo N phases that are being used. - As shown in FIG. 7A, luminance and chrominance pixel pairs from the four image lines are separated into a chrominance path and a luminance path. The 16 bit pixel pair data in the luminance path may be further multiplexed into an 8-bit even (Y-even) and 8-bit odd (Y-odd) format by
LP MUXs CP MUXs luminance filter MUXs - Pixel pairs for the four lines corresponding to luminance pixel information and chrominance pixel information are then passed through the respective polyphase filters. Coefficients used by
Multipliers VPF Controller 702 based on a programmed up or down sampling factor. After combining the weighted luminance pixel information inAdders Clip processor 772 which provides eight bit values (since the coefficient multiplication occurs with higher accuracy).DEMUX register 774 receives the first 8 bit value corresponding to an interpolated 8 bit even (Y-even) luminance value and second 8-bit value corresponding to the interpolated 8-bit odd (Y-odd) value, and provides a vertical filtered luminance pixel pair in 16 bits.Register 780 collects and provides the vertical filtered pixels in the luminance and chrominance paths and provides them as vertically filtered 32 bit values containing a luminance and chrominance pixel pair. - FIG. 7B shows the spatial relationships between the coefficients and pixel sample space of the lines. The coefficients for the luminance and chrominance polyphase filter paths each have 40 bits allocated to each coefficient set, and there is one coefficient set for each phase. The coefficients are interpreted as fractions with a denominator of512. The coefficients are placed in the 40-bit word from left to right, C0 to C3. C0 and C3 are signed ten
bit 2's complement values, and C1 and C2 are 10 bits which have a given range, for example, from −256 to 767, which are each subsequently converted to 11-bit 2's complement values. - FIG. 7A includes an optional luminance coefficient adjustment782 and
chrominance coefficient adjustment 784. Thesecoefficient adjustments 782 and 784 are used to derive the 11bit 2's complement number for C1 and C2. Ifbits 8 and 9(the most significant bit) are both 1, then the sign of the eleven bit number is 1 (negative), otherwise the value is positive. - FIG. 8A is a high level block diagram illustrating an exemplary filter suitable for use as the
HZPF 284 of one embodiment of the present invention.HZPF 284 receives a luminance and chrominance pixel information pair, which may be 32-bit data, from theVPD 282. TheHZPF 284 includes aHZPF Controller 802; CR latches 804; CB latches 806; Y latches 808;Selection MUXs 810; HorizontalFilter Coefficient RAM 812; Multiplyingnetwork 814; Addingnetwork 816; Round andClip processor 818,DEMUX register 820 andoutput register 822. - Horizontal resampling is accomplished by employing an 8 tap, 8 phase polyphase filter. Generation of display pixels is coordinated by the
HZPF Controller 802 by tracking the integer and fractional parts of the horizontal position in the decoded and downsampled picture. The integer part indicates which pixels are to be accessed and the fractional part indicates which filter phase should be used. Using modulo N arithmetic when calculating the fractional part may allow for less than 8 phases to be used. For example, this may be useful if an exact downsampling ratio such as 9 to 5 is used. If the down-sampling ratio cannot be expressed as a simple fraction, the fractional part is truncated to one of the N phases. TheHZPF 284 of the exemplary embodiment of the present invention filters pixel pairs, and uses alignment on even pixel boundaries to facilitate processing of the 4:2:0 formatted picture and to keep the CR and CB pixels (the color pixels) together with the corresponding Y pixels. - The operation of the
HZPF 284 is now described with reference to FIG. 8A. TheHZPF Controller 802, at the beginning of a horizontal line, resets the horizontal polyphase filter, provides control timing to the first and second multiplexer networks, selects coefficient sets fromHorizontal Coefficient RAM 812 for the CR, CB and Y filter coefficients for each of the polyphase filter phases, and selects each set of CR, CB and Y values for processing. In addition, when the horizontal position is near the left or right side of the line, theHZPF Controller 802 forces the edge pixel values to be repeated or set to 0 for use by the 8-tap polyphase filter. Any distortion in the image caused by this simplification is usually hidden in the overscan portion of the displayed image. - The pixel data received from the
VPF 282 is separated into Y, CR and CB values, and these values are individually latched into CR latches 804; CB latches 806; and Y latches 808 for filtering. TheHZPF Controller 802 then selects the Y, CR and CB values by an appropriate signal to theselection MUXs 810. In the exemplary embodiment, there are more Y values than CR or CB values so the filter uses additional latches in the Y luminance latches 808. At the same time, theHZPF Controller 802 selects the appropriate filter coefficients for the filter phase, and for the CR or CB or Y values, based on a programmed upsampling or downsampling value by a control signal to HorizontalFilter Coefficient RAM 812. - Horizontal
Filter Coefficient RAM 812 then outputs the coefficients to the respective elements of the MultiplyingNetwork 814 for multiplication with the input pixel values to produce weighted pixel values, and the weighted pixel values are combined in AddingNetwork 816 to provide a horizontally filtered CR, CB or Y value. - After combining the weighted pixel values in Adding
network 816, the horizontally filtered pixel value is applied to the Round and Clip processor which provides eight-bit values (since the coefficient multiplication occurs with higher accuracy).DEMUX register 820 receives a series of 8 bit values corresponding to a CR value, an 8 bit even (Y-even) Y value, an eight-bit CB value, and finally an eight-bit value corresponding to an 8-bit odd (Y-odd) Y value; and the DEMUX register 820 multiplexes the values into a horizontally filtered luminance and chrominance pixel pair having a 32 bit value (Y even, CR, Y odd, CB).Register 822 stores and provides the pixel pair as a vertically and horizontally filtered 32 bit pixel luminance and chrominance pixel pair. - FIG. 8B illustrates the spatial relationships between coefficients stored in Horizontal
Filter Coefficient RAM 812 and used in the polyphase filter and the pixel sample values of the down sampled image for a horizontal line. The coefficients for the exemplary embodiment are placed in a 64 bit word from left to right, C0 to C7. The coefficients C0, C1, C6 and C7 are signed 7-bit 2's complement values, and C2 and C5 are signed 8-bit 2's complement and C3 and C4 are signed 10-bit 2's complement values representing a range from −256 to 767. C3 and C4 are adjusted to derive the 11-bit 2's complement values. If bothbit 8 and bit 9 (the most significant bit) are 1, then the sign of the 11-bit value is 1 (negative), otherwise the value is 0 (positive). All coefficients can be interpreted as fractions with a denominator of 512. - Table 13 lists coefficient for the
VPF 282 andHZPF 284 for exemplary embodiments of the present invention performing the indicated format conversion.TABLE 13 Coefficients for 750P to 525P or 750P to 525I 4 tap and 2 polyphase Luminance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 0103 306 103 0 Phase 110 246 246 10 -
Coefficients for 750P to 525P or 750P to 525I 4 tap and 4 polyphase Chrominance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 025 462 25 0 Phase 1−33 424 145 −24 Phase 2−40 296 296 −40 Phase 3−24 145 424 −33 -
Coefficients for 750P to 525I 4 tap and 2 polyphase Luminance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 0145 222 145 0 Phase 184 172 172 84 -
Coefficients for 750P to 525I 4 tap and 4 polyphase Chrominance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 057 398 57 0 Phase 1−6 382 166 −30 Phase 2−29 285 285 −29 Phase 3−30 166 382 −6 -
Coefficients for 1125I to 525P 4 tap and 8 polyphase Luminance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 020 472 20 0 Phase 1−20 425 70 37 Phase 2−52 472 161 −69 Phase 3−62 397 238 −61 Phase 4−63 319 319 −63 Phase 5−61 238 397 −62 Phase 6−69 161 472 −52 Phase 737 70 425 −20 -
Coefficients for 1125I to 525P 4 tap and 16 polyphase Chrominance Vertical Filter Tap 0 Tap 1Tap 2Tap 3Phase 029 454 29 0 Phase 113 455 49 −5 Phase 20 445 73 −6 Phase 3−9 428 101 −8 Phase 4−15 404 132 −9 Phase 5−18 376 165 −11 Phase 6−20 345 201 −14 Phase 7−19 310 237 −16 Phase 8−18 274 274 −18 Phase 9−16 237 310 −19 Phase 10−14 201 345 −20 Phase 11−11 165 376 −18 Phase 12−9 132 404 −15 Phase 13−8 101 428 −9 Phase 14 −6 73 445 0 Phase 15 −5 49 455 13 - In the exemplary embodiments of the display conversion system horizontal conversion is, in part performed by the
DCT domain filter 216, and thedownsampling Processor 232 shown in FIG. 2B. These provide the same number of horizontal pixels (640) whether the conversion is from 1125I or 750P. Accordingly, theHZPF 284 upsamples these signals to provide 720 active pixels per line and passes 525P or 525I signals unmodified, as these signals have 720 active pixels per line as set forth above in Tables 1 and 2, the values of the coefficients of the Horizontal Filter do not change for conversion to 480P/480I/525P/525I. These Horizontal filter coefficients are given in Table 14.TABLE 14 Coefficients for Horizontal Filter Tap 0 Tap 1Tap 2Tap 3Tap 4Tap 5Tap 6Tap 7Phase 0−8 13 −17 536 −17 13 −8 0 Phase 1−13 28 −62 503 48 −9 0 17 Phase 2−14 37 −90 477 134 −37 10 −5 Phase 3−13 38 −96 406 226 −64 22 −7 Phase 4−10 31 −85 320 320 −85 31 −10 Phase 5−7 22 −64 226 406 −96 38 −13 Phase 6−5 10 −37 134 477 −90 37 −14 Phase 717 0 −9 48 503 −62 28 −13 - In addition, the programmable capability of the
HZPF 284 allows for a nonlinear horizontal scan. FIG. 9A illustrates a resampling ratio profile which may be employed with the present invention. As shown the resampling ratio of theHZPF 284 may be varied across the horizontal scan line and may be changed in piecewise linear fashion. In the exemplary configuration of FIG. 9A, at the beginning of the scan line, the resampling ratio increases (or decreases) linearly until a first point on the scan line, where the resampling ration is held constant until a second point is reached where the resampling ratio decreases (or increases) linearly. Referring to FIG. 9A, h_initial_resampling ratio is the initial resampling ratio for a picture, h_resampling_ratio_change is the first change per pixel in the resampling ratio, —h_resampling_ratio_change is the second change per pixel in the resampling ratio, and h_resampling_ratio_hold column and h_resampling_ratio_reverse_column are the display column pixel points between which the resampling ratio is held constant. The value display_width is the last pixel (column) of the picture line. - FIGS. 9B and 9C show ratio profiles for mapping a 4:3 picture onto a 16:9 display. The ratios are defined in terms of input value to output value, so 4/3 is downsampling by 4 to 3 and 1/3 is up
sampling 1 to 3. The ratio profiles shown in FIGS. 9B and 9C map an input picture image having 720 active pixels to a display having 720 active pixels. For example, in FIG. 9B mapping a 4:3 aspect ratio display to a 16×9 aspect ratio display uses a 4/3 downsampling, but to fill all the samples of the display requires a 1/1 average across the horizontal line. Consequently, the profile of FIG. 9B has the correct aspect ratio in the center betweendisplay pixels - The effect of using resampling ratio profiles according to an exemplary embodiment of the present invention may be seen pictorially in FIG. 10. A video transmission format having either a 16×9 or 4×3 aspect ratio may be displayed as either 16×9 or 4×3, but the original video picture may be adjusted to fit within the display area. Consequently, the original video picture may be shown in full, zoom, squeeze, or variable expand/shrink.
- The system allows users to select a preferred mapping between the aspect ratio of the received video signal and the aspect ratio of the display device, when these aspect ratios are incompatible. As set forth above, the control processor207 (shown in FIG. 2A) receives the aspect ratio of the received image from the
parser 209. Thecontrol processor 207 also determines the aspect ratio of the display device (not shown) which is connected to receive the output signal of the system. If, for example, the display device is connected to the S-video output 153 or the composite video output 154 (both shown in FIG. 1A), then the aspect ratio of the display device must be 4 by 3. If, however, the display device is connected to the primaryvideo output port 146, the aspect ratio may be either 4 by 3 or 16 by 9. - In the exemplary embodiment of the invention, the user specifies the aspect ratio of the display device as a part of a start-up process which may be invoked through the remote control IR receiver208 (shown in FIG. 2A). The start up process may only be run if the video decoder system includes a primary output port and the system senses that there is a display device coupled to the primary output port. The start-up process may determine the display format of the display device (i.e. aspect ratio and maximum video resolution) in several ways. First, the process may present the user with a menu of possible display devices, each represented, for example, by a manufacturer name and model number. The user may then use the remote control device to select one of these display devices. The decoder system may be configured with a modem to periodically contact a central location to receive an updated list of display types as well as other updates to the programming of the
controller 207. Alternatively, this type of information may be encoded in the user data of a received ATSC video signal and the decoder may be programmed to access this information to update its internal programming. - Alternatively, to determine the aspect ratio of the display device, the user may be presented with a menu showing a 4 by 3 rectangle and a 16 by 9 rectangle and asked to indicate which is more like their display device. As another alternative, the user may asked to choose two menu choices, one listing possible video display resolutions and another listing possible aspect ratios.
- As yet another alternative, the
control processor 207 may program the on-screen display generator to produce a figure, for example a circle, in several different signal resolutions (e.g. 525I, 525P, 750P, 1180I and 1180P) and several different aspect ratios (e.g. 4 by 3 and 16 by 9), with text asking the viewer to press a button on the remote control device (not shown) when the best circle is displayed. The system may sequentially provide each of these images for a few seconds at the primary output to correlate the pressing of the button on the remote control device with the display of a particular image. This will provide the system with the needed information on image resolution and aspect ratio for the display device. - With information on the display format of the display device, the system may automatically adapt the received video signal for the best possible presentation on the display device. When, for example, there is a mismatch between the aspect ratio of the received video signal and the aspect ratio of the display device, this may be indicated to the viewer and the viewer may be allowed, by invoking a command using the remote control device (not shown), to sequentially see all of the possible conversions between the two aspect ratios, as shown in FIGS. 9A through 9E and FIG. 10, and to select one of these conversions to be used. This applies when the aspect ratio of the received video signal is 4 by 3 and the aspect ratio of the display device is 16 by 9 as well as when the aspect ratio of the received video signal is 16 by 9 and the aspect ratio of the display device is 4 by 3.
- As a final alternative, the system may be configured to sense information provided by the display device in order to determine the display format. For example, a two-way data path may be provided via one of the output signal lines (Y, CR, CB) of the decoder system by which data in a digital register in the display device may be read. The data in this register may indicate a manufacturer and model number or a maximum resolution and aspect ratio for the display device. Alternatively, the display device may impose a direct-current (DC) signal on one or more of these lines and this signal may be sensed by the decoder system as an indication of the display format of the display device.
- It is contemplated that a multi-sync monitor, which is capable of displaying video signals having several different display formats may be connected to the primary output port of the video decoder. In this instance, the video resolution component of the display type information recovered by the
control processor 207 desirably includes an indication that the display is a multi-sync device so that the only format conversion that occurs is the aspect ratio adaptation shown in FIGS. 9A through 9E and FIG. 10, when the aspect ratio of the received video signal does not match that of the display device. - While exemplary embodiments of the invention have been shown and described herein, it will be understood that such embodiments are provided by way of example only. Numerous variations, changes, and substitutions will occur to those skilled in the art without departing from the spirit of the invention. Accordingly, it is intended that the appended claims cover all such variations as fall within the scope of the invention.
Claims (20)
1. A method for determining a display format of a display device, the method comprising the steps of:
sensing information provided by a display device having a display format, the sensed information being indicative of the display format of the display device; and
determining the display format of the display device responsive to the sensed information.
2. The method of claim 1 , wherein the display device includes a register containing information indicative of the display format and wherein the sensing step comprises at least the step of:
reading the register to obtain the information indicative of the display format.
3. The method of claim 2 , wherein the register includes a manufacturer and model number of the display device and wherein the determining step comprises at least the step of:
determining the display format for the display device based on the manufacturer and model number read from the register.
4. The method of claim 2 , wherein the register includes an aspect ratio and resolution of the display device and wherein the determining step comprises at least the step of:
determining the display format for the display device based on the aspect ratio and resolution read from the register.
5. The method of claim 2 , wherein the reading step comprises at least the step of:
reading the register over at least one video signal line coupled to the display device, the at least one video signal line configured as a two-way data path.
6. A method for determining display device characteristics, the method comprising the steps of:
sensing information provided by a display device having display parameters, the sensed information being indicative of the display parameters of the display device; and
determining the display device characteristics responsive to the sensed information.
7. The method of claim 6 , wherein the display device includes a register containing data indicative of the display parameters and wherein the sensing step comprises at least the step of:
reading the register to obtain the data indicative of the display parameters.
8. The method of claim 7 , wherein the register includes data indicative of a manufacturer and model number of the display device and wherein the determining step comprises at least the step of:
determining a display format for the display device responsive to the manufacturer and model number.
9. The method of claim 7 , wherein the register includes data indicative of an aspect ratio and resolution of the display device and wherein the determining step comprises at least the step of:
determining a display format for the display device responsive to data indicative of the aspect ratio and resolution.
10. The method of claim 7 , wherein the register includes data indicative of an aspect ratio of the display device and wherein the determining step comprises at least the step of:
determining the aspect ratio of the display device from the read data.
11. The method of claim 7 , wherein the register includes data indicative of a resolution of the display device and wherein the determining step comprises at least the step of:
determining the resolution of the display device from the read data.
12. The method of claim 7 , wherein the reading step comprises at least the step of:
reading the register over at least one video signal line coupled to the display device, the at least one video signal line configured as a two-way data path.
13. A video monitor including:
a display device;
a digital register coupled to the display device, the digital register including data indicative of at least one characteristic of the display device; and
a data path coupled to the digital register to provide the data indicative of the at least one characteristic of the display device to an output port.
14. The video monitor of claim 13 , wherein the data path is a video signal path configured as a two-way data path.
15. The video monitor of claim 13 , wherein the at least one characteristic includes an aspect ratio of the display.
16. The video monitor of claim 13 , wherein the at least one characteristic includes a resolution of the display.
17. The television of claim 13 , wherein the at least one characteristic includes manufacturer and model number of the display.
18. A video display system including:
a video display having a register including data indicative of at least one characteristic of the video display; and
a decoder configured to read the data in the register of the video display and determine the at least one characteristic of the video display from the data.
19. A video display system according to claim 18 , wherein the at least one characteristic includes an aspect ratio of the display.
20. A video display system according to claim 18 , wherein the at least one characteristic includes a resolution of the display.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/672,773 US20040150747A1 (en) | 1997-03-12 | 2003-09-26 | HDTV downconversion system |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US4051797P | 1997-03-12 | 1997-03-12 | |
US09/180,243 US6788347B1 (en) | 1997-03-12 | 1998-03-11 | HDTV downconversion system |
US10/672,773 US20040150747A1 (en) | 1997-03-12 | 2003-09-26 | HDTV downconversion system |
Related Parent Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/180,243 Division US6788347B1 (en) | 1997-03-12 | 1998-03-11 | HDTV downconversion system |
PCT/US1998/004749 Division WO1998041011A1 (en) | 1997-03-12 | 1998-03-11 | Hdtv downconversion system |
Publications (1)
Publication Number | Publication Date |
---|---|
US20040150747A1 true US20040150747A1 (en) | 2004-08-05 |
Family
ID=32775378
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/180,243 Expired - Fee Related US6788347B1 (en) | 1997-03-12 | 1998-03-11 | HDTV downconversion system |
US10/672,773 Abandoned US20040150747A1 (en) | 1997-03-12 | 2003-09-26 | HDTV downconversion system |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/180,243 Expired - Fee Related US6788347B1 (en) | 1997-03-12 | 1998-03-11 | HDTV downconversion system |
Country Status (1)
Country | Link |
---|---|
US (2) | US6788347B1 (en) |
Cited By (39)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020113947A1 (en) * | 2001-02-07 | 2002-08-22 | Seiko Epson Corporation | Image display apparatus |
US20030103166A1 (en) * | 2001-11-21 | 2003-06-05 | Macinnis Alexander G. | Method and apparatus for vertical compression and de-compression of progressive video data |
US20030189666A1 (en) * | 2002-04-08 | 2003-10-09 | Steven Dabell | Multi-channel digital video broadcast to composite analog video converter |
US20030190136A1 (en) * | 2000-03-09 | 2003-10-09 | Yukihiro Yamamoto | Magnetic recording and reproducing apparatus |
US20040215965A1 (en) * | 2003-04-25 | 2004-10-28 | Kabushiki Kaisha Toshiba | Image processing system |
US20060050976A1 (en) * | 2004-09-09 | 2006-03-09 | Stephen Molloy | Caching method and apparatus for video motion compensation |
US7020195B1 (en) * | 1999-12-10 | 2006-03-28 | Microsoft Corporation | Layered coding and decoding of image data |
US20060078180A1 (en) * | 2002-12-30 | 2006-04-13 | Berretty Robert-Paul M | Video filtering for stereo images |
US20070052871A1 (en) * | 2005-09-06 | 2007-03-08 | Taft Frederick D | Selectively masking image data |
US20070076750A1 (en) * | 2005-09-30 | 2007-04-05 | Microsoft Corporation | Device driver interface architecture |
US20080001977A1 (en) * | 2006-06-30 | 2008-01-03 | Aufranc Richard E | Generating and displaying spatially offset sub-frames |
US20080022335A1 (en) * | 2006-07-24 | 2008-01-24 | Nabil Yousef | A receiver with a visual program guide for mobile television applications and method for creation |
US20080068499A1 (en) * | 2006-08-30 | 2008-03-20 | Sony Corporation | Image processing method, image processing program and image processing apparatus, and playback method, playback program and playback apparatus |
US20080187045A1 (en) * | 2004-10-20 | 2008-08-07 | Thomson Licensing | Method for Hierarchically Coding Video Images |
US20090167941A1 (en) * | 2007-12-28 | 2009-07-02 | Kabushiki Kaisha Toshiba | Video data reception apparatus and video data transmission and reception system |
US20090168895A1 (en) * | 2005-04-15 | 2009-07-02 | Franck Abelard | High-definition and single-definition digital television decoder |
WO2010047805A2 (en) * | 2008-10-22 | 2010-04-29 | Vns Portfolio Llc | System for signal sample rate conversion |
US20100158124A1 (en) * | 2008-12-19 | 2010-06-24 | Tandberg Telecom As | Filter process in compression/decompression of digital video systems |
US20100188566A1 (en) * | 2006-11-29 | 2010-07-29 | Panasonic Corporation | Video/audio signal input/output device, video/audio reproduction device, video/audio device network and signal reproducing method |
US20100238355A1 (en) * | 2007-09-10 | 2010-09-23 | Volker Blume | Method And Apparatus For Line Based Vertical Motion Estimation And Compensation |
US20100246682A1 (en) * | 2009-03-27 | 2010-09-30 | Vixs Systems, Inc. | Scaled motion search section with downscaling and method for use therewith |
US20110013737A1 (en) * | 2009-07-20 | 2011-01-20 | Electronics And Telecommunications Research Institute | Time synchronization apparatus based on parallel processing |
US20110314253A1 (en) * | 2010-06-22 | 2011-12-22 | Jacob Yaakov Jeffrey Allan Alon | System, data structure, and method for transposing multi-dimensional data to switch between vertical and horizontal filters |
US20120162227A1 (en) * | 2010-12-24 | 2012-06-28 | Li-Po Chou | Method of Picture Display and Device Thereof |
US20130051767A1 (en) * | 2011-08-30 | 2013-02-28 | Rovi Corp. | Selection of Resolutions for Seamless Resolution Switching of Multimedia Content |
US20140226070A1 (en) * | 2013-02-08 | 2014-08-14 | Ati Technologies Ulc | Method and apparatus for reconstructing motion compensated video frames |
US20140333669A1 (en) * | 2013-05-08 | 2014-11-13 | Nvidia Corporation | System, method, and computer program product for implementing smooth user interface animation using motion blur |
US20150124165A1 (en) * | 2013-11-05 | 2015-05-07 | Broadcom Corporaton | Parallel pipelines for multiple-quality level video processing |
US20150124888A1 (en) * | 2012-11-07 | 2015-05-07 | Lg Elelctronics Inc. | Apparatus for transreceiving signals and method for transreceiving signals |
US20160112667A1 (en) * | 2013-06-10 | 2016-04-21 | Lg Electronics Inc. | Multimedia device having flexible display and controlling method thereof |
US9510031B2 (en) | 2011-08-30 | 2016-11-29 | Sonic Ip, Inc. | Systems and methods for encoding alternative streams of video for playback on playback devices having predetermined display aspect ratios and network connection maximum data rates |
US20170025093A1 (en) * | 2014-03-18 | 2017-01-26 | Mediatek Inc. | Data processing apparatus for performing display data compression/decompression with color format conversion and related data processing method |
WO2017021688A1 (en) * | 2015-07-31 | 2017-02-09 | Forbidden Technologies Plc | Compressor |
US20170118379A1 (en) * | 2015-10-23 | 2017-04-27 | Ricoh Company, Ltd. | Image processing device, image forming apparatus, and image processing method |
US9955195B2 (en) | 2011-08-30 | 2018-04-24 | Divx, Llc | Systems and methods for encoding and streaming video encoded using a plurality of maximum bitrate levels |
US10148989B2 (en) | 2016-06-15 | 2018-12-04 | Divx, Llc | Systems and methods for encoding video content |
US20210352318A1 (en) * | 2018-06-20 | 2021-11-11 | Tencent Technology (Shenzhen) Company Limited | Method and apparatus for video decoding |
US11638033B2 (en) | 2011-01-05 | 2023-04-25 | Divx, Llc | Systems and methods for performing adaptive bitrate streaming |
US11785066B2 (en) | 2012-12-31 | 2023-10-10 | Divx, Llc | Systems, methods, and media for controlling delivery of content |
Families Citing this family (63)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP3564961B2 (en) * | 1997-08-21 | 2004-09-15 | 株式会社日立製作所 | Digital broadcast receiver |
KR20010071519A (en) * | 1998-06-19 | 2001-07-28 | 벤자민 에프 커틀러 | Decoding an encoded image having a first resolution directly into a decoded image having a second resolution |
US7995896B1 (en) * | 1999-11-04 | 2011-08-09 | Thomson Licensing | System and user interface for a television receiver in a television program distribution system |
KR100357098B1 (en) * | 1999-11-12 | 2002-10-19 | 엘지전자 주식회사 | apparatus and method for display of data information in data broadcasting reciever |
KR100689724B1 (en) * | 2000-01-28 | 2007-03-09 | 후지쯔 가부시끼가이샤 | Clock switching circuit for a hot plug |
US6791578B1 (en) * | 2000-05-30 | 2004-09-14 | Apple Computer, Inc. | 16:9 aspect ratio and anamorphic image processing |
TW519840B (en) * | 2000-06-02 | 2003-02-01 | Sony Corp | Image coding apparatus and method, image decoding apparatus and method, and recording medium |
KR100370248B1 (en) * | 2000-08-08 | 2003-01-30 | 엘지전자 주식회사 | Digital television |
US6648543B2 (en) * | 2001-04-19 | 2003-11-18 | Saab Ericsson Space Ab | Device for a space vessel |
WO2002087256A1 (en) * | 2001-04-20 | 2002-10-31 | Mti Film Llc | High resolution image color correction method and system |
US7215708B2 (en) * | 2001-05-22 | 2007-05-08 | Koninklijke Philips Electronics N.V. | Resolution downscaling of video images |
KR100442239B1 (en) * | 2001-06-01 | 2004-07-30 | 엘지전자 주식회사 | Method for Displaying Video Signal of Digital TV |
FR2830157A1 (en) * | 2001-09-25 | 2003-03-28 | Koninkl Philips Electronics Nv | Second video image standard decoding from first MPEG standard video image having inverse quantification and truncation/zero adding/discrete inverse stages providing filtered block/decoded digital words. |
KR100412503B1 (en) * | 2001-12-13 | 2003-12-31 | 삼성전자주식회사 | SetTop Box capable of setting easily resolution of digital broadcast signal |
US8284844B2 (en) | 2002-04-01 | 2012-10-09 | Broadcom Corporation | Video decoding system supporting multiple standards |
US6912255B2 (en) * | 2002-05-30 | 2005-06-28 | Mobixell Netwoks Inc. | Bit rate control through selective modification of DCT coefficients |
US6894726B2 (en) * | 2002-07-05 | 2005-05-17 | Thomson Licensing S.A. | High-definition de-interlacing and frame doubling circuit and method |
US7009655B2 (en) * | 2002-07-23 | 2006-03-07 | Mediostream, Inc. | Method and system for direct recording of video information onto a disk medium |
JP4017498B2 (en) * | 2002-11-05 | 2007-12-05 | 松下電器産業株式会社 | Imaging device |
US7272258B2 (en) * | 2003-01-29 | 2007-09-18 | Ricoh Co., Ltd. | Reformatting documents using document analysis information |
US7154557B2 (en) * | 2003-02-11 | 2006-12-26 | Texas Instruments Incorporated | Joint pre-/post-processing approach for chrominance mis-alignment |
US7233703B2 (en) * | 2003-03-25 | 2007-06-19 | Sharp Laboratories Of America, Inc. | Computation-reduced IDCT method for video coding |
KR20060105408A (en) * | 2005-04-01 | 2006-10-11 | 엘지전자 주식회사 | Method for scalably encoding and decoding video signal |
KR20060109247A (en) * | 2005-04-13 | 2006-10-19 | 엘지전자 주식회사 | Method and apparatus for encoding/decoding a video signal using pictures of base layer |
US8761252B2 (en) * | 2003-03-27 | 2014-06-24 | Lg Electronics Inc. | Method and apparatus for scalably encoding and decoding video signal |
KR100617178B1 (en) * | 2003-06-13 | 2006-08-30 | 엘지전자 주식회사 | Apparatus and method for zoom transfer of television system |
US20040252762A1 (en) * | 2003-06-16 | 2004-12-16 | Pai R. Lakshmikanth | System, method, and apparatus for reducing memory and bandwidth requirements in decoder system |
US20050030386A1 (en) * | 2003-08-04 | 2005-02-10 | John Kamieniecki | Method and apparatus for determining video formats supported by a digital television receiver |
US7443404B2 (en) * | 2003-10-17 | 2008-10-28 | Casio Computer Co., Ltd. | Image display apparatus, image display controlling method, and image display program |
US7307664B2 (en) * | 2004-05-17 | 2007-12-11 | Ati Technologies Inc. | Method and apparatus for deinterlacing interleaved video |
US20060062478A1 (en) * | 2004-08-16 | 2006-03-23 | Grandeye, Ltd., | Region-sensitive compression of digital video |
EP1655966A3 (en) * | 2004-10-26 | 2011-04-27 | Samsung Electronics Co., Ltd. | Apparatus and method for processing an image signal in a digital broadcast receiver |
JP3858923B2 (en) * | 2004-11-02 | 2006-12-20 | 船井電機株式会社 | Video display device and video display method of video display device |
TWI248762B (en) * | 2004-11-10 | 2006-02-01 | Realtek Semiconductor Corp | Video processing device and method thereof |
JP4736456B2 (en) * | 2005-02-15 | 2011-07-27 | 株式会社日立製作所 | Scanning line interpolation device, video display device, video signal processing device |
US8660180B2 (en) * | 2005-04-01 | 2014-02-25 | Lg Electronics Inc. | Method and apparatus for scalably encoding and decoding video signal |
EP1880552A4 (en) * | 2005-04-13 | 2011-03-09 | Lg Electronics Inc | Method and apparatus for encoding/decoding video signal using reference pictures |
US8755434B2 (en) * | 2005-07-22 | 2014-06-17 | Lg Electronics Inc. | Method and apparatus for scalably encoding and decoding video signal |
US7872668B2 (en) * | 2005-08-26 | 2011-01-18 | Nvidia Corporation | Video image processing with programmable scripting and remote diagnosis |
KR20070048025A (en) * | 2005-11-03 | 2007-05-08 | 삼성전자주식회사 | Apparatus and method for outputting multimedia data |
US7761789B2 (en) | 2006-01-13 | 2010-07-20 | Ricoh Company, Ltd. | Methods for computing a navigation path |
CN101379812A (en) * | 2006-02-03 | 2009-03-04 | Nxp股份有限公司 | Video processing device and method of processing video data |
US7788579B2 (en) * | 2006-03-06 | 2010-08-31 | Ricoh Co., Ltd. | Automated document layout design |
KR100720871B1 (en) * | 2006-06-20 | 2007-05-23 | 삼성전자주식회사 | Apparatus and method for low distortion display in portable communication terminal |
US8023729B2 (en) * | 2006-08-03 | 2011-09-20 | Tektronix, Inc. | Apparatus and method of reducing color smearing artifacts in a low resolution picture |
US8731064B2 (en) * | 2006-09-11 | 2014-05-20 | Apple Inc. | Post-processing for decoder complexity scalability |
TWI319959B (en) * | 2006-11-29 | 2010-01-21 | Image transmission interface | |
US7881511B2 (en) * | 2007-01-19 | 2011-02-01 | Korea Advanced Institute Of Science And Technology | Method for super-resolution reconstruction using focal underdetermined system solver algorithm |
US20080235564A1 (en) * | 2007-03-21 | 2008-09-25 | Ricoh Co., Ltd. | Methods for converting electronic content descriptions |
US8583637B2 (en) * | 2007-03-21 | 2013-11-12 | Ricoh Co., Ltd. | Coarse-to-fine navigation through paginated documents retrieved by a text search engine |
US8584042B2 (en) | 2007-03-21 | 2013-11-12 | Ricoh Co., Ltd. | Methods for scanning, printing, and copying multimedia thumbnails |
US8812969B2 (en) * | 2007-03-21 | 2014-08-19 | Ricoh Co., Ltd. | Methods for authoring and interacting with multimedia representations of documents |
US8031222B2 (en) * | 2007-04-25 | 2011-10-04 | Microsoft Corporation | Multiple resolution capture in real time communications |
US20090113504A1 (en) * | 2007-10-26 | 2009-04-30 | John Mezzalingua Associates, Inc. | Digital Signal Converter Device |
JP4543105B2 (en) * | 2008-08-08 | 2010-09-15 | 株式会社東芝 | Information reproduction apparatus and reproduction control method |
KR101634562B1 (en) * | 2009-09-22 | 2016-06-30 | 삼성전자주식회사 | Method for producing high definition video from low definition video |
WO2013036972A1 (en) | 2011-09-09 | 2013-03-14 | Panamorph, Inc. | Image processing system and method |
US9392214B2 (en) * | 2013-02-06 | 2016-07-12 | Gyrus Acmi, Inc. | High definition video recorder/player |
US9135720B2 (en) * | 2013-03-27 | 2015-09-15 | Stmicroelectronics Asia Pacific Pte. Ltd. | Content-based aspect ratio detection |
JP6365899B2 (en) * | 2013-08-22 | 2018-08-01 | ソニー株式会社 | Signal processing apparatus, signal processing method, program, and signal transmission system |
CN104916250B (en) * | 2015-06-26 | 2018-03-06 | 合肥鑫晟光电科技有限公司 | A kind of data transmission method and device, display device |
US9571786B1 (en) * | 2015-10-15 | 2017-02-14 | Eth Zurich | Systems and methods for interpolating frames of a video |
US9911215B1 (en) | 2016-11-04 | 2018-03-06 | Disney Enterprises, Inc. | Systems and methods for propagating edits through a video |
Citations (34)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3997772A (en) * | 1975-09-05 | 1976-12-14 | Bell Telephone Laboratories, Incorporated | Digital phase shifter |
US4468688A (en) * | 1981-04-10 | 1984-08-28 | Ampex Corporation | Controller for system for spatially transforming images |
US4472785A (en) * | 1980-10-13 | 1984-09-18 | Victor Company Of Japan, Ltd. | Sampling frequency converter |
US4472732A (en) * | 1981-04-10 | 1984-09-18 | Ampex Corporation | System for spatially transforming images |
US4536745A (en) * | 1982-06-15 | 1985-08-20 | Kokusai Denshin Denwa Co., Ltd. | Sampling frequency conversion device |
US4562450A (en) * | 1983-03-07 | 1985-12-31 | International Business Machines Corporation | Data management for plasma display |
US4631750A (en) * | 1980-04-11 | 1986-12-23 | Ampex Corporation | Method and system for spacially transforming images |
US4652908A (en) * | 1985-03-25 | 1987-03-24 | Rca Corporation | Filtering system for processing a reduced-resolution video image |
US4774581A (en) * | 1987-04-14 | 1988-09-27 | Rca Licensing Corporation | Television picture zoom system |
US4870661A (en) * | 1986-09-30 | 1989-09-26 | Kabushiki Kaisha Toshiba | Sample rate conversion system having interpolation function |
US4897799A (en) * | 1987-09-15 | 1990-01-30 | Bell Communications Research, Inc. | Format independent visual communications |
US4908874A (en) * | 1980-04-11 | 1990-03-13 | Ampex Corporation | System for spatially transforming images |
US5028995A (en) * | 1987-10-28 | 1991-07-02 | Hitachi, Ltd. | Picture signal processor, picture signal coder and picture signal interpolator |
US5038301A (en) * | 1987-07-31 | 1991-08-06 | Compaq Computer Corporation | Method and apparatus for multi-monitor adaptation circuit |
US5057911A (en) * | 1989-10-19 | 1991-10-15 | Matsushita Electric Industrial Co., Ltd. | System and method for conversion of digital video signals |
US5262854A (en) * | 1992-02-21 | 1993-11-16 | Rca Thomson Licensing Corporation | Lower resolution HDTV receivers |
US5274372A (en) * | 1992-10-23 | 1993-12-28 | Tektronix, Inc. | Sampling rate conversion using polyphase filters with interpolation |
US5327235A (en) * | 1992-02-17 | 1994-07-05 | Sony United Kingdom Limited | Video conversions of video signal formats |
US5331346A (en) * | 1992-10-07 | 1994-07-19 | Panasonic Technologies, Inc. | Approximating sample rate conversion system |
US5389923A (en) * | 1992-03-31 | 1995-02-14 | Sony Corporation | Sampling rate converter |
US5481568A (en) * | 1992-02-14 | 1996-01-02 | Sony Corporation | Data detecting apparatus using an over sampling and an interpolation means |
US5483474A (en) * | 1993-11-15 | 1996-01-09 | North Shore Laboratories, Inc. | D-dimensional, fractional bandwidth signal processing apparatus |
US5489903A (en) * | 1993-09-13 | 1996-02-06 | Analog Devices, Inc. | Digital to analog conversion using non-uniform sample rates |
US5519446A (en) * | 1993-11-13 | 1996-05-21 | Goldstar Co., Ltd. | Apparatus and method for converting an HDTV signal to a non-HDTV signal |
US5528301A (en) * | 1995-03-31 | 1996-06-18 | Panasonic Technologies, Inc. | Universal video format sample size converter |
US5572259A (en) * | 1993-10-29 | 1996-11-05 | Maki Enterprise Inc. | Method of changing personal computer monitor output for use by a general purpose video display |
US5613084A (en) * | 1994-10-04 | 1997-03-18 | Panasonic Technologies, Inc. | Interpolation filter selection circuit for sample rate conversion using phase quantization |
US5737019A (en) * | 1996-01-29 | 1998-04-07 | Matsushita Electric Corporation Of America | Method and apparatus for changing resolution by direct DCT mapping |
US5754437A (en) * | 1996-09-10 | 1998-05-19 | Tektronix, Inc. | Phase measurement apparatus and method |
US5835151A (en) * | 1996-05-15 | 1998-11-10 | Mitsubishi Electric Information Technology Center America | Method and apparatus for down-converting a digital signal |
US6078361A (en) * | 1996-11-18 | 2000-06-20 | Sage, Inc | Video adapter circuit for conversion of an analog video signal to a digital display image |
US6104753A (en) * | 1996-02-03 | 2000-08-15 | Lg Electronics Inc. | Device and method for decoding HDTV video |
US6262770B1 (en) * | 1993-01-13 | 2001-07-17 | Hitachi America, Ltd. | Methods and apparatus for decoding high and standard definition images and for decoding digital data representing images at less than the image's full resolution |
US6292621B1 (en) * | 1996-02-05 | 2001-09-18 | Canon Kabushiki Kaisha | Recording apparatus for newly recording a second encoded data train on a recording medium on which an encoded data train is recorded |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5367334A (en) | 1991-05-20 | 1994-11-22 | Matsushita Electric Industrial Co., Ltd. | Video signal encoding and decoding apparatus |
JP3093494B2 (en) | 1992-11-18 | 2000-10-03 | 株式会社東芝 | Diversity signal processing device |
AU701684B2 (en) | 1994-12-14 | 1999-02-04 | Koninklijke Philips Electronics N.V. | Subtitling transmission system |
JPH08181988A (en) | 1994-12-26 | 1996-07-12 | Canon Inc | Moving image processing unit |
JP3855282B2 (en) | 1995-02-06 | 2006-12-06 | ソニー株式会社 | Receiving apparatus and receiving method |
JP4330040B2 (en) | 1995-06-29 | 2009-09-09 | トムソン マルチメデイア ソシエテ アノニム | System for encoding and decoding layered compressed video data |
-
1998
- 1998-03-11 US US09/180,243 patent/US6788347B1/en not_active Expired - Fee Related
-
2003
- 2003-09-26 US US10/672,773 patent/US20040150747A1/en not_active Abandoned
Patent Citations (34)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3997772A (en) * | 1975-09-05 | 1976-12-14 | Bell Telephone Laboratories, Incorporated | Digital phase shifter |
US4631750A (en) * | 1980-04-11 | 1986-12-23 | Ampex Corporation | Method and system for spacially transforming images |
US4908874A (en) * | 1980-04-11 | 1990-03-13 | Ampex Corporation | System for spatially transforming images |
US4472785A (en) * | 1980-10-13 | 1984-09-18 | Victor Company Of Japan, Ltd. | Sampling frequency converter |
US4468688A (en) * | 1981-04-10 | 1984-08-28 | Ampex Corporation | Controller for system for spatially transforming images |
US4472732A (en) * | 1981-04-10 | 1984-09-18 | Ampex Corporation | System for spatially transforming images |
US4536745A (en) * | 1982-06-15 | 1985-08-20 | Kokusai Denshin Denwa Co., Ltd. | Sampling frequency conversion device |
US4562450A (en) * | 1983-03-07 | 1985-12-31 | International Business Machines Corporation | Data management for plasma display |
US4652908A (en) * | 1985-03-25 | 1987-03-24 | Rca Corporation | Filtering system for processing a reduced-resolution video image |
US4870661A (en) * | 1986-09-30 | 1989-09-26 | Kabushiki Kaisha Toshiba | Sample rate conversion system having interpolation function |
US4774581A (en) * | 1987-04-14 | 1988-09-27 | Rca Licensing Corporation | Television picture zoom system |
US5038301A (en) * | 1987-07-31 | 1991-08-06 | Compaq Computer Corporation | Method and apparatus for multi-monitor adaptation circuit |
US4897799A (en) * | 1987-09-15 | 1990-01-30 | Bell Communications Research, Inc. | Format independent visual communications |
US5028995A (en) * | 1987-10-28 | 1991-07-02 | Hitachi, Ltd. | Picture signal processor, picture signal coder and picture signal interpolator |
US5057911A (en) * | 1989-10-19 | 1991-10-15 | Matsushita Electric Industrial Co., Ltd. | System and method for conversion of digital video signals |
US5481568A (en) * | 1992-02-14 | 1996-01-02 | Sony Corporation | Data detecting apparatus using an over sampling and an interpolation means |
US5327235A (en) * | 1992-02-17 | 1994-07-05 | Sony United Kingdom Limited | Video conversions of video signal formats |
US5262854A (en) * | 1992-02-21 | 1993-11-16 | Rca Thomson Licensing Corporation | Lower resolution HDTV receivers |
US5389923A (en) * | 1992-03-31 | 1995-02-14 | Sony Corporation | Sampling rate converter |
US5331346A (en) * | 1992-10-07 | 1994-07-19 | Panasonic Technologies, Inc. | Approximating sample rate conversion system |
US5274372A (en) * | 1992-10-23 | 1993-12-28 | Tektronix, Inc. | Sampling rate conversion using polyphase filters with interpolation |
US6262770B1 (en) * | 1993-01-13 | 2001-07-17 | Hitachi America, Ltd. | Methods and apparatus for decoding high and standard definition images and for decoding digital data representing images at less than the image's full resolution |
US5489903A (en) * | 1993-09-13 | 1996-02-06 | Analog Devices, Inc. | Digital to analog conversion using non-uniform sample rates |
US5572259A (en) * | 1993-10-29 | 1996-11-05 | Maki Enterprise Inc. | Method of changing personal computer monitor output for use by a general purpose video display |
US5519446A (en) * | 1993-11-13 | 1996-05-21 | Goldstar Co., Ltd. | Apparatus and method for converting an HDTV signal to a non-HDTV signal |
US5483474A (en) * | 1993-11-15 | 1996-01-09 | North Shore Laboratories, Inc. | D-dimensional, fractional bandwidth signal processing apparatus |
US5613084A (en) * | 1994-10-04 | 1997-03-18 | Panasonic Technologies, Inc. | Interpolation filter selection circuit for sample rate conversion using phase quantization |
US5528301A (en) * | 1995-03-31 | 1996-06-18 | Panasonic Technologies, Inc. | Universal video format sample size converter |
US5737019A (en) * | 1996-01-29 | 1998-04-07 | Matsushita Electric Corporation Of America | Method and apparatus for changing resolution by direct DCT mapping |
US6104753A (en) * | 1996-02-03 | 2000-08-15 | Lg Electronics Inc. | Device and method for decoding HDTV video |
US6292621B1 (en) * | 1996-02-05 | 2001-09-18 | Canon Kabushiki Kaisha | Recording apparatus for newly recording a second encoded data train on a recording medium on which an encoded data train is recorded |
US5835151A (en) * | 1996-05-15 | 1998-11-10 | Mitsubishi Electric Information Technology Center America | Method and apparatus for down-converting a digital signal |
US5754437A (en) * | 1996-09-10 | 1998-05-19 | Tektronix, Inc. | Phase measurement apparatus and method |
US6078361A (en) * | 1996-11-18 | 2000-06-20 | Sage, Inc | Video adapter circuit for conversion of an analog video signal to a digital display image |
Cited By (78)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7020195B1 (en) * | 1999-12-10 | 2006-03-28 | Microsoft Corporation | Layered coding and decoding of image data |
US20030190136A1 (en) * | 2000-03-09 | 2003-10-09 | Yukihiro Yamamoto | Magnetic recording and reproducing apparatus |
US7043135B2 (en) * | 2000-03-09 | 2006-05-09 | Matsushita Electric Industrial Co., Ltd. | Magnetic recording and reproducing apparatus |
US7019792B2 (en) * | 2001-02-07 | 2006-03-28 | Seiko Epson Corporation | Image display apparatus |
US20020113947A1 (en) * | 2001-02-07 | 2002-08-22 | Seiko Epson Corporation | Image display apparatus |
US20030103166A1 (en) * | 2001-11-21 | 2003-06-05 | Macinnis Alexander G. | Method and apparatus for vertical compression and de-compression of progressive video data |
US20030189666A1 (en) * | 2002-04-08 | 2003-10-09 | Steven Dabell | Multi-channel digital video broadcast to composite analog video converter |
US20060078180A1 (en) * | 2002-12-30 | 2006-04-13 | Berretty Robert-Paul M | Video filtering for stereo images |
US7689031B2 (en) * | 2002-12-30 | 2010-03-30 | Koninklijke Philips Electronics N.V. | Video filtering for stereo images |
US6883982B2 (en) * | 2003-04-25 | 2005-04-26 | Kabushiki Kaisha Toshiba | Image processing system |
US20040215965A1 (en) * | 2003-04-25 | 2004-10-28 | Kabushiki Kaisha Toshiba | Image processing system |
US20060050976A1 (en) * | 2004-09-09 | 2006-03-09 | Stephen Molloy | Caching method and apparatus for video motion compensation |
US20080187045A1 (en) * | 2004-10-20 | 2008-08-07 | Thomson Licensing | Method for Hierarchically Coding Video Images |
US8306119B2 (en) * | 2004-10-20 | 2012-11-06 | Thomson Licensing | Method for hierarchically coding video images |
US20090168895A1 (en) * | 2005-04-15 | 2009-07-02 | Franck Abelard | High-definition and single-definition digital television decoder |
US20070052871A1 (en) * | 2005-09-06 | 2007-03-08 | Taft Frederick D | Selectively masking image data |
US8174627B2 (en) | 2005-09-06 | 2012-05-08 | Hewlett-Packard Development Company, L.P. | Selectively masking image data |
US20070076750A1 (en) * | 2005-09-30 | 2007-04-05 | Microsoft Corporation | Device driver interface architecture |
US20080001977A1 (en) * | 2006-06-30 | 2008-01-03 | Aufranc Richard E | Generating and displaying spatially offset sub-frames |
WO2008014030A2 (en) * | 2006-07-24 | 2008-01-31 | Newport Media, Inc. | A receiver with a visual program guide for mobile television applications and method for creation |
WO2008014030A3 (en) * | 2006-07-24 | 2008-03-27 | Newport Media Inc | A receiver with a visual program guide for mobile television applications and method for creation |
US20080022335A1 (en) * | 2006-07-24 | 2008-01-24 | Nabil Yousef | A receiver with a visual program guide for mobile television applications and method for creation |
US7707611B2 (en) | 2006-07-24 | 2010-04-27 | Newport Media, Inc. | Receiver with a visual program guide for mobile television applications and method for creation |
US20080068499A1 (en) * | 2006-08-30 | 2008-03-20 | Sony Corporation | Image processing method, image processing program and image processing apparatus, and playback method, playback program and playback apparatus |
US8269887B2 (en) * | 2006-08-30 | 2012-09-18 | Sony Corporation | Image processing method, image processing program and image processing apparatus, and playback method, playback program and playback apparatus |
US8325278B2 (en) * | 2006-11-29 | 2012-12-04 | Panasonic Corporation | Video display based on video signal and audio output based on audio signal, video/audio device network including video/audio signal input/output device and video/audio reproduction device, and signal reproducing method |
US20100188566A1 (en) * | 2006-11-29 | 2010-07-29 | Panasonic Corporation | Video/audio signal input/output device, video/audio reproduction device, video/audio device network and signal reproducing method |
US20100238355A1 (en) * | 2007-09-10 | 2010-09-23 | Volker Blume | Method And Apparatus For Line Based Vertical Motion Estimation And Compensation |
US8526502B2 (en) * | 2007-09-10 | 2013-09-03 | Entropic Communications, Inc. | Method and apparatus for line based vertical motion estimation and compensation |
US20090167941A1 (en) * | 2007-12-28 | 2009-07-02 | Kabushiki Kaisha Toshiba | Video data reception apparatus and video data transmission and reception system |
WO2010047805A3 (en) * | 2008-10-22 | 2010-07-01 | Vns Portfolio Llc | System for signal sample rate conversion |
WO2010047805A2 (en) * | 2008-10-22 | 2010-04-29 | Vns Portfolio Llc | System for signal sample rate conversion |
CN102257530A (en) * | 2008-12-19 | 2011-11-23 | 坦德伯格电信公司 | Video compression/decompression systems |
US20100158124A1 (en) * | 2008-12-19 | 2010-06-24 | Tandberg Telecom As | Filter process in compression/decompression of digital video systems |
US8891629B2 (en) * | 2008-12-19 | 2014-11-18 | Cisco Technology, Inc. | Filter process in compression/decompression of digital video systems |
US20100246682A1 (en) * | 2009-03-27 | 2010-09-30 | Vixs Systems, Inc. | Scaled motion search section with downscaling and method for use therewith |
US20110013737A1 (en) * | 2009-07-20 | 2011-01-20 | Electronics And Telecommunications Research Institute | Time synchronization apparatus based on parallel processing |
US8532241B2 (en) * | 2009-07-20 | 2013-09-10 | Electronics and Telecommunications Research and Instittute | Time synchronization apparatus based on parallel processing |
US20110314253A1 (en) * | 2010-06-22 | 2011-12-22 | Jacob Yaakov Jeffrey Allan Alon | System, data structure, and method for transposing multi-dimensional data to switch between vertical and horizontal filters |
CN102543045A (en) * | 2010-12-24 | 2012-07-04 | 纬创资通股份有限公司 | Method and related device for displaying picture |
US20120162227A1 (en) * | 2010-12-24 | 2012-06-28 | Li-Po Chou | Method of Picture Display and Device Thereof |
US11638033B2 (en) | 2011-01-05 | 2023-04-25 | Divx, Llc | Systems and methods for performing adaptive bitrate streaming |
US20130051767A1 (en) * | 2011-08-30 | 2013-02-28 | Rovi Corp. | Selection of Resolutions for Seamless Resolution Switching of Multimedia Content |
US9955195B2 (en) | 2011-08-30 | 2018-04-24 | Divx, Llc | Systems and methods for encoding and streaming video encoded using a plurality of maximum bitrate levels |
US10708587B2 (en) | 2011-08-30 | 2020-07-07 | Divx, Llc | Systems and methods for encoding alternative streams of video for playback on playback devices having predetermined display aspect ratios and network connection maximum data rates |
US10798143B2 (en) | 2011-08-30 | 2020-10-06 | Divx, Llc | Selection of resolutions for seamless resolution switching of multimedia content |
US10931982B2 (en) | 2011-08-30 | 2021-02-23 | Divx, Llc | Systems and methods for encoding and streaming video encoded using a plurality of maximum bitrate levels |
US11457054B2 (en) | 2011-08-30 | 2022-09-27 | Divx, Llc | Selection of resolutions for seamless resolution switching of multimedia content |
US10645429B2 (en) | 2011-08-30 | 2020-05-05 | Divx, Llc | Systems and methods for encoding and streaming video encoded using a plurality of maximum bitrate levels |
US9467708B2 (en) * | 2011-08-30 | 2016-10-11 | Sonic Ip, Inc. | Selection of resolutions for seamless resolution switching of multimedia content |
US9510031B2 (en) | 2011-08-30 | 2016-11-29 | Sonic Ip, Inc. | Systems and methods for encoding alternative streams of video for playback on playback devices having predetermined display aspect ratios and network connection maximum data rates |
US11611785B2 (en) | 2011-08-30 | 2023-03-21 | Divx, Llc | Systems and methods for encoding and streaming video encoded using a plurality of maximum bitrate levels |
WO2013033335A1 (en) * | 2011-08-30 | 2013-03-07 | Divx, Llc | Selection of resolutions for seamless resolution switching of multimedia content |
US9894407B2 (en) * | 2012-11-07 | 2018-02-13 | Lg Electronics Inc. | Apparatus for transreceiving signals and method for transreceiving signals |
US20150124888A1 (en) * | 2012-11-07 | 2015-05-07 | Lg Elelctronics Inc. | Apparatus for transreceiving signals and method for transreceiving signals |
US11785066B2 (en) | 2012-12-31 | 2023-10-10 | Divx, Llc | Systems, methods, and media for controlling delivery of content |
US9131127B2 (en) * | 2013-02-08 | 2015-09-08 | Ati Technologies, Ulc | Method and apparatus for reconstructing motion compensated video frames |
US20140226070A1 (en) * | 2013-02-08 | 2014-08-14 | Ati Technologies Ulc | Method and apparatus for reconstructing motion compensated video frames |
US20140333669A1 (en) * | 2013-05-08 | 2014-11-13 | Nvidia Corporation | System, method, and computer program product for implementing smooth user interface animation using motion blur |
US9860474B2 (en) * | 2013-06-10 | 2018-01-02 | Lg Electronics Inc. | Multimedia device having flexible display and controlling method thereof |
US20160112667A1 (en) * | 2013-06-10 | 2016-04-21 | Lg Electronics Inc. | Multimedia device having flexible display and controlling method thereof |
USRE48782E1 (en) * | 2013-06-10 | 2021-10-19 | Lg Electronics Inc. | Multimedia device having flexible display and controlling method thereof |
US9729817B2 (en) * | 2013-11-05 | 2017-08-08 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Parallel pipelines for multiple-quality level video processing |
US20150124165A1 (en) * | 2013-11-05 | 2015-05-07 | Broadcom Corporaton | Parallel pipelines for multiple-quality level video processing |
US20170025093A1 (en) * | 2014-03-18 | 2017-01-26 | Mediatek Inc. | Data processing apparatus for performing display data compression/decompression with color format conversion and related data processing method |
US9922620B2 (en) * | 2014-03-18 | 2018-03-20 | Mediatek Inc. | Data processing apparatus for performing display data compression/decompression with color format conversion and related data processing method |
US10242641B2 (en) | 2014-03-18 | 2019-03-26 | Mediatek Inc. | Data processing apparatus capable of performing optimized compression for compressed data transmission over multiple display ports of display interface and related data processing method |
US10089955B2 (en) | 2014-03-18 | 2018-10-02 | Mediatek Inc. | Data processing apparatus capable of using different compression configurations for image quality optimization and/or display buffer capacity optimization and related data processing method |
WO2017021688A1 (en) * | 2015-07-31 | 2017-02-09 | Forbidden Technologies Plc | Compressor |
US20170118379A1 (en) * | 2015-10-23 | 2017-04-27 | Ricoh Company, Ltd. | Image processing device, image forming apparatus, and image processing method |
US10027852B2 (en) * | 2015-10-23 | 2018-07-17 | Ricoh Company, Ltd. | Image processing device, image forming apparatus, and image processing method |
US11483609B2 (en) | 2016-06-15 | 2022-10-25 | Divx, Llc | Systems and methods for encoding video content |
US10595070B2 (en) | 2016-06-15 | 2020-03-17 | Divx, Llc | Systems and methods for encoding video content |
US11729451B2 (en) | 2016-06-15 | 2023-08-15 | Divx, Llc | Systems and methods for encoding video content |
US10148989B2 (en) | 2016-06-15 | 2018-12-04 | Divx, Llc | Systems and methods for encoding video content |
US12126849B2 (en) | 2016-06-15 | 2024-10-22 | Divx, Llc | Systems and methods for encoding video content |
US11563974B2 (en) * | 2018-06-20 | 2023-01-24 | Tencent Technology (Shenzhen) Company Limited | Method and apparatus for video decoding |
US20210352318A1 (en) * | 2018-06-20 | 2021-11-11 | Tencent Technology (Shenzhen) Company Limited | Method and apparatus for video decoding |
Also Published As
Publication number | Publication date |
---|---|
US6788347B1 (en) | 2004-09-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6788347B1 (en) | HDTV downconversion system | |
US6539120B1 (en) | MPEG decoder providing multiple standard output signals | |
EP1628479A2 (en) | HDTV downconversion system | |
WO1998041011A9 (en) | Hdtv downconversion system | |
US6175592B1 (en) | Frequency domain filtering for down conversion of a DCT encoded picture | |
WO1998041012A9 (en) | Mpeg decoder providing multiple standard output signals | |
US6249549B1 (en) | Down conversion system using a pre-decimation filter | |
US6487249B2 (en) | Efficient down conversion system for 2:1 decimation | |
US6618443B1 (en) | Upsampling filter for a down conversion system | |
US7263231B2 (en) | Method and apparatus for performing video image decoding | |
US5973740A (en) | Multi-format reduced memory video decoder with adjustable polyphase expansion filter | |
JP2001177832A (en) | Image decoder and image decoding method | |
US20010016010A1 (en) | Apparatus for receiving digital moving picture | |
JPH11164322A (en) | Aspect ratio converter and its method | |
US5777679A (en) | Video decoder including polyphase fir horizontal filter | |
US6493391B1 (en) | Picture decoding method and apparatus | |
KR100518477B1 (en) | HDTV Down Conversion System | |
KR100526905B1 (en) | MPEG decoder provides multiple standard output signals | |
JP4051799B2 (en) | Image decoding apparatus and image decoding method | |
KR100563015B1 (en) | Upsampling Filter and Half-Pixel Generator for HDTV Downconversion System |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |