一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java 中分形圖的幾種方法詳解

Java 中分形圖的幾種方法詳解

2020-11-29 11:47Java教程網 Java教程

這篇文章主要介紹了Java 中幾種分形的方法詳解的相關資料,需要的朋友可以參考下

Java分形

Java的分形主要有一下幾種:

1.類似Clifford的分形。這種分形的特點是:分形的初始坐標為(0,0),通過初始坐標經過大量的迭代,得到一系列的點,根據得到的點來繪制分形曲線。這類分形的參數有限,可以很簡單的實現。

2.類似IFS fern這樣的分形。這種分形比上一種分形具有更多的參數,值得注意的是IFS fern分形的參數列表中有一項P值,該值表示的是各組不同的參數應該出現的概率,如果這個值沒用上是無法得到想要的圖形的。

3.類似Mandelbrot這樣的分形。這種分形涉及到了復數的知識,以及時間逃逸算法。本質上是復平面上一系列點的集合,用時間逃逸算法來確定點是否在集合內,得到一系列的點,根據這些點來繪制圖形。

4.類似L-System Sticks這樣的分形。這類的分形需要定義母串,以及演變的規則,通過不同的母串和演變規則的到的點來繪制圖形。演變規則和母串等的理解并不難,主要是涉及了坐標之間的變換較為難以計算。

下面是一段關于Mandelbrot分形的代碼。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/**
 * 復數類
 * @author CBS
 */
public class Complex {
  
  public double r;
  public double i;
  
  public Complex(double real,double image){
    this.r=real;
    this.i=image;
  }
  //取復數的模
  public double modulus(){
    return Math.sqrt(r*r+i*i);
  }
  //復數的加法
  public Complex add(Complex z){
    double addr=r+z.r;
    double addi=i+z.i;
    return new Complex(addr,addi);
  }
  //復數的乘法
  public Complex mul(Complex z){
    double mulr=r*z.r-i*z.i;
    double muli=i*z.r+r*z.i;
    return new Complex(mulr,muli);
  }
}
?
1
2
3
4
5
6
7
8
9
10
11
// 求最大的迭代次數的算法,時間逃逸算法
  public int mand(Complex z, int maxIte) {
    Complex curComp = new Complex(0, 0);
    for (int i = 0; i < maxIte; i++) {
      if (curComp.modulus() > 2)
        return i;
      curComp = curComp.mul(curComp).add(z);
    }
    return maxIte;
  }
<br>
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// 畫圖的算法
  public void drawMand(Complex z, double scale, int MaxIte) {
    double pixUnit = 3 / (1080 * scale);
    double startx = z.r - 1080 * pixUnit / 2;
    double starty = z.i - 720 * pixUnit / 2;
 
    for (int i = 0; i < 1080; i++) {
      for (int j = 0; j < 720; j++) {
        double x0 = startx + i * pixUnit;
        double y0 = starty + j * pixUnit;
        Complex curComplex = new Complex(x0, y0);
        int time = mand(curComplex, MaxIte);
        if (time == MaxIte) {
          double x = x0 * 150 + 500;// 擴大出現方格
          double y = y0 * 150 + 500;
          g.drawLine((int) x, (int) y, (int) x, (int) y);
        }
      }
    }
  }

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天美传媒影视在线免费观看 | 天天爱天天做天天爽天天躁 | a天堂在线视频 | 免费看成人毛片日本久久 | 亚洲国产欧美日韩在线一区 | 亚洲一区二区三区深夜天堂 | 亚洲国产精品一在线观看 | 成人国产精品一区二区不卡 | 日本最新免费二区 | 青青五月天 | 亚洲精品国产精品国自产观看 | 古装全套 毛片 | 亚洲欧美优优色在线影院 | 天天射寡妇射 | 日本三级免费看 | 亚洲高清国产品国语在线观看 | 亚欧有色在线观看免费版高清 | 校花小雪灌满了男人们的浓浆 | 美女扒下内裤让男人桶的图片 | 久久99国产亚洲高清观着 | 黑帮少爷爱上我第8集在线观看 | 国产精品免费aⅴ片在线观看 | chinesemature老女人 | 国产日韩欧美色视频色在线观看 | 色狠狠成人综合网 | tubehdxx丝袜正片 | 草草视频免费看 | 欧美成人精品福利网站 | 亚洲国产精品网 | 亚洲精品www久久久久久久软件 | 窝窝午夜理伦影院 | 猥琐对着美女飞机喷到脸上 | 精品国产福利在线观看一区 | 大团圆6全文在线阅读 | 性印度freehd | 色综合网天天综合色中文男男 | 1024国产看片在线观看 | 国产日韩精品一区二区在线观看 | 99久久www免费 | 无码国产成人777爽死 | 强迫高h |