Skip to content

Latest commit

 

History

History
111 lines (79 loc) · 14.1 KB

README-ua.md

File metadata and controls

111 lines (79 loc) · 14.1 KB

Due East over Shadequarter Mountain - Matthew Rangel (2005)

Фрактальний броунівський рух

Для різних людей слово "шум" означає різні речі. Музиканти будуть думати про безладні звуки, інженери зв'язку — про перешкоди, а астрофізики — про космічний мікрохвильовий фон. Ці концепції повертають нас до фізичної природи випадковості в навколишньому світі. Однак почнімо з чогось більш фундаментального та простішого: хвиль та їхніх характеристик. Хвиля — це коливання певної властивості з плином часу. Аудіохвилі — це коливання тиску повітря, електромагнітні хвилі — це коливання електричного та магнітного полів. Двома важливими характеристиками хвилі є її амплітуда та частота. Рівняння для простої лінійної (одномірної) хвилі виглядає так:

  • Спробуйте змінити значення частоти та амплітуди, щоб зрозуміти їх поведінку.
  • Використовуючи формотворчі функції, змінюйте амплітуду залежно від часу.
  • Використовуючи формотворчі функції, змінюйте частоту залежно від часу.

Виконуючи останні дві вправи, ви "модулювали" синусоїду, створивши AM (амплітудно-модульовані) та FM (frequency modulated - частотно-модульовані) хвилі. Мої вітання!

Ще однією цікавою властивістю хвиль є здатність до їх поєднання, що формально називається суперпозицією. Закоментуйте, розкоментуйте та позмінюйте наступні рядки. Зверніть увагу на зміни загального вигляду, коли ми додаємо разом хвилі з різними амплітудами та частотами.

  • Поекспериментуйте, змінюючи частоту й амплітуду додаткових хвиль.
  • Чи можна зробити дві хвилі, що нейтралізуватимуть одна одну? Як це буде виглядати?
  • Чи можна скласти хвилі так, щоб вони посилювали одна одну?

У музиці кожна нота асоціюється з певною частотою. Частоти для цих нот відповідають певному порядку, який ми називаємо гамою. Подвоєння або зменшення частоти вдвоє відповідає зміні ноти на одну октаву.

Тепер, замість синусоїди, використаємо шум Перліна! Шум Перліна у своїй основній формі виглядає та відчувається, як синусоїда. Його амплітуда та частота дещо мінливі, але амплітуда залишається досить однорідною, а частота обмежена досить вузьким діапазоном навколо центральної частоти. В цілому шум не такий регулярний, як синусоїда, та з його допомогою легше створити видимість випадковості, об'єднавши кілька масштабованих версій. Вигляд суми синусоїд також можна зробити більш випадковим, але для цього потрібно багато різних хвиль, щоб приховати їх періодичну та регулярну природу.

Додаючи різні ітерації шуму (октави), у яких ми послідовно збільшуємо частоту на регулярну величину (лакунарність) та зменшуємо амплітуду (посилення) шуму, можна отримати деталізованіший шум та більше дрібних деталей. Ця техніка називається "фрактальний броунівський рух" (fBM) або просто "фрактальний шум". У найпростішому вигляді її можна створити за допомогою наступного коду:

  • Поступово збільшуйте кількість октав від 1 до 2, 4, 8 і 10. Спостерігайте за результатом.
  • Коли матимете понад чотири октави, спробуйте змінити значення лакунарності.
  • Також, коли октав понад 4, змініть значення для посилення (gain) та подивіться, що станеться.

Зверніть увагу, що з кожною додатковою октавою крива стає деталізованішою. Також зверніть увагу на прояви самоподібності, зі збільшенням кількості октав. Якщо збільшити масштаб кривої, менша її частина виглядатиме приблизно так само, як і вся крива, а кожен окремий відрізок виглядає більш-менш схоже на будь-який інший. Це важлива властивість математичних фракталів, яку ми моделюємо у нашому циклі. Ми не створюємо справжній фрактал, оскільки зупиняємо модуляцію після кількох ітерацій, але теоретично можна отримати справжній математичний фрактал, якщо дозволити циклу тривати вічно та додавати нескінченну кількість компонентів шуму. У комп'ютерній графіці ми завжди маємо обмеження щодо найдрібніших деталей, які можемо розпізнати. Наприклад, якщо об'єкти стають меншими за піксель, немає потреби робити нескінченні обрахунки, щоб створити видимість фракталу. Іноді може знадобитися багато доданків, але ніколи не знадобиться їх нескінченна кількість.

Наступний код показує реалізацію двомірного fBm, схожого на фрактальний візерунок:

  • Знизьте кількість октав, змінивши значення в рядку 37
  • Змініть значення лакунарності у рядку 47
  • Дослідіть результати, змінюючи значення підсилення в рядку 48

Ця техніка зазвичай використовується для побудови процедурних ландшафтів. Самоподібність fBm ідеально підходить для створення гір, тому що процеси ерозії, які створюють реальні гори, також надають їм вигляд самоподібності в широкому діапазоні масштабів. Якщо це вас зацікавило, вам варто прочитати цю чудову статтю Inigo Quiles про вдосконалений шум.

Blackout - Dan Holdsworth (2010)

Використовуючи більш-менш таку саму техніку, можна також отримати й інші ефекти, такі як турбулентність. По суті, це fBm, але побудований з абсолютних значень шуму, що створює різкі впадини.

for (int i = 0; i < OCTAVES; i++) {
    value += amplitude * abs(snoise(st));
    st *= 2.;
    amplitude *= .5;
}

Іншим представником цього сімейства алгоритмів є хребти, де гострі долини перевернуті догори дном, щоб натомість вийшли гострі гребні:

    n = abs(n);     // створюємо складки 
    n = offset - n; // інвертуємо складки догори дном
    n = n * n;      // загострюємо складки ще більше

Ще один варіант з корисними варіаціями можна здобути за допомогою перемноження компонентів шуму замість їх додавання. Також цікаво масштабувати наступні шумові функції на основі чогось, що залежить від попередніх сум складових. Коли ми робимо подібні речі, то віддаляємося від суворого визначення фракталу та переходимо у відносно невідому область "мультифракталів". Мультифрактали поки що не мають чіткого математичного визначення, але це не робить їх менш корисними для графіки. Насправді мультифрактальне моделювання дуже поширене в сучасному комерційному програмному забезпеченні для генерації рельєфу. Детальніше про це можна прочитати у 16 розділі 3-го видання книги "Текстурування та моделювання: процедурний підхід" ("Texturing and Modeling: a Procedural Approach"), автор Kenton Musgrave. На жаль, цю книгу перестали друкувати, але її все ще можна знайти в бібліотеках та вторинному ринку. Майте на увазі, що в інтернеті продається PDF-версія 1-го видання, яку не варто купувати, оскільки воно не містить жодного матеріалу про моделювання ландшафтів.

Викривлення домену (просторової області)

Inigo Quiles написав ще одну захопливу статтю про використання fBm для деформації простору fBm. Вибух мозку, правда? Це як сон уві сні у фільмі "Початок" (Inception).

f(p) = fbm(p + fbm(p + fbm(p))) - Inigo Quiles (2002)

Менш екстремальний приклад цієї техніки показано у наступному коді, де викривлення використовується для отримання текстури, схожої на хмари. Зверніть увагу, що властивість самоподібності все ще присутня у результаті:

Викривлення координат текстури за допомогою шуму може бути дуже корисним, дуже веселим та диявольськи складним для освоєння. Це потужний інструмент, але щоб добре його використовувати, потрібен певний досвід. Корисним підходом для подібних маніпуляцій є зміщення координат за допомогою похідної (градієнта) шуму. На цій ідеї базується відома стаття під назвою "Шум потоку", автори Ken Perlin та Fabrice Neyret. Деякі сучасні реалізації шуму Перліна включають обчислення як функції, так і її аналітичного градієнта.