Jump to content

Screen space ambient occlusion: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
See also: hiding link to non-existent article redirect, that redirects to a non-existent glossary entry
Line 30: Line 30:
*[[Ambient occlusion]]
*[[Ambient occlusion]]
*[[Screen space directional occlusion]] (SSDO)<ref>{{cite web|author1=Tobias Ritschel|author2=Thorsten Grosch|author3=Hans-Peter Seidel|title=Approximating Dynamic Global Illumination in Image Space|url=http://people.mpi-inf.mpg.de/~ritschel/SSDO/|publisher=Proceedings ACM SIGGRAPH Symposium on Interactive 3D Graphics and Games|accessdate=25 November 2015|date=2009}}</ref>
*[[Screen space directional occlusion]] (SSDO)<ref>{{cite web|author1=Tobias Ritschel|author2=Thorsten Grosch|author3=Hans-Peter Seidel|title=Approximating Dynamic Global Illumination in Image Space|url=http://people.mpi-inf.mpg.de/~ritschel/SSDO/|publisher=Proceedings ACM SIGGRAPH Symposium on Interactive 3D Graphics and Games|accessdate=25 November 2015|date=2009}}</ref>
*[[Horizon-based ambient occlusion]] (HBAO)
<!-- *[[Horizon-based ambient occlusion]] (HBAO) : Hiding as this is a redirect to a non-existent entry -->


==References==
==References==

Revision as of 16:03, 2 July 2017

Screen space ambient occlusion (SSAO) is a computer graphics technique for efficiently approximating the ambient occlusion effect in real time. It was developed by Vladimir Kajalin while working at Crytek and was used for the first time in 2007 by the video game Crysis, developed by Crytek and published by Electronic Arts.

Implementation

SSAO component of a typical game scene

The algorithm is implemented as a pixel shader, analyzing the scene depth buffer which is stored in a texture. For every pixel on the screen, the pixel shader samples the depth values around the current pixel and tries to compute the amount of occlusion from each of the sampled points. In its simplest implementation, the occlusion factor depends only on the depth difference between sampled point and current point.

Without additional smart solutions, such a brute force method would require about 200 texture reads per pixel for good visual quality. This is not acceptable for real-time rendering on current graphics hardware. In order to get high quality results with far fewer reads, sampling is performed using a randomly rotated kernel. The kernel orientation is repeated every N screen pixels in order to have only high-frequency noise in the final picture. In the end this high frequency noise is greatly removed by a NxN post-process blurring step taking into account depth discontinuities (using methods such as comparing adjacent normals and depths). Such a solution allows a reduction in the number of depth samples per pixel to about 16 or fewer while maintaining a high quality result, and allows the use of SSAO in soft real-time applications like computer games.

Compared to other ambient occlusion solutions, SSAO has the following advantages:

  • Independent from scene complexity.
  • No data pre-processing needed, no loading time and no memory allocations in system memory.
  • Works with dynamic scenes.
  • Works in the same consistent way for every pixel on the screen.
  • No CPU usage – it can be executed completely on the GPU.
  • May be easily integrated into any modern graphics pipeline.

Of course it has its disadvantages as well:

  • Rather local and in many cases view-dependent, as it is dependent on adjacent texel depths which may be generated by any geometry whatsoever.
  • Hard to correctly smooth/blur out the noise without interfering with depth discontinuities, such as object edges (the occlusion should not "bleed" onto objects).

See also

References

  1. ^ Tobias Ritschel; Thorsten Grosch; Hans-Peter Seidel (2009). "Approximating Dynamic Global Illumination in Image Space". Proceedings ACM SIGGRAPH Symposium on Interactive 3D Graphics and Games. Retrieved 25 November 2015.