【发布时间】:2016-12-10 17:53:42
【问题描述】:
生成 Mandelbrot 分形的方程式是 Zn+1 = Zn^2+C。问题是,在计算机程序中,C 用于缩放/分辨率和屏幕上的位置。我的问题是,我怎样才能得到这样的分形:
(equation f(z) = sin(z/c), z0 = c)
我的代码(来自Rosetta Code):
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);;
}
}
【问题讨论】:
-
问题到底是什么?如何获取覆盖缩放窗口的局部变量?或者如何实现复杂参数的正弦?还是别的什么?
标签: java math fractals mandelbrot