-1
만델 브로 프랙털을 생성하는 방정식은 Zn+1 = Zn^2+C
입니다. 문제는 컴퓨터 프로그램에서 C가 화면의 줌/해상도 및 위치에 사용된다는 것입니다. (Rosetta Code에서)Mandelbrot 프랙탈을 생성 할 때 C 값을 어떻게 설정할 수 있습니까?
(equation 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);;
}
}
정확하게 무엇이 질문입니까? 확대/축소 창을 커버하는 지역 변수를 얻는 방법? 또는 복잡한 인수에 대해 사인을 구현하는 방법? 또는 다른 것? – LutzL