Алгоритм алмаз-квадрат - Diamond-square algorithm

Плазменный фрактал
Анимированный плазменный фрактал с цветовой цикл

В алгоритм ромбовидного квадрата это метод создания карты высот за компьютерная графика. Это немного лучший алгоритм, чем трехмерная реализация алгоритма смещения средней точки, который создает двумерные ландшафты. Он также известен как случайный фрактал смещения средней точки, то облачный фрактал или плазменный фрактал, из-за плазменный эффект производится при нанесении.

Идея была впервые представлена Фурнье, Fussell и плотник в СИГГРАФ 1982.[1]

Алгоритм ромбовидного квадрата начинается с двумерной сетки, затем произвольно генерирует высоту местности из четырех исходных значений, расположенных в сетке точек, так что вся плоскость покрывается квадратами.

Описание

Алгоритм ромбовидного квадрата начинается с двумерного квадратного массива шириной и высотой 2.п + 1. Для четырех угловых точек массива сначала должны быть установлены начальные значения. Затем поочередно выполняются ромбовидные и квадратные шаги, пока не будут установлены все значения массива.

  • Алмазный шаг: Для каждого квадрата в массиве установите среднюю точку этого квадрата как среднее из четырех угловых точек плюс случайное значение.
  • Квадратный шаг: Для каждого ромба в массиве установите среднюю точку этого ромба как среднее из четырех угловых точек плюс случайное значение.

На каждой итерации следует уменьшать величину случайной величины.

Во время квадратного шага для точек, расположенных на краях массива, будут установлены только три соседних значения, а не четыре. Есть несколько способов справиться с этой сложностью - самый простой - взять среднее только трех соседних значений. Другой вариант - «обернуть», взяв четвертое значение с другой стороны массива. При использовании с согласованными начальными значениями углов этот метод также позволяет сшивать сгенерированные фракталы без разрывов.

Визуализация

На изображении ниже показаны этапы выполнения алгоритма ромбовидного квадрата на массиве 5 × 5.

Визуализация алгоритма алмазного квадрата

Приложения

Этот алгоритм можно использовать для создания реалистичных пейзажи, и различные реализации используются в программном обеспечении компьютерной графики, таком как Terragen. Он также применим как общий компонент в процедурные текстуры.

Артефакты и расширения

Алгоритм ромбовидного квадрата был проанализирован Гэвин С. П. Миллер в SIGGRAPH 1986[2] который описал его как некорректный, поскольку алгоритм производит заметные вертикальные и горизонтальные «складки» из-за наиболее значительного возмущения, имеющего место в прямоугольной сетке. Артефакты сетки были устранены в обобщенном алгоритме, введенном Дж. П. Льюисом.[3] В этом варианте веса в соседних точках получаются путем решения небольшой линейной системы, мотивированной теорией оценивания, а не фиксированной. Алгоритм Льюиса также позволяет синтезировать нефрактальные карты высот, такие как холмы или океанские волны. Подобные результаты могут быть эффективно получены с помощью синтеза Фурье,[4] хотя возможность адаптивной доработки потеряна. Алгоритм ромбовидного квадрата и его усовершенствования рассматриваются в книге.[4]

Рекомендации

  1. ^ Фурнье, Ален; Фасселл, Дон; Карпентер, Лорен (июнь 1982). «Компьютерный рендеринг стохастических моделей». Коммуникации ACM. 25 (6): 371–384. Дои:10.1145/358523.358553.
  2. ^ Миллер, Гэвин С. П. (август 1986 г.). «Определение и рендеринг карт местности». ACM SIGGRAPH Компьютерная графика. 20 (4): 39–48. Дои:10.1145/15886.15890.
  3. ^ Льюис, Дж. П. (1 июля 1987 г.). «Обобщенное стохастическое подразделение». Транзакции ACM на графике. 6 (3): 167–190. CiteSeerX  10.1.1.21.3719. Дои:10.1145/35068.35069.
  4. ^ а б Пайтген, Хайнц-Отто, Дитмар Саупе (1988). Наука о фрактальных изображениях. Нью-Йорк: Springer-Verlag. ISBN  978-0-387-96608-3.

внешняя ссылка