Z-buffering

Z-buffer data

In computer graphics, z-buffering is the management of image depth coordinates in three-dimensional (3-D) graphics, usually done in hardware, sometimes in software. It is one solution to the visibility problem, which is the problem of deciding which elements of a rendered scene are visible, and which are hidden. The painter's algorithm is another common solution which, though less efficient, can also handle non-opaque scene elements. Z-buffering is also known as depth buffering.

When an object is rendered by a 3D graphics card, the depth of a generated pixel (z coordinate) is stored in a buffer (the z-buffer or depth buffer). This buffer is usually arranged as a two-dimensional array (x-y) with one element for each screen pixel. If another object of the scene must be rendered in the same pixel, the graphics card compares the two depths and chooses the one closer to the observer. The chosen depth is then saved to the z-buffer, replacing the old one. In the end, the z-buffer will allow the graphics card to correctly reproduce the usual depth perception: a close object hides a farther one. This is called z-culling.

The granularity of a z-buffer has a great influence on the scene quality: a 16-bit z-buffer can result in artifacts (called "z-fighting") when two objects are very close to each other. A 24-bit or 32-bit z-buffer behaves much better, although the problem cannot be entirely eliminated without additional algorithms. An 8-bit z-buffer is almost never used since it has too little precision.

Contents

Uses

Z-buffer data in the area of video editing permits one to combine 2D video elements in 3D space, permitting virtual sets, "ghostly passing through wall" effects, and complex effects like mapping of video on surfaces. An application for Maya, called IPR, permits one to perform post-rendering texturing on objects, utilizing multiple buffers like z-buffers, alpha, object id, UV coordinates and any data deemed as useful to the post-production process, saving time otherwise wasted in re-rendering of the video.

Z-buffer data obtained from rendering a surface from a light's POV permits the creation of shadows in a scanline renderer, by projecting the z-buffer data onto the ground and affected surfaces below the object. This is the same process used in non-raytracing modes by the free and open sourced 3D application Blender.

Developments

Even with small enough granularity, quality problems may arise when precision in the z-buffer's distance values is not spread evenly over distance. Nearer values are much more precise (and hence can display closer objects better) than values which are farther away. Generally, this is desirable, but sometimes it will cause artifacts to appear as objects become more distant. A variation on z-buffering which results in more evenly distributed precision is called w-buffering (see below).

At the start of a new scene, the z-buffer must be cleared to a defined value, usually 1.0, because this value is the upper limit (on a scale of 0 to 1) of depth, meaning that no object is present at this point through the viewing frustum.

The invention of the z-buffer concept is most often attributed to Edwin Catmull, although Wolfgang Straßer also described this idea in his 1974 Ph.D. thesis1.

On recent PC graphics cards (1999–2005), z-buffer management uses a significant chunk of the available memory bandwidth. Various methods have been employed to reduce the performance cost of z-buffering, such as lossless compression (computer resources to compress/decompress are cheaper than bandwidth) and ultra fast hardware z-clear that makes obsolete the "one frame positive, one frame negative" trick (skipping inter-frame clear altogether using signed numbers to cleverly check depths).

Z-culling

In rendering, z-culling is early pixel elimination based on depth, a method that provides an increase in performance when rendering of hidden surfaces is costly. It is a direct consequence of z-buffering, where the depth of each pixel candidate is compared to the depth of existing geometry behind which it might be hidden.

When using a z-buffer, a pixel can be culled (discarded) as soon as its depth is known, which makes it possible to skip the entire process of lighting and texturing a pixel that would not be visible anyway. Also, time-consuming pixel shaders will generally not be executed for the culled pixels. This makes z-culling a good optimization candidate in situations where fillrate, lighting, texturing or pixel shaders are the main bottlenecks.

While z-buffering allows the geometry to be unsorted, sorting polygons by increasing depth (thus using a reverse painter's algorithm) allows each screen pixel to be rendered fewer times. This can increase performance in fillrate-limited scenes with large amounts of overdraw, but if not combined with z-buffering it suffers from severe problems such as:

  • polygons might occlude one another in a cycle (e.g. : triangle A occludes B, B occludes C, C occludes A), and
  • there is no canonical "closest" point on a triangle (e.g.: no matter whether one sorts triangles by their centroid or closest point or furthest point, one can always find two triangles A and B such that A is "closer" but in reality B should be drawn first).

As such, a reverse painter's algorithm cannot be used as an alternative to Z-culling (without strenuous re-engineering), except as an optimization to Z-culling. For example, an optimization might be to keep polygons sorted according to x/y-location and z-depth to provide bounds, in an effort to quickly determine if two polygons might possibly have an occlusion interaction.

Algorithm

Given: A list of polygons {P1,P2,.....Pn}
Output: A COLOR array, which displays the intensity of the visible polygon surfaces.
Initialize:

          note : z-depth and z-buffer(x,y) is positive........
           z-buffer(x,y)=max depth; and
           COLOR(x,y)=background color.

Begin:

      for(each polygon P in the polygon list) do{
        for(each pixel(x,y) that intersects P) do{
            Calculate z-depth of P at (x,y)
             If (z-depth < z-buffer[x,y]) then{
                  z-buffer[x,y]=z-depth;
                  COLOR(x,y)=Intensity of P at(x,y);
            }
         }
      }
  display COLOR array.

Mathematics

The range of depth values in camera space (see 3D projection) to be rendered is often defined between a near and far value of z. After a perspective transformation, the new value of z, or z', is defined by:

z'=
\frac{\mathit{far}+\mathit{near}}{\mathit{far}-\mathit{near}} +
\frac{1}{z} \left(\frac{-2 \cdot \mathit{far} \cdot \mathit{near}}{\mathit{far}-\mathit{near}}\right)

After an orthographic projection, the new value of z, or z', is defined by:

z'=
2 \cdot \frac{{z} - \mathit{near}}{\mathit{far}-\mathit{near}} - 1

where z is the old value of z in camera space, and is sometimes called w or w'.

The resulting values of z' are normalized between the values of -1 and 1, where the near plane is at -1 and the far plane is at 1. Values outside of this range correspond to points which are not in the viewing frustum, and shouldn't be rendered.

Fixed-point representation

Typically, these values are stored in the z-buffer of the hardware graphics accelerator in fixed point format. First they are normalized to a more common range which is [0,1] by substituting the appropriate conversion  z'_2 = \frac{\left(z'_1+1\right)}{2} into the previous formula:

z'=
\frac{\mathit{far}+\mathit{near}}{2 \cdot \left( \mathit{far}-\mathit{near} \right) } +
\frac{1}{z} \left(\frac{-\mathit{far} \cdot \mathit{near}}{\mathit{far}-\mathit{near}}\right) + 
\frac{1}{2}

Second, the above formula is multiplied by S = 2d − 1 where d is the depth of the z-buffer (usually 16, 24 or 32 bits) and rounding the result to an integer:[1]

z'=f\left(z\right)=\left\lfloor  \left(2^d-1\right) \cdot \left(
\frac{\mathit{far}+\mathit{near}}{2 \cdot \left( \mathit{far}-\mathit{near} \right) } +
\frac{1}{z} \left(\frac{-\mathit{far} \cdot \mathit{near}}{\mathit{far}-\mathit{near}}\right) + 
\frac{1}{2} \right) \right\rfloor

This formula can be inversed and derivated in order to calculate the z-buffer resolution (the 'granularity' mentioned earlier). The inverse of the above f\left(z\right):

z=
\frac{- \mathit{far} \cdot \mathit{near}}{\frac{z'}{S}\left(\mathit{far} - \mathit{near}\right) - {far}} 
=
\frac{- \mathit S  \cdot {far} \cdot \mathit{near}}{z'\left(\mathit{far} - \mathit{near}\right) - {far} \cdot S }

where S = 2d − 1

The z-buffer resolution in terms of camera space would be the incremental value resulted from the smallest change in the integer stored in the z-buffer, which is +1 or -1. Therefore this resolution can be calculated from the derivative of z as a function of z':


\frac{dz}{dz'}=
\frac{-1 \cdot -1 \cdot \mathit S  \cdot {far} \cdot \mathit{near}}
     {\left( z'\left(\mathit{far} - \mathit{near}\right) - {far} \cdot S \right)^2}
\cdot \left(\mathit{far} - \mathit{near}\right)

Expressing it back in camera space terms, by substituting z' by the above f\left(z\right):

\frac{dz}{dz'}=
\frac{-1 \cdot -1 \cdot \mathit S  \cdot {far} \cdot \mathit{near} \cdot \left(\mathit{far} - \mathit{near}\right)}
     {\left( \mathit S  \cdot \left(\frac{-\mathit{far} \cdot \mathit{near}}{z} + \mathit{far}\right) - {far} \cdot S \right)^2} =


\frac{ \left(\mathit{far} - \mathit{near}\right) \cdot z^2 }{ S \cdot \mathit{far} \cdot \mathit{near} }=


\frac{z^2}{S \cdot \mathit{near}}-\frac{z^2}{S \cdot \mathit{far} }=

~ 
\frac{z^2}{S \cdot \mathit{near}}

This shows that the values of z' are grouped much more densely near the near plane, and much more sparsely farther away, resulting in better precision closer to the camera. The smaller the near / far ratio is, the less precision there is far away—having the near plane set too closely is a common cause of undesirable rendering artifacts in more distant objects.[2]

To implement a z-buffer, the values of z' are linearly interpolated across screen space between the vertices of the current polygon, and these intermediate values are generally stored in the z-buffer in fixed point format.

W-buffer

To implement a w-buffer, the old values of z in camera space, or w, are stored in the buffer, generally in floating point format. However, these values cannot be linearly interpolated across screen space from the vertices—they usually have to be inverted, interpolated, and then inverted again. The resulting values of w, as opposed to z', are spaced evenly between near and far. There are implementations of the w-buffer that avoid the inversions altogether.

Whether a z-buffer or w-buffer results in a better image depends on the application.

See also

References

External links

Notes

Note 1: see W.K. Giloi, J.L. Encarnação, W. Straßer. "The Giloi’s School of Computer Graphics". Computer Graphics 35 4:12–16.


Wikimedia Foundation. 2010.

Look at other dictionaries:

  • Buffering agent — For an aqueous solution composed of both a weak acid or base and its conjugate, see Buffer solution. For uses not related to acid base chemistry, see Buffer. A buffering agent adjusts the pH of a solution. The function of a buffering agent is to… …   Wikipedia

  • buffering method — buferizavimo metodas statusas T sritis automatika atitikmenys: angl. buffering method vok. Pufferungsmethode, f rus. метод буферизации, m; метод буферирования, m pranc. méthode tampon, f …   Automatikos terminų žodynas

  • buffering — tarpinis kaupimas statusas T sritis radioelektronika atitikmenys: angl. buffering; spooling vok. Pufferung, f rus. буферизация, f; откачка данных, f; подкачка данных, f pranc. spoulage, m; tamponnage, m …   Radioelektronikos terminų žodynas

  • buffering — buferingumas statusas T sritis augalininkystė apibrėžtis Atsparumas išorinių veiksnių sukeliamiems pakitimams. atitikmenys: angl. buffering rus. буферность …   Žemės ūkio augalų selekcijos ir sėklininkystės terminų žodynas

  • buffering — buf·fer·ing (bufґər ing) the action produced by a buffer …   Medical dictionary

  • buffering — n. one that buffs; cushion which lessens or absorbs shock; polisher buf·fer || bÊŒfÉ™ n. divider, partition; location in the memory designated for temporary storage (Computers); shock absorber v. lessen, ease, make less severe; protect, shield;… …   English contemporary dictionary

  • buffering — The practice of isolating the operations within an organization from the effects of environmental uncertainty. This can be achieved either by holding inventory or by the design of the organization s systems. While a degree of stability may be… …   Big dictionary of business and management

  • Buffering — VP An online video term referring to the downloading process of a video …   Audio and video glossary

  • buffering — /ˈbʌfərɪŋ/ (say bufuhring) noun Computers the system by which data, as data in streaming, is stored in a buffer until the buffer is full to accommodate any delays in transmission before the audio or video can be played …   Australian English dictionary

  • buffering system —    The several blood factors that enable the acid waste products of metabolism to be carried in the alkaline blood without disrupting its chemistry. These include carbolic acid, carbonates, phosphates, electrolytes, blood proteins, and… …   Herbal-medical glossary

  • buffering — …   Useful english dictionary


Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”

We are using cookies for the best presentation of our site. Continuing to use this site, you agree with this.