The present invention relates in general to video processing devices, and in particular to supersampling of digital video output for multiple analog display formats.
Many display devices in use today generate images by coloring each of an array of pixels in accordance with an analog input signal that sequentially specifies the color of each pixel. The analog input signal is generally provided in a format specified by a transmission protocol associated with the device. A number of signal formats are in use today, including “standard definition” television (SDTV) formats such as NTSC (National Television Standards Committee) or PAL (Phase Alternating Line); high definition television (HDTV) formats such as 720p, 1080i or 1080p; and VGA or similar formats for computer monitors. Transmission protocols or signal formats, which are usually defined by some standards body or industry consortium, specify parameters such as the frame rate, the number of lines per frame, the number of pixels per line, the meaning of signal amplitude and/or phase, and similar parameters. For example, the NTSC protocol specifies a data rate 525 lines per frame and about 30 frames, interlaced, per second. It also specifies a relationship between (analog) signal amplitude and pixel intensity and, in the case of color images, between signal phase and pixel hue. Such specifications establish a bandpass and other characteristics of the analog signals that a video data source should provide.
In general, different protocols specify different signal formats, and display devices are usually designed for a single format. Thus, makers of video processing devices and other video data sources are confronted with the challenge of providing video signals for a number of different (and sometimes still evolving) formats.
One solution is to provide a different video processing device for each different format. This, however, makes it harder for the end user to upgrade one component of a system, e.g., replacing an SDTV display device with an HDTV, because any incompatible video processing devices (video game consoles, DVD players, etc.) would also have to be replaced. It also requires the manufacturer to design and build a number of different devices with different internal architectures, adding overhead.
Another, more common, solution is to provide a video processing device that has different output processing paths for some number of different standards. For example,
It would therefore be desirable to provide an improved video data source that supports multiple standards and can easily be reconfigured for different standards.
Embodiments of the present invention provide an output pipeline for a video processing device in which the output data is supersampled in the digital domain to eliminate or reduce unwanted frequency components in an analog output signal. In some embodiments, this supersampling reduces or eliminates the need for format-specific analog filtering circuitry, allowing the output pipeline to be more easily reconfigured for different output formats. In some embodiments, the output pipeline can be reconfigured to provide different output formats.
According to one aspect of the present invention, a device for converting a digital pixel signal to an analog output signal having a target format includes a pixel pipeline circuit, an encoder, a supersampling circuit, and a digital to analog converter. The pixel pipeline circuit is configured to provide a pixel stream including digital pixel values. The encoder is coupled to an output of the pixel pipeline circuit and is configured to convert the pixel stream to digital sample values for a target analog signal representing the pixel stream in the target format, thereby generating a base data stream at a base sampling rate. The supersampling circuit is coupled to an output of the encoder and is configured to generate a supersampled data stream at a supersampling rate from the base data stream, the supersampling rate being higher than the base sampling rate. The digital to analog converter is coupled to an output of the supersampling circuit and is configured to convert the supersampled data stream to an analog output signal. In some embodiments, the supersampling rate is selected so as to provide substantial attenuation of a higher frequency echo in the analog output signal, the higher frequency echo occurring in a frequency band above a baseband of the analog output signal. In some embodiments, the device may also include an electromagnetic interference (EMI) filter coupled to an output of the digital to analog converter and configured to substantially attenuate frequency components of the analog output signal above a maximum frequency.
In some embodiments the encoder may be further configured to respond to one or more control parameters, thereby enabling selection of one of a number of candidate formats as the target format. The candidate formats may include, for example, a standard definition television format and a high definition television format.
According to another aspect of the present invention, a device for converting a digital pixel signal to an analog output signal having a target format includes a pixel pipeline circuit, a supersampling circuit, an encoder, and a digital to analog converter. The pixel pipeline circuit is configured to provide a pixel stream including a first number of digital pixel values per line at a base pixel rate. The supersampling circuit is coupled to an output of the pixel pipeline circuit and is configured to generate a supersampled pixel stream including a second number of digital pixel values per line, the second number being greater than the first number, at a supersampling rate higher than the base pixel rate. The encoder is coupled to an output of the supersampling circuit and is configured to convert the supersampled pixel stream to digital sample values for a target analog signal representing the supersampled pixel stream in the target format, thereby generating a supersampled data stream at an enhanced sampling rate. The digital to analog converter is coupled to an output of the encoder and is configured to convert the supersampled data stream to an analog output signal. The supersampling rate may be selected so as to provide substantial attenuation of a higher frequency echo of the analog output signal, the higher frequency echo occurring in a frequency band above a baseband of the analog output signal.
According to yet another aspect of the present invention, a video processing unit includes a pixel generator circuit, a pixel pipeline, an encoder, a supersampling circuit, and a digital to analog converter. The pixel generator circuit is configured to generate and store pixel data for a frame of an image. The pixel pipeline is configured to retrieve the stored pixel data and to provide a pixel stream including digital pixel values at a base pixel rate. The encoder is coupled to an output of the pixel pipeline circuit and is configured to convert the pixel stream to digital sample values for a target analog signal representing the pixel stream in a target format, thereby generating a base data stream at a base sampling rate. The supersampling circuit is coupled to an output of the encoder circuit and is configured to generate a supersampled data stream at a supersampling rate from the base data stream, the supersampling rate being higher than the base sampling rate. The digital to analog converter is coupled to an output of the supersampling circuit and is configured to convert the supersampled data stream to an analog output signal. The supersampling rate of the supersampled data stream is selected so as to provide substantial attenuation of a higher frequency echo in the analog output signal, the higher frequency echo occurring in a frequency band above a baseband of the analog output signal.
According to still another aspect of the present invention, a method for converting a digital pixel signal to an analog output signal having a target format is provided. A pixel stream including digital pixel values is received. The pixel stream is encoded as a base data stream including digital sample values for a corresponding analog signal having the target format, where the encoding is performed at a base sampling rate. The base data stream is supersampled at a supersampling rate, the supersampling rate being higher than the base sampling rate, thereby generating a supersampled data stream. The supersampled data stream is converted to an analog output signal. The supersampling rate is selected so as to provide substantial attenuation of a higher frequency echo in the analog output signal, the higher frequency echo occurring in a frequency band above a baseband of the analog output signal. In some embodiments, the target format may be selected from a plurality of candidate formats, which may include, e.g., a standard definition television format and a high definition television format.
The following detailed description together with the accompanying drawings will provide a better understanding of the nature and advantages of the present invention.
FIGS. 1A-B are block diagrams of video data paths used in conventional video processing devices;
Embodiments of the present invention provide an output pipeline for a video processing device in which the output data is supersampled in the digital domain to eliminate or reduce unwanted frequency components in the analog output signal. In some embodiments, supersampling reduces or eliminates the need for format-specific analog filtering circuitry, allowing the output pipeline to be more easily reconfigured for different output formats. In some embodiments, the output pipeline can be used to provide multiple output formats in parallel; in other embodiments, the pipeline can be reconfigured to provide a different output format. The present invention can be implemented in a wide range of video processing devices, including graphics or video processors for general purpose computer systems, special purpose computer systems such as video game consoles, and other digital video devices such as DVD players or the like.
Graphics processing subsystem 212 includes a graphics processing unit (GPU) 214 and a graphics memory 216, which may be implemented, e.g., using one or more integrated circuit devices such as programmable processors, application specific integrated circuits (ASICs), and memory devices. Graphics memory 216 includes a pixel buffer 218 that stores color data for an array of display pixels. GPU 214 includes a geometry processing pipeline 220, a memory interface module 222, and scanout control logic 224. Geometry processing pipeline 220 may be configured to perform various tasks related to generating pixel data from graphics data supplied via system bus 206 (e.g., implementing various 2D and or 3D rendering algorithms), interacting with graphics memory 216 to store and update pixel data, and the like. Memory interface module 222, which communicates with geometry pipeline 220 and scanout control logic 224, manages all interactions with graphics memory 216. Memory interface module 222 may also include pathways for writing pixel data received from system bus 206 to pixel buffer 218 without processing by geometry pipeline 220. The particular configuration of geometry processing pipeline 220 and memory interface module 222 may be varied as desired, and a detailed description is omitted as not being critical to understanding the present invention.
As mentioned above, pixel buffer 218 stores color data for an array of display pixels. In some embodiments, the color data for a pixel includes separate red (R), green (G), and blue (B) color intensity values, each represented using a number (e.g., 8) of bits. Pixel buffer 218 may also store other data, such as depth (Z) and/or transparency data for some or all pixels. In some embodiments, pixel buffer 218 may store more than one set of RGB color values per pixel, and the color values may be combined, or downfiltered, prior to or during scanout operation. It is to be understood that GPU 214 may be operated in any manner that results in pixel data being stored in pixel buffer 218.
Scanout module 224, which may be integrated in a single chip with GPU 214 or implemented in a separate chip, reads pixel color data from pixel buffer 218 and transfers the data to display device 210 to be displayed. In one embodiment, scanout occurs at a constant screen refresh rate (e.g., 80 Hz); the refresh rate can be a user selectable parameter, or it can be determined based on the display format in use (e.g., about 30 Hz for NTSC). The scanout order may be varied as appropriate to the display format (e.g., interlaced or progressive scan). Scanout module 224 may also perform other operations, such as adjusting color values for particular display hardware; and/or generating composite screen images by combining the pixel data from pixel buffer 218 with data for a video or cursor overlay image or the like, which may be obtained, e.g., from graphics memory 216, system memory 204, or another data source (not shown).
In accordance with an embodiment of the present invention, scanout module 224 includes conversion circuitry that converts the pixel data from digital format to analog format for displaying on display device 210. As described below, the conversion circuitry is adaptable to different display device protocols; accordingly many types of display devices 210 can be supported, including SDTV displays using NTSC, PAL or other formats; HDTV displays using various HD formats; CRT or LCD computer monitors, and so on.
It will be appreciated that the system described herein is illustrative and that variations and modifications are possible. A GPU may be implemented using any suitable technologies, e.g., as one or more integrated circuit devices. The GPU may be mounted on an expansion card that may include one or more such processors, mounted directly on a system motherboard, or integrated into a system chipset component (e.g., into the north bridge chip of one commonly used PC system architecture). The graphics processing subsystem may include any amount of dedicated graphics memory (some implementations may have no dedicated graphics memory) and may use system memory and dedicated graphics memory in any combination. In particular, the pixel buffer may be implemented in dedicated graphics memory or system memory as desired. The scanout circuitry may be integrated with a GPU or provided on a separate chip and may be implemented, e.g., using one or more ASICs, programmable processor elements, other integrated circuit technologies, or any combination thereof. In addition, the GPU may be incorporated into a variety of devices, including general purpose computer systems, video game consoles and other special purpose computer systems, DVD players, and the like.
After any transformations in pixel pipeline 306, a stream of pixel data is provided in digital form (e.g., as RGB color components) to an encoder 310. The pixel stream is advantageously provided to encoder 310 at a substantially constant pixel rate, although there may be blanking periods or other interruptions, e.g., corresponding to horizontal and/or vertical retrace intervals specified by a target display protocol.
Encoder 310 transforms the pixel data to a stream of digital sample values modeling a target analog signal that advantageously conforms to a display device protocol for a target device. Encoder 310 advantageously generates samples at a substantially constant base sampling rate. In some instances, the base sampling rate may be specified by the display device protocol; in other instances, the base sampling rate may be selected according to standard rules of sampling theory, e.g., based on spectral analysis of characteristic analog signals for a particular target format.
For example, if the target format is NTSC, encoder 310 would be configured to compute appropriate amplitude and/or phase values for each pixel and generate samples of the resulting waveform at a base sampling rate of around 54 million samples per second (MS/s). In some embodiments, encoder 310 may be configurable to generate samples conforming to different protocols; for example, a CVE4 video encoder supplied by Zoran Corp. of Sunnyvale, Calif., that can support a number of different display protocols may be used. Encoding techniques for various protocols are known in the art, and a detailed description is omitted as not being critical to understanding the present invention.
The data stream from encoder 310 is provided to a supersampling (or upsampling) unit 314. Supersampling unit 314 increases the number of samples per display line by generating additional samples that are intermediate between the samples received from encoder 310. In some embodiments, supersampling unit 314 may include a conventional interpolation circuit that generates an intermediate sample between two adjacent samples based on the values of the two adjacent samples. In other embodiments, additional preceding and/or succeeding values (referred to herein as “taps”) may be used, with different taps being given different weights (or filter coefficients). For instance, an 8-tap filter with coefficients of (−2, 8, −21, 79, 79, −21, 8, −2) or a 6-tap filter with coefficients of (2, −14, 76, 76, −14, 2) might be used.
In one embodiment, supersampling unit 314 performs “2× supersampling,” in which one intermediate value is generated between each pair of samples, e.g., using an 8-tap filter. In another embodiment, this 2× supersampling operation may be followed by a second 2× supersampling operation (e.g., using a 6-tap filter) to generate two additional intermediate values, resulting in 4× supersampling. In other embodiments, supersampling unit 314 may generate other numbers of intermediate samples, including numbers that are not integer multiples of the input sampling rate. More generally, supersampling unit 314 generates a number M of output samples for every number N of input samples, where M>N; this is referred to herein as M:N supersampling. Any M:N supersampling technique may be employed in supersampling unit 314.
Supersampling unit 314 provides the M:N supersampled data stream to a digital to analog converter (DAC) 316. The supersampled data stream is provided at a supersampling rate, which for M:N supersampling is approximately M/N times the base sampling rate, so that supersampling does not substantially alter the amount of time required to transmit a line or frame of data. DAC 316, which may be of generally conventional design, is configured to convert a received digital signal to a corresponding analog voltage. Thus, DAC 316 generates an analog output signal (which is generally time varying) from the supersampled data.
The analog output signal from DAC 316 is optionally passed through an electromagnetic interference (EMI) filter 318 that attenuates (suppresses) high frequency components of the analog waveform. For example, EMI filter 318 may attenuate all frequencies above about 200 MHz in compliance with FCC regulations limiting high frequency emissions of electronic devices. The filtered output is supplied via a connector 320 to an appropriate display device (e.g., a TV). Connector 320 may be adapted for compatibility with a particular display device or transmission conduit and may be, e.g., a component video connector, an S-video connector, a monitor connector, or other standard connector type.
It will be appreciated that the device described herein is illustrative and that variations and modifications are possible. The various circuit modules may be implemented in a number of ways, and the scanout control logic may include one or more integrated circuit devices. Scanout control logic may also be further integrated with other GPU functions as described above. Additional components for further signal processing may also be provided; for example, the baseband analog output signal from DAC 316 or EMI filter 318 may be mixed onto a carrier wave for wireless (e.g., radio frequency) transmission via a suitable antenna.
Inclusion of M:N supersampling unit 314 in the digital portion of the output path advantageously results in an analog output signal that more closely reflects the target signal. This can reduce, or in some instances eliminate, the need for subsequent analog filtering to correct for such artifacts of the digital-to-analog conversion process as high frequency echoes, spectral response variation from the DAC, and the like. By way of example,
A frequency spectrum of an analog signal that might be generated by the DAC in a conventional device is shown in
In a video processing device according to one embodiment of the present invention, the encoded digital signal is supersampled prior to conversion to analog, e.g., as shown in
Accordingly, the embodiment shown in
Thus, in some embodiments, it is possible to switch a video processing device to a new target format by modifying one or more configuration parameters of the encoder. In some embodiments, the pixel pipeline may also be configurable to supply pixel data at different rates conforming to the different target formats. It should be noted that the hardware elements of the output path do not need to be changed. In some cases, display devices using different formats may use the same physical connection (e.g., S-video or coaxial cable); in other cases, multiple output connectors may be arranged on the card to provide an additional degree of interchangeability.
It should also be noted that in some embodiments, reconstructive correction (e.g., sin(x)/x correction) in the analog domain is not needed regardless of the target format. For example, supersampling the DAC input as described herein can significantly reduce frequency dependence in the DAC response, eliminating the need for reconstructive correction. Further, because the same output path can be used for any format, integrated circuits implementing the embodiment shown in
After any transformations in pixel pipeline 506, a stream of digital pixel data is provided to a supersampling (upsampling) unit 508 at a base pixel rate. In this embodiment, supersampling unit 508 increases the number of pixels supplied to the encoder per display line by generating additional pixel values that are intermediate between the pixel values received from pixel pipeline 506. In some embodiments, supersampling unit 508 may include a conventional interpolation circuit that generates an intermediate pixel value between two adjacent input values based on the two adjacent values, and optionally on other preceding and/or succeeding values, including values of adjacent pixels in rows above and/or below the current row. Various pixel interpolation filters known in the art may be used: such filters may have any number of inputs (taps), with different inputs optionally being given different weights, or filter coefficients.
Supersampling unit 508 may generate any number of intermediate pixel values. For instance, 2× supersampling or 4× supersampling may be employed. In one embodiment, 4× supersampling is implemented using two cascaded 2× supersampling operations. In other embodiments, other numbers of intermediate samples may also be generated, including numbers that are non-integer multiples of the input sampling rate. More generally, for every number P of input pixels, supersampling unit 508 generates a number Q of output pixels, where Q>P. A variety of interpolation techniques may be employed in supersampling unit 508, and a detailed description is omitted as not being critical to understanding the present invention.
Supersampling unit 508 provides the supersampled pixel data at a (supersampled) rate of approximately Q/P times the base pixel rate to an encoder 512. Encoder 512 may be generally similar to encoder 310 described above, except that encoder 512 is adapted to receive pixel data the supersampled rate rather than the nominal pixel rate for the target format. As described above, encoder 512 transforms the pixel data (e.g., RGB components) to samples of an analog signal for a particular protocol and may be, e.g., a CVE4 video encoder. In this embodiment, encoder 512 is advantageously configured to receive and process more pixels per line than the target format specifies. Because encoder 512 receives more pixels per line (i.e., a higher density of information) than the target format specifies, encoder 512 can generate a more detailed digital representation of the target analog signal. Thus, echo suppression effects similar to those shown in
Encoder 512 provides the signal samples at an enhanced sampling rate (e.g., at Q/P times a base sampling rate) to a digital to analog converter (DAC) 516. DAC 516, which may be of generally conventional design, is configured to convert a received digital signal to a corresponding analog voltage, similarly to DAC 316 described above. The analog output signal from DAC 516 is optionally passed through an EMI filter 518 for removal of high frequency components. EMI filter 518 may be generally similar to EMI filter 318 described above. The filtered output is supplied via a connector 520 to an appropriate display device (e.g., a TV). Like connector 320, connector 520 is adapted for a particular display device or transmission cable type, and may be, e.g., a component video connector, an S-video connector, a monitor connector, or other standard connector type.
While the invention has been described with respect to specific embodiments, one skilled in the art will recognize that numerous modifications are possible. For instance, digital pixel data may be supplied to the encoder in a number of different formats, including RGB formats and Y/C (luminance/chrominance) formats. The digital pixel data may be generated in various ways, e.g., by executing rendering algorithms for 2-D or 3-D geometry data describing a scene, by decoding MPEG-2 or MPEG-4 video data or other encoded digital video data, and so on. Thus, a GPU or other video processing unit embodying the present invention can be incorporated into a general purpose computing system, a special purpose computing system such as a video game console, a DVD player, or any other system or device for processing digital video data.
Supersampling units, which may operate on target signal sample streams or digital pixel data streams, are not limited to a particular algorithm, number of taps, or filter coefficients, and may generate any larger number of samples for a given number of input samples. The terms “upsampling” and “supersampling” are used interchangeably herein; both terms refer generally to increasing the sampling resolution (e.g., number of data samples per scan line), with sample resolution being measured by the number of pixels per line or analog signal samples per line as appropriate. Cascaded supersampling operations or a sequence of supersampling units may be used to further increase the number of output samples. Various encoders may be used, and the encoder may be adapted to a particular pixel data format and analog output format or configurable for supporting multiple different formats. The supersampling and encoding operations described herein may be implemented in hardware devices, such as one or more application specific integrated circuits (ASICs), in software executing on one or more suitable processors, or any combination thereof. In some embodiments, supersampling and encoding functions may be integrated into a supersampling encoder circuit; such a circuit may encode the data and supersample the encoded data stream, or it may supersample the pixel data and encode the resulting pixel stream.
Thus, although the invention has been described with respect to specific embodiments, it will be appreciated that the invention is intended to cover all modifications and equivalents within the scope of the following claims.