1. Field of the Invention
This invention relates generally to the field of computer graphics and, more particularly, to a high performance graphics system which implements super-sampling.
2. Description of the Related Art
A computer system typically relies upon its graphics system for producing visual output on the computer screen or display device. Early graphics systems were only responsible for taking what the processor produced as output and displaying that output on the screen. In essence, they acted as simple translators or interfaces. Modern graphics systems, however, incorporate graphics processors with a great deal of processing power. They now act more like coprocessors rather than simple translators. This change is due to the recent increase in both the complexity and amount of data being sent to the display device. For example, modern computer displays have many more pixels, greater color depth, and are able to display images that are more complex with higher refresh rates than earlier models. Similarly, the images displayed are now more complex and may involve advanced techniques such as anti-aliasing and texture mapping.
As a result, without considerable processing power in the graphics system, the CPU would spend a great deal of time performing graphics calculations. This could rob the computer system of the processing power needed for performing other tasks associated with program execution and thereby dramatically reduce overall system performance. With a powerful graphics system, however, when the CPU is instructed to draw a box on the screen, the CPU is freed from having to compute the position and color of each pixel. Instead, the CPU may send a request to the video card stating: “draw a box at these coordinates”. The graphics system then draws the box, freeing the processor to perform other tasks.
Generally, a graphics system in a computer (also referred to as a graphics system) is a type of video adapter that contains its own processor to boost performance levels. These processors are specialized for computing graphical transformations, so they tend to achieve better results than the general-purpose CPU used by the computer system. In addition, they free up the computer's CPU to execute other commands while the graphics system is handling graphics computations. The popularity of graphical applications, and especially multimedia applications, has made high performance graphics systems a common feature of computer systems. Most computer manufacturers now bundle a high performance graphics system with their systems.
Since graphics systems typically perform only a limited set of functions, they may be customized and therefore far more efficient at graphics operations than the computer's general-purpose central processor. While early graphics systems were limited to performing two-dimensional (2D) graphics, their functionality has increased to support three-dimensional (3D) wire-frame graphics, 3D solids, and now includes support for three-dimensional (3D) graphics with textures and special effects such as advanced shading, fogging, alpha-blending, and specular highlighting.
While the number of pixels is an important factor in determining graphics system performance, another factor of equal import is the quality of the image. Various methods are used to improve the quality of images, including anti-aliasing, alpha blending, and fogging, among numerous others. While various techniques may be used to improve the appearance of computer graphics images, they also have certain limitations. In particular, they may introduce their own aberrations and are typically limited by the density of pixels displayed on the display device.
As a result, a graphics system is desired which is capable of utilizing increased performance levels to increase not only the number of pixels rendered but also the quality of the image rendered. In addition, a graphics system is desired which is capable of utilizing increases in processing power to improve graphics effects.
Prior art graphics systems have generally fallen short of these goals. Prior art graphics systems use a conventional frame buffer for refreshing pixel/video data on the display. The frame buffer stores rows and columns of pixels that exactly correspond to respective row and column locations on the display. Prior art graphics system render 2D and/or 3D images or objects into the frame buffer in pixel form, and then read the pixels from the frame buffer during a screen refresh to refresh the display. Thus, the frame buffer stores the output pixels that are provided to the display. To reduce visual artifacts that may be created by refreshing the screen at the same time as the frame buffer is being updated, most graphics systems' frame buffers are double-buffered.
To obtain images that are more realistic, some prior art graphics systems have gone further by generating more than one sample per pixel. In other words, some graphics systems implement super-sampling whereby the graphics system may generate a larger number of samples than exist display elements or pixels on the display. By calculating more samples than pixels (i.e., super-sampling), a more detailed image is calculated than can be displayed on the display device. For example, a graphics system may calculate 4, 8 or 16 samples for each pixel to be output to the display device. After the samples are calculated, they are then combined or filtered to form the pixels that are stored in the frame buffer and then conveyed to the display device. Using pixels formed in this manner may create a more realistic final image because overly abrupt changes in the image may be smoothed by the filtering process.
As used herein, the term “sample” refers to calculated information that indicates the color of the sample and possibly other information, such as depth (z), transparency, etc., of a particular point on an object or image. For example, a sample may comprise the following component values: a red value, a green value, a blue value, a z value, and an alpha value (e.g., representing the transparency of the sample). A sample may also comprise other information, e.g., a z-depth value, a blur value, an intensity value, brighter-than-bright information, and an indicator that the sample consists partially or completely of control information rather than color information (i.e., “sample control information”).
When a graphics system implements super-sampling, the graphics system is typically required to read a plurality of samples, i.e., sample data, corresponding to the area or support region of a filter, and then filter the samples within the filter region to generate an output pixel. This typically requires a large number of reads from the sample memory. Therefore, improved methods are desired for more efficiently accessing sample data from the sample memory in order to generate output pixels for a sample buffer, frame buffer and/or a display device.
One embodiment of the invention comprises a system and method for generating pixels for a display device. The system may include a sample buffer for storing a plurality samples in a memory, a sample cache for caching recently accessed samples, and a sample filter unit for filtering one or more samples to generate a pixel. The generated pixels may then be stored in a frame buffer or provided to a display device. The method operates to take advantage of the common samples shared by neighboring pixels in both the x and y directions for reduced sample buffer accesses and improved performance.
The method may involve reading a first portion of samples from the memory. The first portion of samples may correspond to pixels in a plurality of (at least two) neighboring scan lines. The first portion of samples may be stored in a cache memory and then accessed from the cache memory for filtering.
The sample filter unit may then operate to filter a first subset of the first portion of samples to generate a first pixel in a first scan line. The sample filter unit may also filter a second subset of the first portion of samples to generate a second pixel in a second scan line, wherein the second scan line neighbors the first scan line. The first subset of the first portion of samples may include a plurality of common samples with the second subset of the first portion of samples. Thus the method may operate to reduce the number of accesses required to be made to the sample buffer. Where the sample filter unit is configured to access samples for greater than 2 neighboring scan lines, the sample filter unit may also access the requisite samples from the cache and filter other subsets of the first portion of samples to generate additional pixels in other scan lines.
The sample filter unit may also be operable to generate additional pixels neighboring the first and second pixels in the x direction (in the first and second scan lines) based on the read. In this case, the sample filter unit may access a third subset of the first portion of samples from the cache memory and filter the third subset of samples to generate a third pixel in the first scan line, wherein the third pixel neighbors the first pixel in the first scan line. The sample filter unit may access a fourth subset of the first portion of samples from the cache memory and filter the fourth subset of samples to generate a fourth pixel in the second scan line, wherein the fourth pixel neighbors the second pixel in the second scan line.
The above operation may then be repeated for multiple sets of pixels in the plurality of scan lines, e.g., to generate all pixels in the first and second scan lines. For example, the method may then involve reading a second portion of samples from the memory, wherein the second portion of samples corresponds to pixels in the at least two neighboring scan lines, wherein the second portion of samples neighbors the first portion of samples. The sample filter unit may filter a first subset of the second portion of samples to generate a third pixel in the first scan line, and may filter a second subset of the second portion of samples to generate a fourth pixel in the second scan line. The third pixel may neighbor the first pixel in the first scan line, and the fourth pixel may neighbor the second pixel in the second scan line. The first subset of the second portion of samples may include a plurality of common samples with the first subset of the first portion of samples, and the second subset of the second portion of samples may include a plurality of common samples with the second subset of the first portion of samples.
Thus the sample filter unit may proceed by generating pixels in multiple neighboring scan lines, e.g., generating a pair of pixels in neighboring scan lines in the x direction, one pair at a time. This operates to more efficiently use the sample memory accesses in the generation of pixels.
The foregoing, as well as other objects, features, and advantages of this invention may be more completely understood by reference to the following detailed description when read together with the accompanying drawings in which:
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present invention as defined by the appended claims. Note, the headings are for organizational purposes only and are not meant to be used to limit or interpret the description or claims. Furthermore, note that the word “may” is used throughout this application in a permissive sense (i.e., having the potential to, being able to), not a mandatory sense (i.e., must).” The term “include”, and derivations thereof, mean “including, but not limited to”. The term “connected” means “directly or indirectly connected”, and the term “coupled” means “directly or indirectly connected”.
Incorporation by Reference
The following applications are hereby incorporated by reference in their entirety as though fully and completely set forth herein.
U.S. patent application Ser. No. 09/251,453 titled “Graphics System with Programmable Real-Time Sample Filtering” filed Feb. 17, 1999, whose inventors are Michael F. Deering, David Naegle and Scott Nelson.
U.S. patent application Ser. No. 09/970,077 titled “Programmable Sample Filtering For Image Rendering” filed Oct. 3, 2001, whose inventors are Wayne E. Burk, Yan Y. Tang, Michael G. Lavelle, Philip C. Leung, Michael F. Deering and Ranjit S. Oberoi.
U.S. patent application Ser. No. 09/861,479 titled “Sample Cache For Supersample Filtering” filed May 18, 2001, whose inventors are Michael G. Lavelle, Philip C. Leung and Yan Y. Tang
Computer System—
As shown, the computer system 80 includes a system unit 82 and a video monitor or display device 84 coupled to the system unit 82. The display device 84 may be any of various types of display monitors or devices (e.g., a CRT, LCD, or gas-plasma display). Various input devices may be connected to the computer system, including a keyboard 86 and/or a mouse 88, or other input device (e.g., a trackball, digitizer, tablet, six-degree of freedom input device, head tracker, eye tracker, data glove, or body sensors). Application software may be executed by the computer system 80 to display graphical objects on display device 84.
Computer System Block Diagram—
Host processor 102 may include one or more processors of varying types, e.g., microprocessors, multi-processors and CPUs. The system memory 106 may include any combination of different types of memory subsystems such as random access memories (e.g., static random access memories or “SRAMs,” synchronous dynamic random access memories or “SDRAMs,” and Rambus dynamic random access memories or “RDRAMs,” among others), read-only memories, and mass storage devices. The system bus or host bus 104 may include one or more communication or host computer buses (for communication between host processors, CPUs, and memory subsystems) as well as specialized subsystem buses.
In
Host CPU 102 may transfer information to and from the graphics system 112 according to a programmed input/output (I/O) protocol over host bus 104. Alternately, graphics system 112 may access system memory 106 according to a direct memory access (DMA) protocol or through intelligent bus mastering.
A graphics application program conforming to an application programming interface (API) such as OpenGL® or Java 3D™ may execute on host CPU 102 and generate commands and graphics data that define geometric primitives such as polygons for output on display device 84. Host processor 102 may transfer the graphics data to system memory 106. Thereafter, the host processor 102 may operate to transfer the graphics data to the graphics system 112 over the host bus 104. In another embodiment, the graphics system 112 may read in geometry data arrays over the host bus 104 using DMA access cycles. In yet another embodiment, the graphics system 112 may be coupled to the system memory 106 through a direct port, such as the Advanced Graphics Port (AGP) promulgated by Intel Corporation.
The graphics system may receive graphics data from any of various sources, including host CPU 102 and/or system memory 106, other memory, or from an external source such as a network (e.g. the Internet), or from a broadcast medium, e.g., television, or from other sources.
Note while graphics system 112 is depicted as part of computer system 80, graphics system 112 may also be configured as a stand-alone device (e.g., with its own built-in display). Graphics system 112 may also be configured as a single chip device or as part of a system-on-a-chip or a multi-chip module. Additionally, in some embodiments, certain of the processing operations performed by elements of the illustrated graphics system 112 may be implemented in software.
Graphics System—
In some embodiments, one or more of these components may be removed. For example, the texture buffer may not be included in an embodiment that does not provide texture mapping. In other embodiments, all or part of the functionality incorporated in either or both of the media processor or the hardware accelerator may be implemented in software.
In one set of embodiments, media processor 14 is one integrated circuit and hardware accelerator is another integrated circuit. In other embodiments, media processor 14 and hardware accelerator 18 may be incorporated within the same integrated circuit. In some embodiments, portions of media processor 14 and/or hardware accelerator 18 may be included in separate integrated circuits.
As shown, graphics system 112 may include an interface to a host bus such as host bus 104 in
Media Processor—
Transformation refers to the spatial manipulation of objects (or portions of objects) and includes translation, scaling (e.g. stretching or shrinking), rotation, reflection, or combinations thereof. More generally, transformation may include linear mappinga (e.g. matrix multiplications), nonlinear mappings, and combinations thereof.
Lighting refers to calculating the illumination of the objects within the displayed image to determine what color values and/or brightness values each individual object will have. Depending upon the shading algorithm being used (e.g., constant, Gourand, or Phong), lighting may be evaluated at a number of different spatial locations.
As illustrated, media processor 14 may be configured to receive graphics data via host interface 11. A graphics queue 148 may be included in media processor 14 to buffer a stream of data received via the accelerated port of host interface 11. The received graphics data may include one or more graphics primitives. As used herein, the term graphics primitive may include polygons, parametric surfaces, splines, NURBS (non-uniform rational B-splines), sub-divisions surfaces, fractals, volume primitives, voxels (i.e., three-dimensional pixels), and particle systems. In one embodiment, media processor 14 may also include a geometry data preprocessor 150 and one or more microprocessor units (MPUs) 152. MPUs 152 may be configured to perform vertex transformation, lighting calculations and other programmable functions, and to send the results to hardware accelerator 18. MPUs 152 may also have read/write access to texels (i.e. the smallest addressable unit of a texture map) and pixels in the hardware accelerator 18. Geometry data preprocessor 150 may be configured to decompress geometry, to convert and format vertex data, to dispatch vertices and instructions to the MPUs 152, and to send vertex and attribute tags or register data to hardware accelerator 18.
As shown, media processor 14 may have other possible interfaces, including an interface to one or more memories. For example, as shown, media processor 14 may include direct Rambus interface 156 to a direct Rambus DRAM (DRDRAM) 16. A memory such as DRDRAM 16 may be used for program and/or data storage for MPUs 152. DRDRAM 16 may also be used to store display lists and/or vertex texture maps.
Media processor 14 may also include interfaces to other functional components of graphics system 112. For example, media processor 14 may have an interface to another specialized processor such as hardware accelerator 18. In the illustrated embodiment, controller 160 includes an accelerated port path that allows media processor 14 to control hardware accelerator 18. Media processor 14 may also include a direct interface such as bus interface unit (BIU) 154. Bus interface unit 154 provides a path to memory 16 and a path to hardware accelerator 18 and video output processor 24 via controller 160.
Hardware Accelerator—
One or more hardware accelerators 18 may be configured to receive graphics instructions and data from media processor 14 and to perform a number of functions on the received data according to the received instructions. For example, hardware accelerator 18 may be configured to perform rasterization, 2D and/or 3D texturing, pixel transfers, imaging, fragment processing, clipping, depth cueing, transparency processing, set-up, and/or screen space rendering of various graphics primitives occurring within the graphics data.
Clipping refers to the elimination of graphics primitives or portions of graphics primitives that lie outside of a 3D view volume in world space. The 3D view volume may represent that portion of world space that is visible to a virtual observer (or virtual camera) situated in world space. For example, the view volume may be a solid truncated pyramid generated by a 2D view window, a viewpoint located in world space, a front clipping plane and a back clipping plane. The viewpoint may represent the world space location of the virtual observer. In most cases, primitives or portions of primitives that lie outside the 3D view volume are not currently visible and may be eliminated from further processing. Primitives or portions of primitives that lie inside the 3D view volume are candidates for projection onto the 2D view window.
Set-up refers to mapping primitives to a three-dimensional viewport. This involves translating and transforming the objects from their original “world-coordinate” system to the established viewport's coordinates. This creates the correct perspective for three-dimensional objects displayed on the screen.
Screen-space rendering refers to the calculations performed to generate the data used to form each pixel that will be displayed. For example, hardware accelerator 18 may calculate “samples.” Samples are points that have color information but no real area. Samples allow hardware accelerator 18 to “super-sample,” or calculate more than one sample per pixel. Super-sampling may result in a higher quality image.
Hardware accelerator 18 may also include several interfaces. For example, in the illustrated embodiment, hardware accelerator 18 has four interfaces. Hardware accelerator 18 has an interface 161 (referred to as the “North Interface”) to communicate with media processor 14. Hardware accelerator 18 may receive commands and/or data from media processor 14 through interface 161. Additionally, hardware accelerator 18 may include an interface 176 to bus 32. Bus 32 may connect hardware accelerator 18 to boot PROM 30 and/or video output processor 24. Boot PROM 30 may be configured to store system initialization data and/or control code for frame buffer 22. Hardware accelerator 18 may also include an interface to a texture buffer 20. For example, hardware accelerator 18 may interface to texture buffer 20 using an eight-way interleaved texel bus that allows hardware accelerator 18 to read from and write to texture buffer 20. Hardware accelerator 18 may also interface to a frame buffer 22. For example, hardware accelerator 18 may be configured to read from and/or write to frame buffer 22 using a four-way interleaved pixel bus.
The vertex processor 162 may be configured to use the vertex tags received from the media processor 14 to perform ordered assembly of the vertex data from the MPUs 152. Vertices may be saved in and/or retrieved from a mesh buffer 164.
The render pipeline 166 may be configured to rasterize 2D window system primitives and 3D primitives into fragments. A fragment may contain one or more samples. Each sample may contain a vector of color data and perhaps other data such as alpha and control tags. 2D primitives include objects such as dots, fonts, Bresenham lines and 2D polygons. 3D primitives include objects such as smooth and large dots, smooth and wide DDA (Digital Differential Analyzer) lines and 3D polygons (e.g. 3D triangles).
For example, the render pipeline 166 may be configured to receive vertices defining a triangle, to identify fragments that intersect the triangle.
The render pipeline 166 may be configured to handle full-screen size primitives, to calculate plane and edge slopes, and to interpolate data (such as color) down to tile resolution (or fragment resolution) using interpolants or components such as:
r, g, b (i.e., red, green, and blue vertex color);
r2, g2, b2 (i.e., red, green, and blue specular color from lit textures);
alpha (i.e. transparency);
z (i.e. depth); and
s, t, r, and w (i.e. texture components).
In embodiments using supersampling, the sample generator 174 may be configured to generate samples from the fragments output by the render pipeline 166 and to determine which samples are inside the rasterization edge. Sample positions may be defined by user-loadable tables to enable various types of sample-positioning patterns.
Hardware accelerator 18 may be configured to write textured fragments from 3D primitives to frame buffer 22. The render pipeline 166 may send pixel tiles defining r, s, t and w to the texture address unit 168. The texture address unit 168 may determine the set of neighboring texels that are addressed by the fragment(s), as well as the interpolation coefficients for the texture filter, and write texels to the texture buffer 20. The texture buffer 20 may be interleaved to obtain as many neighboring texels as possible in each clock. The texture filter 170 may perform bilinear, trilinear or quadlinear interpolation. The pixel transfer unit 182 may also scale and bias and/or lookup texels. The texture environment 180 may apply texels to samples produced by the sample generator 174. The texture environment 180 may also be used to perform geometric transformations on images (e.g., bilinear scale, rotate, flip) as well as to perform other image filtering operations on texture buffer image data (e.g., bicubic scale and convolutions).
In the illustrated embodiment, the pixel transfer MUX 178 controls the input to the pixel transfer unit 182. The pixel transfer unit 182 may selectively unpack pixel data received via north interface 161, select channels from either the frame buffer 22 or the texture buffer 20, or select data received from the texture filter 170 or sample filter 172.
The pixel transfer unit 182 may be used to perform scale, bias, and/or color matrix operations, color lookup operations, histogram operations, accumulation operations, normalization operations, and/or min/max functions. Depending on the source of (and operations performed on) the processed data, the pixel transfer unit 182 may output the processed data to the texture buffer 20 (via the texture buffer MUX 186), the frame buffer 22 (via the texture environment unit 180 and the fragment processor 184), or to the host (via north interface 161). For example, in one embodiment, when the pixel transfer unit 182 receives pixel data from the host via the pixel transfer MUX 178, the pixel transfer unit 182 may be used to perform a scale and bias or color matrix operation, followed by a color lookup or histogram operation, followed by a min/max function. The pixel transfer unit 182 may then output data to either the texture buffer 20 or the frame buffer 22.
Fragment processor 184 may be used to perform standard fragment processing operations such as the OpenGL® fragment processing operations. For example, the fragment processor 184 may be configured to perform the following operations: fog, area pattern, scissor, alpha/color test, ownership test (WID), stencil test, depth test, alpha blends or logic ops (ROP), plane masking, buffer selection, pick hit/occlusion detection, and/or auxiliary clipping in order to accelerate overlapping windows.
Texture Buffer 20
Texture buffer 20 may include several SDRAMs. Texture buffer 20 may be configured to store texture maps, image processing buffers, and accumulation buffers for hardware accelerator 18. Texture buffer 20 may have many different capacities (e.g., depending on the type of SDRAM included in texture buffer 20). In some embodiments, each pair of SDRAMs may be independently row and column addressable.
Frame Buffer 22
Graphics system 112 may also include a frame buffer 22. In one embodiment, frame buffer 22 may include multiple 3D-RAM memory devices (e.g. 3D-RAM64 memory devices) manufactured by Mitsubishi Electric Corporation. Frame buffer 22 may be configured as a display pixel buffer, an offscreen pixel buffer, and/or a super-sample buffer. Furthermore, in one embodiment, certain portions of frame buffer 22 may be used as a display pixel buffer, while other portions may be used as an offscreen pixel buffer and sample buffer. In one embodiment, graphics system 112 may include a sample buffer for storing samples, and may not include a frame buffer 22 for storing pixels. Rather, the graphics system 112 may be operable to access and filter samples and provide resulting pixels to a display with no frame buffer. Thus, in this embodiment the samples are filtered and pixels generated and provided to the display “on the fly” with no storage of the pixels.
Video Output Processor—
A video output processor 24 may also be included within graphics system 112. Video output processor 24 may buffer and process pixels output from frame buffer 22. For example, video output processor 24 may be configured to read bursts of pixels from frame buffer 22. Video output processor 24 may also be configured to perform double buffer selection (dbsel) if the frame buffer 22 is double-buffered, overlay transparency (using transparency/overlay unit 190), plane group extraction, gamma correction, psuedocolor or color lookup or bypass, and/or cursor generation. For example, in the illustrated embodiment, the output processor 24 includes WID (Window ID) lookup tables (WLUTs) 192 and gamma and color map lookup tables (GLUTs, CLUTs) 194. In one embodiment, frame buffer 22 may include multiple 3DRAM64s 201 that include the transparency overlay 190 and all or some of the WLUTs 192. Video output processor 24 may also be configured to support two video output streams to two displays using the two independent video raster timing generators 196. For example, one raster (e.g., 196A) may drive a 1280×1024 CRT while the other (e.g., 196B) may drive a NTSC or PAL device with encoded television video.
DAC 26 may operate as the final output stage of graphics system 112. The DAC 26 translates the digital pixel data received from GLUT/CLUTs/Cursor unit 194 into analog video signals that are then sent to a display device. In one embodiment, DAC 26 may be bypassed or omitted completely in order to output digital pixel data in lieu of analog video signals. This may be useful when a display device is based on a digital technology (e.g., an LCD-type display or a digital micro-mirror display).
DAC 26 may be a red-green-blue digital-to-analog converter configured to provide an analog video output to a display device such as a cathode ray tube (CRT) monitor. In one embodiment, DAC 26 may be configured to provide a high resolution RGB analog video output at dot rates of 240 MHz. Similarly, encoder 28 may be configured to supply an encoded video signal to a display. For example, encoder 28 may provide encoded NTSC or PAL video to an S-Video or composite video television monitor or recording device.
In other embodiments, the video output processor 24 may output pixel data to other combinations of displays. For example, by outputting pixel data to two DACs 26 (instead of one DAC 26 and one encoder 28), video output processor 24 may drive two CRTs. Alternately, by using two encoders 28, video output processor 24 may supply appropriate video input to two television monitors. Generally, many different combinations of display devices may be supported by supplying the proper output device and/or converter for that display device.
Sample-to-Pixel Processing
In one set of embodiments, hardware accelerator 18 may receive geometric parameters defining primitives such as triangles from media processor 14, and render the primitives in terms of samples. The samples may be stored in a sample storage area (also referred to as the sample buffer) of frame buffer 22. The samples may be computed at positions in a two-dimensional sample space (also referred to as rendering space). The sample space may be partitioned into an array of bins (also referred to herein as fragments). The storage of samples in the sample storage area of frame buffer 22 may be organized according to bins (e.g. bin 300) as illustrated in FIG. 7. Each bin may contain one or more samples. The number of samples per bin may be a programmable parameter.
The samples may then be read from the sample storage area of frame buffer 22 and filtered by sample filter 22 to generate pixels. In one embodiment, the pixels may be stored in a pixel storage area of frame buffer 22. The pixel storage area may be double-buffered. Video output processor 24 reads the pixels from the pixel storage area of frame buffer 22 and generates a video stream from the pixels. The video stream may be provided to one or more display devices (e.g. monitors, projectors, head-mounted displays, and so forth) through DAC 26 and/or video encoder 28. In one embodiment, as discussed above, the sample filter 22 may filter respective samples to generate pixels, and the pixels may be provided as a video stream to the display without any intervening frame buffer storage, i.e., without storage of the pixels.
Super-Sampling Sample Positions—
The sample filter 172 may be programmed to generate one pixel position in each bin (e.g. at the center of each bin). For example, if the bins are squares with side length one, the horizontal and vertical step sizes between successive pixel positions may be set equal to one.
Each pixel may be computed on the basis of one or more samples. For example, the pixel located in bin 70 may simply take the values of samples in the same bin. Alternatively, the pixel located in bin 70 may be computed on the basis of filtering samples in a support region (or extent) covering multiple bins including bin 70.
The pixel at the center of bin 70 may be computed on the basis of a plurality of samples falling in support region 72. The radius of the support region may be programmable. As the radius increases, the support region 72 would cover a greater number of samples, possibly including those from neighboring bins.
The sample filter 172 may compute each pixel by operating on samples with a filter. Support region 72 illustrates the support of a filter which is localized at the center of bin 70. The support of a filter is the set of locations over which the filter (i.e. the filter kernel) is defined. In this example, the support region 72 is a circular disc. The output pixel values (e.g. red, green, blue) for the pixel at the center of bin 70 are determined by samples which fall within support region 72. This filtering operation may advantageously improve the realism of a displayed image by smoothing abrupt edges in the displayed image (i.e., by performing anti-aliasing). The filtering operation may simply average the values of samples within the support region 72 to form the corresponding output values of pixel 70. More generally, the filtering operation may generate a weighted sum of the values of samples within the support region 72, where the contribution of each sample may be weighted according to some function of the sample's position (or distance) with respect to the center of support region 72.
The filter, and thus support region 72, may be repositioned for each output pixel being calculated. For example, the filter center may visit the center of each bin. It is noted that the filters for neighboring pixels may have one or more samples in common in both the x and y directions. One embodiment of the present invention comprises a method for accessing samples from a memory in an efficient manner during pixel calculation to reduce the number of memory accesses. More specifically, one embodiment of the present invention comprises a method for accessing samples from a memory for pixels being generated in multiple neighboring or adjacent scan lines.
FIG. 9—Sample-to-Pixel Processing Flow—Pixel Generation From Samples
In addition to the vertex data, draw process 352 also receives sample coordinates from a sample position memory 354. In one embodiment, position memory 354 is embodied within sample generator & evaluator 174. Sample position memory 354 is configured to store position information for samples that are calculated in draw process 352 and then stored into super-sampled sample buffer 22A. The super-sampled sample buffer 22A may be a part of frame buffer 22 in the embodiment of FIG. 5. In one embodiment, position memory 354 may be configured to store entire sample addresses. Alternatively, position memory 354 may be configured to store only x- and y-offsets for the samples. Storing only the offsets may use less storage space than storing each sample's entire position. The offsets may be relative to bin coordinates or relative to positions on a regular grid. The sample position information stored in sample position memory 354 may be read by a dedicated sample position calculation unit (not shown) and processed to calculate sample positions for graphics processor 90.
Sample-to-pixel calculation process (or sample filter) 172 may use the same sample positions as draw process 352. Thus, in one embodiment, sample position memory 354 may generate sample positions for draw process 352, and may subsequently regenerate the same sample positions for sample-to-pixel calculation process 172.
As shown in the embodiment of
In one embodiment, sample position memory 354 may comprise a RAM/ROM that contains stochastically determined sample points or sample offsets. Thus, the density of samples in the rendering space may not be uniform when observed at small scale. As used herein, the term “bin” refers to a region or area in virtual screen space.
An array of bins may be superimposed over the rendering space, i.e. the 2-D viewport, and the storage of samples in sample buffer 22A may be organized in terms of bins. Sample buffer 22A may comprise an array of memory blocks which correspond to the bins. Each memory block may store the sample values (e.g. red, green, blue, z, alpha, etc.) for the samples that fall within the corresponding bin. The approximate location of a sample is given by the bin in which it resides. The memory blocks may have addresses which are easily computable from the corresponding bin locations in virtual screen space, and vice versa. Thus, the use of bins may simplify the storage and access of sample values in sample buffer 22A.
The bins may tile the 2-D viewport in a regular array, e.g. in a square array, rectangular array, triangular array, hexagonal array, etc., or in an irregular array. Bins may occur in a variety of sizes and shapes. The sizes and shapes may be programmable. The maximum number of samples that may populate a bin is determined by the storage space allocated to the corresponding memory block. This maximum number of samples per bin is referred to herein as the bin sample capacity, or simply, the bin capacity. The bin capacity may take any of a variety of values. The bin capacity value may be programmable. Henceforth, the memory blocks in sample buffer 22A which correspond to the bins in rendering space will be referred to as memory bins.
The specific position of each sample within a bin may be determined by looking up the sample's offset in the RAM/ROM table, i.e., the sample's offset with respect to the bin position (e.g. the lower-left corner or center of the bin, etc.). However, depending upon the implementation, not all choices for the bin capacity may have a unique set of offsets stored in the RAM/ROM table. Offsets for a first bin capacity value may be determined by accessing a subset of the offsets stored for a second larger bin capacity value. In one embodiment, each bin capacity value supports at least four different sample positioning schemes. The use of different sample positioning schemes may reduce final image artifacts that would arise in a scheme of naively repeating sample positions.
In one embodiment, sample position memory 354 may store pairs of 8-bit numbers, each pair comprising an x-offset and a y-offset. When added to a bin position, each pair defines a particular position in rendering space. To improve read access times, sample position memory 354 may be constructed in a wide/parallel manner so as to allow the memory to output more than one sample location per read cycle.
Once the sample positions have been read from sample position memory 354, draw process 352 selects the samples that fall within the polygon currently being rendered. This is illustrated in FIG. 7. Draw process 352 then may calculate depth (z), color information, and perhaps other sample attributes (which may include alpha and/or a depth of field parameter) for each of these samples and store the data into sample buffer 22A. In one embodiment, sample buffer 22A may only single-buffer z values (and perhaps alpha values) while double-buffering other sample components such as color. Graphics system 112 may optionally use double-buffering for all samples (although not all components of samples may be double-buffered, i.e., the samples may have some components that are not double-buffered).
The filter process 172 may operate in parallel with draw process 352. The filter process 172 may be configured to:
(a) read sample values from sample buffer 22A,
(b) read corresponding sample positions from sample position memory 354,
(c) filter the sample values based on their positions (or distance) with respect to the pixel center (i.e. the filter center),
(d) output the resulting output pixel values to a frame buffer, or directly onto video channels.
Sample-to-pixel calculation unit or sample filter 172 implements the filter process. Filter process 172 may be operable to generate the red, green, and blue values for an output pixel based on a spatial filtering of the corresponding data for a selected plurality of samples, e.g. samples falling in a filter support region around the current pixel center in the rendering space. Other values such as alpha may also be generated.
In one embodiment, filter process 172 is configured to:
(i) determine the distance of each sample from the pixel center;
(ii) multiply each sample's attribute values (e.g., red, green, blue, alpha) by a filter weight that is a specific programmable) function of the sample's distance (or square distance) from the pixel center;
(iii) generate sums of the weighted attribute values, one sum per attribute (e.g. a sum for red, a sum for green, . . . ), and
(iv) normalize the sums to generate the corresponding pixel attribute values.
In the embodiment just described, the filter kernel is a function of distance from the pixel center. However, in alternative embodiments, the filter kernel may be a more general function of X and Y sample displacements from the pixel center, or a function of some non-Euclidean distance from the pixel center. Also, the support of the filter, i.e. the 2-D neighborhood over which the filter kernel is defined, need not be a circular disk. Rather the filter support region may take various shapes.
As described further below, in one embodiment the filter process 172 may be configured to read sample values from the sample buffer 22A corresponding to pixels in multiple neighboring or adjacent scan lines. The filter process 172 may also read corresponding sample positions from sample position memory 354 for each of the read samples. The filter process 172 may filter the sample values based on their positions (or distance) with respect to the pixel center (i.e. the filter center) for pixels in multiple scan lines. Thus, for example, the filter process 172 may generate pixels in pairs in the x direction, wherein the pixel pairs comprise pixels with the same x coordinates and residing in neighboring scan lines.
Thus, one embodiment of the invention comprises a system and method for generating pixels. The system may include a sample buffer 22A for storing a plurality samples in a memory, a sample cache 402 (
The method may involve reading a first portion of samples from the memory. The first portion of samples may correspond to pixels in a plurality of (at least two) neighboring scan lines. The first portion of samples may be stored in the cache memory 402 and then accessed from the cache memory 402 for filtering.
The sample filter unit 172 may then access samples from the cache to generate first and second pixels (e.g., two or more pixels) having the same x coordinates, and residing in neighboring or adjacent scan lines. The sample filter unit 172 may operate to filter a first subset of the first portion of samples to generate a first pixel in a first scan line. The sample filter unit 172 may also filter a second subset of the first portion of samples to generate a second pixel in a second scan line, wherein the second scan line neighbors the first scan line. The first subset of the first portion of samples may include a plurality of common samples with the second subset of the first portion of samples. Thus the method may operate to reduce the number of accesses required to be made to the sample buffer 22A. Where the sample filter unit 172 is configured to access samples for greater than 2 neighboring scan lines, the sample filter unit 172 may also obtain these samples during the read performed above, access the requisite samples from the cache 402 and filter other subsets of the first portion of samples to generate additional pixels in other adjacent scan lines.
The sample filter unit 172 may also be operable to generate additional pixels neighboring the first and second pixels in the x direction (in the first and second scan lines) based on the read. In other words, the sample filter unit 172 may also be operable to generate additional pixels having different x coordinates than the first and second pixels, wherein the additional pixels neighbor the first and second pixels in the x direction. In this case, the sample filter unit 172 may access a third subset of the first portion of samples from the cache memory 402 and filter the third subset of samples to generate a third pixel in the first scan line, wherein the third pixel neighbors the first pixel in the first scan line. The sample filter unit 172 may access a fourth subset of the first portion of samples from the cache memory 402 and filter the fourth subset of samples to generate a fourth pixel in the second scan line, wherein the fourth pixel neighbors the second pixel in the second scan line.
The above operation may then be repeated for multiple sets of pixels in the plurality of scan lines, e.g., to generate all pixels in the first and second scan lines. For example, the method may then involve reading a second portion of samples from the sample memory 22A into the cache 402, wherein the second portion of samples corresponds to pixels in the at least two neighboring scan lines, and wherein the second portion of samples neighbors the first portion of samples. The sample filter unit 172 may filter a first subset of the second portion of samples to generate a third pixel in the first scan line, and may filter a second subset of the second portion of samples to generate a fourth pixel in the second scan line. The third pixel may neighbor the first pixel in the first scan line, and the fourth pixel may neighbor the second pixel in the second scan line. In other words, if the first and second pixels have x coordinate A, the third ad fourth pixels have x coordinates A+1. The first subset of the second portion of samples may include a plurality of common samples with the first subset of the first portion of samples, and the second subset of the second portion of samples may include a plurality of common samples with the second subset of the first portion of samples.
The above operation may then be repeated for all of the scan lines in the image being rendered. Thus the sample filter unit 172 may proceed by generating pixels in multiple neighboring scan lines, e.g., generating a pair of pixels in neighboring scan lines having the same x coordinates, and proceeding in this manner in the x direction, one pair at a time until the end of the multiple neighboring scan lines is reached. The method may then operate again on a next set of multiple scan lines, and so on, until all pixels have been rendered. This operates to more efficiently use the sample memory accesses in the generation of pixels.
The description of
Sample Filtering
As described above, the graphic system may implement super-sampling. The implementation of super-sampling includes a method for filtering the samples into pixels as described above. In one embodiment, each sample that falls into the filter's area or support region has a weight associated with it. Each sample is multiplied by its corresponding weight and added together. This sum is then divided by the sum of the weights to produce the final pixel color. For example, the following filter equation may be used.
Exemplary filters that may be used in various embodiments include a square filter, a cone filter, a Gaussian filter, and a sinc filter. As described above, a filter can include several bins in its calculation to determine the color of a single pixel. A bin may be a 1×1 pixel in size and in one embodiment can hold up to 16 samples.
Filter diameters may be as follows:
The filter may be centered on the pixel in question, and all samples which are within the filter's diameter or support region may contribute to the pixel. Each sample may be weighted according to the filter function. In normal super-sampling mode, the filter moves in one bin increments in the x direction over a scan line. However, during zoom-in the filter moves in fractional increments and during zoom-out the filter moves in greater than one decimal increments. The filter may be implemented with a lookup table. The samples may be listed in order of quality. As the quality of the filter increases, the computation cost increases as well.
In a first embodiment, pixels are filtered first in increasing x coordinates, then in increasing y coordinates. This is shown by the numbers 1-11 in
In the first embodiment, the filtering process may operate as follows. First, the samples may be read into a cache memory. The method may operate to read tiles into the cache memory to cover all the bins that the filter support region or footprint covers in a ymajor fashion. For example, the method may read a 2×n strip at a time. Since n can be odd, in one embodiment the method reads half tiles into the cache memory. For the sinc filter, n=5. Thus, for each strip, 2 full tiles and 1 half tile may be read. This read is illustrated in FIG. 16.
If the x address of the tile is greater than the edge of the filter for a pixel, then all the samples for the pixel have been read into the cache and the pixel may be now filtered. This may occur when:
xaddr>filter_centeri+filter_radius)
However, depending on the size of the filter and the zoom factor, all the samples for multiple pixels may have been read into the cache after reading a previous 2×n strip. For example,
In order to filter samples into a pixel, the filter may require knowledge of the pixel center, the position of each sample, and the type of filter. The distance from the pixel center to a sample is given by a simple distance equation.
d=(dx2+dy2)1/2
The distance may be used to find the appropriate weight given the type of filter, e.g., using a table lookup. If the sample is outside the filter, then the weight is zero.
The weight of each sample is multiplied by the color of each sample and the result is accumulated. The result is divided by the sum of the weights, producing the filtered pixel color. The following filter equation may be used.
After this, the next pixel center may be calculated using the reciprocal of the zoom factor, e.g.:
pixel center+=(zoom factor)−1
Multiple Scan Line Sample Filtering
As described above, a large amount of overlap may occur between samples in the footprint or support region of the filter applied to adjacent pixels. One embodiment of the invention recognizes this overlap both for neighboring pixels in the same scan line, and for neighboring pixels in adjacent scan lines. The method described above showed the reuse of samples when pixel filtering is performed in the x direction. However, as shown above, a large amount of overlap between samples in adjacent pixels may also occur in consecutive scan lines.
In one embodiment, a cache memory is used to store samples after they are read from the sample memory 22A, e.g., frame buffer 22. This may allow reuse of samples that have been already read for a neighboring filter operation. In addition, as described above, multiple filter commands may be generated or issued after samples for two or more pixels in adjacent scan lines (having the same x coordinates) have been read. This is because an access of samples for multiple pixels in adjacent scan lines may include the requisite samples for one or more neighboring pixels in the x direction. The reuse of samples for pixels in multiple scan lines (and adjacent pixels in the same scan lines) and access of samples from the cache memory that have been previously read are very important. This is because read of sample data from the sample buffer or frame buffer 22 is typically a bottleneck operation.
One embodiment of the present mention operates to take advantage of this overlap of samples between multiple x scan lines. This embodiment operates to filter multiple scan lines at a time, preferably 2 scan lines at a time. This operates to reduce accesses to both the cache memory and the sample memory.
FIG. 19—Sample Filter Embodiment
The sample memory 22A may be a portion of the frame buffer 22. The sample memory 22A may be accessed to obtain sample values for use in generating respective pixels. As mentioned above, in one embodiment of the invention, the method operates to access the sample memory 22A to retrieve samples corresponding to pixels in a plurality of neighboring scan lines, i.e., two or more scan lines. In other words, the sample memory 22A may be accessed to retrieve samples corresponding to pixels having the same x coordinates and residing in two or more horizontal rows or scan lines. This may operate to further reduce the amount of accesses to sample memory 22A. The samples read from the sample memory 22A may be stored in a cache memory 402 as shown. The samples may then be accessed from the cache memory 402 and provided to the filter tree 440. The filter tree 440 may multiply the sample values by respective weights from the weight queue 430 and perform an averaging function to produce the final pixel value.
The method which involves multiple scan line processing as described herein may operate as follows. First, the method may read tiles of samples into the cache memory 402 in order to cover all of the bins that the union of the two filter footprints or support regions cover, in a ymajor fashion. In one embodiment, since the difference in y coordinates between the two centers is a maximum of 1, this results in an additional two pixels being read as compared to the single scan line method described above with respect to
The filtering operation may be performed when all of the requisite samples have been obtained for the pixel being generated. This may occur when the x address of the tile is greater than the edge of the filter for the respective pixel,
i.e., if (xaddr>filter_centeri+filter_radius),
then all the samples for pixeli and pixelj have been read into the cache 402, and pixeli and pixelj may be filtered. However, depending on the size of the filter and the zoom factor, all the samples for multiple pixels in each of multiple scan lines may have been read into the cache 402 after reading a 2X(n+1) strip. For example, consider the cone filter which has a radius of 1 and a zoom factor 2, as shown in FIG. 23. In this example, the samples for 8 pixels were read into the cache 402 after reading a single 2X(n+1) strip. In one embodiment, both pixeli and pixelj (having the same x coordinates and residing in neighboring scan lines) are filtered in parallel. In other embodiments, the system may include additional filters and thus an even larger number of pixels may be filtered in parallel as desired.
The filtering operation may be performed as follows. As described above, in order to filter samples into a pixel, the filter may require knowledge of the pixel center, the position of each sample, and the type of filter. The distance from the pixel center to a sample is given by a simple distance equation.
d=(dx2+dy2)1/2
The distance may be used to find the appropriate weight given the type of filter, e.g., using a table lookup. If the sample is outside the filter, then the weight is zero. As described above,
In one embodiment, the system includes a plurality of filter and weight units corresponding to the plurality of pixels in neighboring scan lines being rendered in parallel. For example, in an embodiment where 2 pixels (having the same x coordinates and residing in neighboring scan lines) are being rendered in parallel, the system has 2 filter and weight units.
The pixel center of pixelj can be derived from pixeli as follows:
pixel center of j=pixel center of i+(zoom factor)−1
After this, the next pixel center(s) may be calculated using the reciprocal of the zoom factor in the x direction
pixel center+=(zoom factor)−1
However, in the y direction, after two or more scan lines have been completely processed and the system is advancing to begin at the next group of multiple scan lines, since multiple (e.g., 2) scan lines are being processed at one time, the pixel center is moved by a multiple of this amount in the y direction, the multiple being dependent on the number of scan lines being processed in parallel. For example, where 2 scan lines are being processed at one time, the pixel center is moved by twice this amount.
The sample filter 172 basically comprises the following blocks: the span walker (SW), the sample generator (SG), the frame buffer addressing unit (FBA) and the frame buffer readback unit (FRB).
The span walker's responsibility is to issue sample read and filter commands to the FBA. Each read command gives an integer x, y address of the upper lefthand corner of the tile to be read. Each pixel tile sent by SW may be either a full tile (2×2) or a horizontal half tile (2×1). In that way, the FBA can maximize the read throughput and expand the pixel tile in a regular fashion. The span walker issues read tile commands walking the area of the filter in a ymajor fashion. Therefore, the span walker is actually reading 2X(n+1) strips where n is the height of the footprint embracing the filters. The span walker will also avoid straddling block boundaries. An example of the read order is shown in FIG. 26. As shown, the read order proceeds in the order from 0 to 8.
In determining when to issue filter commands, where the method is about to read a new 2X(n—1) strip, the x address is examined. If this x address is greater than the edge of the filter, then a filter command is sent for this pixel pair. Therefore, the span walker uses knowledge of the radius, center, and zoom factor of the filter.
However, it is possible, after reading a 2X(n+1) strip, that enough samples may have been read for more than 1 pixel pair. Therefore, the method may consider more than 1 pixel pair and send down filter commands for more than 1 pixel pair as well.
As shown in
A filter command comprises the pixel center in fixed point arithmetic. The span walker will also add the reciprocal of the zoom factor to produce the new pixel center.
During read sample operations, frame buffer address (FBA) is responsible for receiving pixel (bin) tiles from span walker (SW) and expanding them into sample tiles in a regular fashion according to sample packing rules. In one embodiment, as shown in
Since in the current embodiment the pixel tiles from SW is limited to either a full tile (2×2) or a horizontal half tile (2×1), SG can expand a pixel tile into sample tiles in a regular fashion.
The FRB performs the actual filtering of the samples. When FRB receives a read-sample command, it stores the samples read out from frame buffer memory into its cache. The sample cache can hold samples belonging to an area of 8×6 bins. The cache is made up of 8 separate 1×6 strip (column), each a 2-port memory. When the FRB receives a filter command, it first calculates the weight for each sample. This may be done using a jitter table and a mirror table to compute the position of a given sample in a bin. The distance between a sample and the pixel center is used to lookup a weight in a filter table. The samples are “visited” in the order of the easiest way to read samples out of the cache. The FRB reads samples out in an xmajor fashion. Since in one embodiment the maximum filter size is 5 columns, the filter has been made to handle 10 samples at a time. Therefore, the weights are computed for the first two samples in each column, and then the next two samples in each column and so on.
Once the weights have been computed, they are placed in a queue where they wait to be filtered. In the current embodiment, the filter can handle up to 10 samples at a time and multiplies the sample color by the weights. The results are accumulated and divided by the sum of the weights to get the resulting pixel. The samples are filtered in the same order that the weight computation was done.
FRB includes 2 units to handle filtering for the 2 scanlines. Each cycle, the same 10 samples are read out, and sent to the 2 units respectively. The “distance from pixel center” is calculated separately for the 2 units, and hence the corresponding weight will be selected for the same sample, but with respect to 2 different filter centers.
The filter process described in the previous sections involving SW, SG, FBA and FRB can be summarized in an “opcode flows” diagram.
Although the embodiments above have been described in considerable detail, other versions are possible. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications. Note the section headings used herein are for organizational purposes only and are not meant to limit the description provided herein or the claims attached hereto.
Number | Name | Date | Kind |
---|---|---|---|
5943060 | Cosman et al. | Aug 1999 | A |
6326964 | Snyder et al. | Dec 2001 | B1 |
6424343 | Deering et al. | Jul 2002 | B1 |
6459428 | Burk et al. | Oct 2002 | B1 |
Number | Date | Country | |
---|---|---|---|
20030160789 A1 | Aug 2003 | US |