Симплексный шум - Simplex noise

Абстрактная композиция в 3D, созданная с помощью OpenSimplex шум алгоритм генерации.

Симплексный шум это метод построения п-размерный шум функция сопоставима с Шум Перлина («классический» шум), но с меньшим направленные артефакты и, в более высоких измерениях, меньшие вычислительные затраты. Кен Перлин разработал алгоритм в 2001 г.[1] чтобы устранить ограничения его классической функции шума, особенно в более высоких измерениях.

Преимущества симплексного шума перед шумом Перлина:

  • Симплексный шум имеет меньшую вычислительную сложность и требует меньшего количества умножений.
  • Симплексный шум масштабируется до более высоких измерений (4D, 5D) с гораздо меньшими вычислительными затратами: сложность за размеры вместо классического шума.[2]
  • Симплексный шум не имеет заметных направленных артефактов (визуально изотропный ), хотя шум, генерируемый для разных размеров, визуально различен (например, 2D-шум имеет другой вид, чем срезы 3D-шума, и он выглядит все хуже для более высоких измерений.[нужна цитата ]).
  • Симплексный шум имеет четко определенный и непрерывный градиент (почти) везде, который можно довольно дешево вычислить.
  • Симплексный шум легко реализовать аппаратно.

В то время как классический шум интерполируется между градиенты в окружающих конечных точках гиперсети (т.е. северо-восток, северо-запад, юго-восток и юго-запад в 2D[нужна цитата ]) симплексный шум делит пространство на симплексы (т.е. -мерные треугольники). Это уменьшает количество точек данных. Пока гиперкуб в размеры имеет уголки, симплекс в размеры имеет только углы. Треугольники равносторонний в 2D, но в более высоких измерениях симплексы только приблизительно регулярны. Например, мозаика в трехмерном случае функции является ориентацией тетрагональные дифеноидные соты.

Симплексный шум полезен для приложений компьютерной графики, где шум обычно вычисляется по 2, 3, 4 или, возможно, 5 измерениям. Для более высоких измерений п-сферы вокруг п-симплексные углы не упакованы достаточно плотно, что снижает поддержку функции и делает ее нулевой на больших участках пространства.

Деталь алгоритма

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

Координатный перекос

Входная координата преобразуется по формуле

куда

Это приводит к размещению координаты на A*
п
решетка, которая по сути расположение вершин из гиперкубические соты который был сжат по своей главной диагонали до тех пор, пока расстояние между точками (0, 0, ..., 0) и (1, 1, ..., 1) не станет равным расстоянию между точками (0, 0, ..., 0) и (1, 0, ..., 0).

Результирующая координата (x ', y', ...) затем используется для определения, в какой наклонной ячейке единичного гиперкуба находится входная точка, (xb '= floor (x'), yb '= floor (y') , ...) и его внутренние координаты (xi '= x'-xb', yi '= y'-yb', ...).

Симплициальное подразделение

Как только вышеуказанное определено, значения внутренней координаты (xi ', yi', ...) сортируются в порядке убывания, чтобы определить, какие Ортосхема Schläfli симплекс, в котором лежит точка. Тогда получившийся симплекс состоит из вершин, соответствующих упорядоченному обходу ребер от (0, 0, ..., 0) до (1, 1, ..., 1), из которых есть п! возможности, каждая из которых соответствует одной перестановке координаты. Другими словами, начните с нулевой координаты и последовательно добавляйте единицы, начиная со значения, соответствующего наибольшему значению внутренней координаты, и заканчивая наименьшим.

Например, точка (0,4, 0,5, 0,3) будет лежать внутри симплекса с вершинами (0, 0, 0), (0, 1, 0), (1, 1, 0), (1, 1, 1) . Координата yi 'самая большая, поэтому она добавляется первой. Затем следует координата xi 'и, наконец, zi'.

Выбор градиента

Каждая симплексная вершина добавляется обратно к базовой координате перекошенного гиперкуба и хешируется в направлении псевдослучайного градиента. Хэш может быть реализован множеством способов, хотя чаще всего используется таблица перестановок или схема манипуляции с битами.

Следует проявлять осторожность при выборе набора градиентов для включения, чтобы свести к минимуму направленные артефакты.

Суммирование ядра

Вклад каждой из n + 1 вершин симплекса учитывается путем суммирования радиально-симметричных ядер, центрированных вокруг каждой вершины. Сначала определяется нескошенная координата каждой из вершин по обратной формуле

куда

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

  • Чтобы вычислить экстраполированное значение градиента с помощью скалярное произведение
  • Чтобы определить d2, квадрат расстояния до точки.

Отсюда суммарный вклад ядра каждой вершины определяется с помощью уравнения

где r2 обычно устанавливается на 0,5 или 0,6. 0,5 гарантирует отсутствие разрывов, тогда как 0,6 может улучшить визуальное качество в приложениях, для которых разрывы не заметны. 0.6 использовался в исходной эталонной реализации Кена Перлина.

Легальное положение

Использование реализаций в 3D и выше за синтез текстурированного изображения покрыты Патент США 6867776 , если алгоритм реализован с использованием конкретных методов, описанных в любом из пунктов формулы изобретения.

Смотрите также

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

  1. ^ Кен Перлин, Шумовое оборудование. В заметках к курсу SIGGRAPH Shading в реальном времени (2001), Olano M., (Ed.). (pdf)
  2. ^ Кен Перлин, Шуметь. На основе доклада, представленного на GDCHardcore (9 декабря 1999 г.). (URL)

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