绘制分形火焰

Drawing fractal flames

让我从我一直在阅读的 PDF 文件 link 开始,让我开始画分形火焰。

http://flam3.com/flame_draves.pdf

根据 Draves 的伪代码,我使用提供的三个函数毫无问题地绘制了 Sierpinski 的垫片:

F0(x, y) = ( x/2 , y/2 ) 
F1(x, y) = ( x+1/2 , y/2 ) 
F2(x, y) = ( x/2 , y+1/2 )

伪代码:

(x, y)= a random point in the bi-unit square
iterate { 
    i = a random integer from 0 to n − 1 inclusive
    (x, y) = Fi(x, y)
    plot (xf , yf ) except during the first 20 iterations
}

据我所知,分形火焰是通过应用变体(非仿射函数)制作的,但如果我们查看附录中的变体目录,第一张图像(变体 0)应该是用身份制作的变化。

现在我无法理解如何仅使用一个函数创建这样的图像,在该函数之上是一个身份函数。 (当我们在随机选择的像素上应用身份函数时,它不会只无限地绘制一个像素吗?)

我不清楚我是否应该使用与 Sierpinski 垫圈相同的伪代码,或者是否还有其他一些我在这里没有看到的问题?

编辑:这是包含用 Java 编写的分形火焰图像生成器的最终产品:https://github.com/xtrinch/fractal_generator

Now I can't wrap my head around how can an image like that have been created with using only one function, on top of which an identity function. (Wouldn't it only draw one pixel infinitely as we are applying identity function on a randomly chosen pixel?)

但是这些变体并没有单独使用。相反,它们应用于 i 个可能的仿射变换的结果。请参考第 4 页底部“3 种变化”标题下的公式:

Fi(x, y) = Vj(aix + biy + ci, dix + eiy + fi)

如果 j 为 0 并且您使用的是变体 0:

V0(x, y) = (x, y)

然后

Fi(x, y) = (aix + biy + ci, dix + eiy + fi)

换句话说,使用变化 0 只是意味着一个简单的仿射变换,没有应用任何额外的变化。 a, b, c, d, e, f 是 Fi 的仿射变换参数,你将有 i 组参数。

如果 j 为 1 则变化函数为:

V1(x, y) = (sin (x), sin(y))

所以

Fi(x, y) = (sin(aix + biy + ci), sin(dix + eiy + fi))

等等。

如前所述,对于每个 i 函数,每个变体都可以有一个混合参数 vij,因此您可以计算仿射变换,应用所有affine-transformed点不同的变化函数,然后根据混合因子将结果混合在一起。