Фракталы на основе метода IFS

Эту группу составляют фракталы, которые генерируются согласно методу "систем итеративных функций" – IFS (Iterated Functions Systems).

Данный метод может быть описан как последовательный итеративный расчет координат новых точек в пространстве:

где Fx и Fy – функции преобразования координат, например аффинного преобразования. Эти функции и определяют форму фрактала. В случае аффинного преобразования необходимо найти соответствующие числовые значения коэффициентов. Примером такого фрактала является построение изображения листа папоротника (рис. 24).

Для начала итераций необходимо задать стартовые координаты линии – точки 1 и 2. На каждом шаге итераций рассчитываются координаты других точек.

Точка 3 получается поворотом точки 2 на угол a относительно центра в точке 1:

x3=(x2-x1)cosa-(y2-y1)sina+x1,

y3=(x2-x1)sina+(y2-y1)cosa+y1.

Если a=0, то ствол и все ветви прямые.

Находим точку 4. От нее будут распространяться ветви. Пусть соотношение длин отрезков 1-4 и 1-3 равно k (0<k<1). Тогда координаты точки 4: x4=x1(1-k)+kx3, y4=y1(1-k)+ky3.

Задаем длину и угол наклона ветвей, которые выходят из точки 4.

Найдем координаты точки 5: параметр k1– соотношение длин отрезков 4-5 и 4-3 (0<k1<1):

x5=x4(1-k1)+k1x3,

y5=y4(1-k1)+k1y3.

Точка 6 получается поворотом точки 5 относительно точки 4 на угол b, а точка 7 – на угол (-b):

x6=(x5-x4)cosb-(y5-y4)sinb+x4;

y6=(x5-x4)sinb+(y5-y4)cosb+y4;

x7=(x5-x4)cosb+(y5-y4)sinb+x4;

y7=-(x5-x4)sinb+(y5-y4)cosb+y4.

После расчета опорных точек на каждом шаге рисуется отрезок 1-4. В зависимости от номера итерации цвет отрезка можно изменять.

Таким образом, фрактал задается как последовательность аффинных преобразований координат точек. Величины a, b, k, k1 – это параметры, которые описывают вид фрактала в целом. Они представляют собой константы на протяжении всего итеративного процесса. Это дает возможность в итерациях использовать только операции сложения, вычитания и умножения, если вычислить заранее значения:

A=cosa; B=sina; C=(1-k); D=k;

E=1-k1; F=k1; G=cosb; H=sinb.

Опишем рекурсивный алгоритм в виде процедуры ШАГ.

ШАГ(x1, y1, x2, y2, num)

Если (x1-x2)2+(y1-y2)2>lmin, то

Вычисляем координаты точек 3-7:

x3=(x2-x1)A ­- (y2-y1)B + x1

y3=(x2-x1)B + (y2-y1)A + y1

x4=x1C + x3D

y4=y1C + y3D

x5=x4E + x3F

y5=y4E + y3F

x6=(x5-x4)G - (y5-y4)H + x4

y6=(x5-x4)H + (y5-y4)G + y4

x7=(x5-x4)G + (y5-y4)H + x4

y7=-(x5-x4)H + (y5-y4)G + y4

Рисуем отрезок (x1, y1 - x4, y4)

ШАГ(x4, y4, x3, y3, num)

ШАГ(x4, y4, x6, y6, num+1)

ШАГ(x4, y4, x7, y7, num+1)

Для того чтобы нарисовать фрактал, необходимо вызвать процедуру ШАГ, установив соответствующие значения ее аргументов: ШАГ(x1,y1,x2,y2,0). Параметр num показывает степень детализации расчета дерева. Это значение можно использовать для прекращения итеративного процесса.

Завершение циклов итерации в нашем алгоритме происходит тогда, когда длина ветви становится меньше некоторой величины lmin.








Дата добавления: 2015-11-20; просмотров: 867;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.004 сек.