欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年07月08日 10:27:15   投稿:lqh  
這篇文章主要介紹了Java 中幾種分形的方法詳解的相關(guān)資料,需要的朋友可以參考下

Java分形

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

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

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

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

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

下面是一段關(guān)于Mandelbrot分形的代碼。

/**
 * 復(fù)數(shù)類
 * @author CBS
 */
public class Complex {
  
  public double r;
  public double i;
  
  public Complex(double real,double image){
    this.r=real;
    this.i=image;
  }
  //取復(fù)數(shù)的模
  public double modulus(){
    return Math.sqrt(r*r+i*i);
  }
  //復(fù)數(shù)的加法
  public Complex add(Complex z){
    double addr=r+z.r;
    double addi=i+z.i;
    return new Complex(addr,addi);
  }
  //復(fù)數(shù)的乘法
  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);
  }
}
// 求最大的迭代次數(shù)的算法,時間逃逸算法
  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;
  }

// 畫圖的算法
  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;// 擴大出現(xiàn)方格
          double y = y0 * 150 + 500;
          g.drawLine((int) x, (int) y, (int) x, (int) y);
        }
      }
    }
  }

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

相關(guān)文章

  • elasticsearch插件開發(fā)教程

    elasticsearch插件開發(fā)教程

    這篇文章主要為大家詳細介紹了elasticsearch插件開發(fā)教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • SpringBoot之核心依賴和自動配置方式

    SpringBoot之核心依賴和自動配置方式

    這篇文章主要介紹了SpringBoot之核心依賴和自動配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • spring cloud oauth2 feign 遇到的坑及解決

    spring cloud oauth2 feign 遇到的坑及解決

    這篇文章主要介紹了spring cloud oauth2 feign 遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Jmeter多用戶并發(fā)壓力測試過程圖解

    Jmeter多用戶并發(fā)壓力測試過程圖解

    這篇文章主要介紹了Jmeter多用戶并發(fā)壓力測試過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2020-07-07
  • SpringBoot中的自定義starter

    SpringBoot中的自定義starter

    這篇文章主要介紹了SpringBoot中的自定義starter,Starter是Spring?Boot中的一個非常重要的概念,Starter相當于模塊,它能將模塊所需的依賴整合起來并對模塊內(nèi)的Bean根據(jù)環(huán)境(條件)進行自動配置,需要的朋友可以參考下
    2024-01-01
  • Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法

    Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法

    這篇文章主要介紹了Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Java?Process中waitFor()的問題詳解

    Java?Process中waitFor()的問題詳解

    這篇文章主要給大家介紹了關(guān)于Java?Process中waitFor()問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2022-12-12
  • java中BigDecimal的使用踩坑記錄

    java中BigDecimal的使用踩坑記錄

    這篇文章主要為大家詳細介紹了java中使用BigDecimal會踩坑的地方以及相關(guān)的解決方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習一下
    2023-10-10
  • springmvc mybatis集成配置示例

    springmvc mybatis集成配置示例

    本文主要介紹springmvc+mybatis集成配置,這里提供了實例代碼,和簡單說明,有需要的小伙伴可以參考下
    2016-09-09
  • java使用DOM對XML文檔進行增刪改查操作實例代碼

    java使用DOM對XML文檔進行增刪改查操作實例代碼

    這篇文章主要介紹了java使用DOM對XML文檔進行增刪改查操作實例代碼,實例涉及對xml文檔的增刪改查,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02

最新評論