Information About

Diamond-square Algorithm




The diamond-square algorithm is a method for generating highly realistic Heightmap s for Computer Graphics . It is a three-dimensional implementation of the Midpoint Displacement Algorithm which produces two-dimensional landscapes. It is also known as the '''random midpoint displacement fractal''', the '''cloud fractal''' or the '''plasma fractal''', because the of the Plasma Effect produced when applied.


ALGORITHM


  • Assign a height value to each corner of the rectangle (image).

  • Divide the rectangle into 4 subrectangles, and let their height values be the mean values of the corners of the parent rectangle.

  • :For example, the upper left sub-rectangle in


:
\begin{bmatrix}
0 & 2 \
4 & 8\
\end{bmatrix}
will have the height values
\begin{bmatrix}
0 & (0+2)/2 \
(0+4)/2 & (0+2+4+8)/4 \
\end{bmatrix}
=
\begin{bmatrix}
0 & 1 \
2 & 3.5\
\end{bmatrix}


:But when computing the middle height, one should add a small error, that depends on the size of the rectangle (the standard is to let the error be propotional to the size of the rectangle and some constant. The constant controls the "roughness" of the fractal; a bigger constant results in more valleys and mountains).
  • Iterate and subdivide each rectange into smaller ones. Eventually, they will be too small to produce a noticiable difference. When this occurs, stop the iteration, and render the pixel with the mean of the height values.



APPLICATIONS


This Algorithm can be used to generate realistic-looking Landscapes , and different implementations are used in computer graphics software such as Bryce .


EXTERNAL LINKS