Sunday, March 1, 2009

Real-Time Terrain with Geo-Mipmapping

This terrain rendering engine with Geo-Mipmapping is one of my research project. Terrain is an outdoor area, which means not much occlusion-based culling can be done to reduce the total amount of polygon being rendered.


To workaround this issue, we need a method to perfrom terrain rendering with CLOD. The concept of CLOD (Continuous Level of Detail) is not too difficult to understand, basically more details are preserved in the areas closer to the camera view than the farther ones. The key is to maintain real-time rendering performance while not sacrificing too much graphic quality.


Algorithms such as ROAM (Real-time Optimal Adapting Mesh) and Chunked Terrain were developed to compute the CLOD at run-time. I chose to implement the Geo-Mipmapping method utilizes the GPU to do the computational load instead of mainly relying on the CPU.


Essentially the whole terrain area is splitted into many smaller terrain blocks. Each block stores a vertex buffer and multiple levels of index buffers, which represent the terrain block at different resotluion. These computations are done at load-time, and during run-time, based on value of pixel-error / distance factor, a suitable LOD is selected to render the terrain block.



One of the major issue with this approach is the gap formed when blocks of different LODs are adjacent, because the shared edges are represented by different numbers of vertices belonging to each block. To seal these gaps, the index buffer of the higher LOD block is re-computed at run-time to reduce the resolution to match that of the lower LOD block, thus effectively sealing up the gaps.

The end result is the capabilty to render an area made of 2M triangles at full resolution with roughly 20k triangles made of various LOD blocks.

Highlights:
  • OpenGL API.
  • Geo-Mipmapped Terrain.
  • Vertex and Index Buffer.
  • Gap-filling between terrain blocks.