Java 中分形圖的幾種方法詳解
Java分形
Java的分形主要有一下幾種:
1.類似Clifford的分形。這種分形的特點(diǎn)是:分形的初始坐標(biāo)為(0,0),通過初始坐標(biāo)經(jīng)過大量的迭代,得到一系列的點(diǎn),根據(jù)得到的點(diǎn)來繪制分形曲線。這類分形的參數(shù)有限,可以很簡(jiǎn)單的實(shí)現(xiàn)。
2.類似IFS fern這樣的分形。這種分形比上一種分形具有更多的參數(shù),值得注意的是IFS fern分形的參數(shù)列表中有一項(xiàng)P值,該值表示的是各組不同的參數(shù)應(yīng)該出現(xiàn)的概率,如果這個(gè)值沒用上是無法得到想要的圖形的。
3.類似Mandelbrot這樣的分形。這種分形涉及到了復(fù)數(shù)的知識(shí),以及時(shí)間逃逸算法。本質(zhì)上是復(fù)平面上一系列點(diǎn)的集合,用時(shí)間逃逸算法來確定點(diǎn)是否在集合內(nèi),得到一系列的點(diǎn),根據(jù)這些點(diǎn)來繪制圖形。
4.類似L-System Sticks這樣的分形。這類的分形需要定義母串,以及演變的規(guī)則,通過不同的母串和演變規(guī)則的到的點(diǎn)來繪制圖形。演變規(guī)則和母串等的理解并不難,主要是涉及了坐標(biāo)之間的變換較為難以計(jì)算。
下面是一段關(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ù)的算法,時(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;// 擴(kuò)大出現(xiàn)方格
double y = y0 * 150 + 500;
g.drawLine((int) x, (int) y, (int) x, (int) y);
}
}
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
springboot+swagger2.10.5+mybatis-plus 入門詳解
這篇文章主要介紹了springboot+swagger2.10.5+mybatis-plus 入門,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
Java的PriorityBlockingQueue優(yōu)先級(jí)阻塞隊(duì)列代碼實(shí)例
這篇文章主要介紹了Java的PriorityBlockingQueue優(yōu)先級(jí)阻塞隊(duì)列代碼實(shí)例,PriorityBlockingQueue顧名思義是帶有優(yōu)先級(jí)的阻塞隊(duì)列,為了實(shí)現(xiàn)按優(yōu)先級(jí)彈出數(shù)據(jù),存入其中的對(duì)象必須實(shí)現(xiàn)comparable接口自定義排序方法,需要的朋友可以參考下2023-12-12
SpringBoot使用CXF集成WebService的方法
這篇文章主要介紹了SpringBoot使用CXF集成WebService的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
初探Spring Cloud Gateway實(shí)戰(zhàn)
這篇文章主要介紹了創(chuàng)建網(wǎng)關(guān)項(xiàng)目(Spring Cloud Gateway)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-08-08
使用session實(shí)現(xiàn)簡(jiǎn)易購物車功能
這篇文章主要為大家詳細(xì)介紹了使用session實(shí)現(xiàn)簡(jiǎn)易購物車功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
詳解Kotlin:forEach也能break和continue
這篇文章主要介紹了詳解Kotlin:forEach也能break和continue的相關(guān)資料,需要的朋友可以參考下2017-06-06

