当前位置: 首页 > 知识库问答 >
问题:

生成Mandelbrot分形时,如何设置c的值?

穆锋
2023-03-14

生成Mandelbrot分形的方程是Zn1=Zn^2 C。问题是,在计算机程序中,C用于屏幕上的缩放/分辨率和位置。我的问题是,我怎样才能得到这样的分形:

沃尔夫拉姆

方程f(z)=sin(z/c),z0=c

我的代码(来自罗塞塔代码):

public class MandelbrotSet extends JFrame {
    private static final long serialVersionUID = 5513426498262284949L;
    private final int MAX_ITER = 570;
    private final double ZOOM = 150;
    private BufferedImage image;
    private double zx, zy, cX, cY, tmp;

    public MandelbrotSet() {
        super("Mandelbrot Set");
        setBounds(100, 100, 800, 600);
        setResizable(false);
        setDefaultCloseOperation(EXIT_ON_CLOSE);
        image = new BufferedImage(getWidth(), getHeight(), BufferedImage.TYPE_INT_RGB);
        for (int y = 0; y < getHeight(); y++) {
            for (int x = 0; x < getWidth(); x++) {
                zx = zy = 0;
                cX = (x - 400) / ZOOM;
                cY = (y - 300) / ZOOM;
                int iter = MAX_ITER;

                while (zx * zx + zy * zy < 4 && iter > 0) {
                    tmp = zx * zx - zy * zy + cX;
                    zy = 2.0 * zx * zy + cY;
                    zx = tmp;
                    iter--;
                }

                image.setRGB(x, y, iter | (iter << 8));
            }
        }
    }

        @Override
        public void paint(Graphics g) {
            g.drawImage(image, 0, 0, this);
        }

    public static void main(String[] args) {
        new MandelbrotSet().setVisible(true);;
    }
}

共有1个答案

曾河
2023-03-14

利用三角定理

sin(A+i*B)=sin(A)*cos(i*B)+  cos(A)*sin(i*B) 
          =sin(A)*cosh(B )+i*cos(A)*sinh(B )

对于商,使用z=xi*yc=ai*b

(x+i*y)/(a+i*b)=(x+i*y)*(a-i*b)/(a*a+b*b)

对于上面的正弦表达式

A = (a*x+b*y)/(a*a+b*b)
B = (a*y-b*x)/(a*a+b*b)

在javascript中,生成此分形的小脚本可以如下所示:

function cosh(x) { return 0.5*(Math.exp(x)+Math.exp(-x)); }
function sinh(x) { return 0.5*(Math.exp(x)-Math.exp(-x)); }

function rgb(r,g,b) { return "rgb("+r+","+g+","+b+")"; }
var colors = new Array(24);
for(var k=0; k<8; k++) {
    colors[   k] = rgb(k*64,(7-k)*64,(7-k)*64);
    colors[ 8+k] = rgb((7-k)*64,k*64,(7-k)*64);
    colors[16+k] = rgb((7-k)*64,(7-k)*64,k*64);
}

var cvs = document.getElementById('sine-fractal');
var ctx = cvs.getContext('2d');
var cx = 0.0, cy = 0.0;
var dx = 1.0;

var tiles = 100;
var scale = Math.min(cvs.width, cvs.height) / tiles;
ctx.scale(scale, scale);

function localx(i) { return cx-dx + 2*i*dx/tiles; }
function localy(j) { return cy-dx + 2*j*dx/tiles; }

for (var i = 0; i < tiles; i++) {
  var a = localx(i);
  for (var j = 0; j < tiles; j++) {
    var b = localy(j);
    var r2 = a*a + b*b;
    var x = a, y = b;
    var rounds = 0;
    var max = 500;
    while (x * x + y * y < 4 && rounds < max) {
      var u = (a*x + b*y) / r2, v = (a*y - b*x) / r2;
      x = Math.sin(u) * cosh(v);
      y = Math.cos(u) * sinh(v);
      rounds++;
    }
    ctx.fillStyle = colors[rounds % 24];
    ctx.fillRect(i, j, 1, 1);
  }
}
<canvas id='sine-fractal' width=200 height=200></canvas>
 类似资料:
  • 我开始制作一个mandelbrot集分形查看器。在放大分形时,我遇到了很多问题。如果您尝试缩放,查看器将刚好靠近中心。我已经尽我所能去理解这个困境。我怎样才能放大我的分形,当我放大时,它会放大屏幕的中心,而不是分形的中心?

  • 我一直在做一个渲染Mandelbrot分形的项目。对于那些知道的人,它是通过迭代以下函数生成的,其中c是复杂平面上的点: 迭代该函数将生成以下分形(忽略颜色): 当你把函数改为这个,(z提高到三次方) 分形应该呈现为这样(同样,颜色并不重要): 然而,当我把z提升到3的幂次时,我得到了一个非常类似于把z提升到2的幂次时的图像。如何正确进行分形渲染?这是完成迭代的代码:(实变量和虚变量只是将屏幕从-

  • 对于复杂变量,我使用以下复杂类文件。 下面的java代码是Mandelbrot集合的迭代计算器示例。 提前谢谢!

  • 我在Python中使用PIL模块制作了一个Mandelbrot分形。现在,我想做一个放大到一点的GIF。我在网上看过其他代码,但不用说,我不明白,因为我使用的模式有点不同(我使用的是类)。 我知道要放大我需要改变比例。。。但我显然不知道如何实施它。

  • 我试着制作这个Mandelbrot分形发生器,但当我运行它时,我得到了一个像圆一样的输出。不知道为什么会这样。我想我的颜色可能有问题,但即使如此,形状也不正确。

  • 我见过许多mandelbrot图像生成器绘制mandelbrot的低分辨率分形,然后不断改进分形。这是一个平铺算法吗?以下是一个例子:http://neave.com/fractal/ 更新:我发现关于递归细分和计算mandelbrot:http://www.metabit.org/~rfigura/figura fractal/math。html。也许可以使用kd树来细分图像? 更新2:http