For the 2 dimensional representation of fractals, I use a grid with a 1000×1000 resolution and a gradient colorization based on iteration/steps which also offsets the points on the Z-axis for depth.
data:image/s3,"s3://crabby-images/a297b/a297b5a71a3fc4ecdd33181e468b6aa15aa084c1" alt=""
Basic Mandelbrot set
data:image/s3,"s3://crabby-images/43a55/43a550a1d1b2f57300e4be40e312d1878fac002c" alt=""
To plot a Mandelbrot set, we can create a function in a point wrangle. Several attributes can be turned into a channel for more convenience. E.g the MaxIteration and scaling attribute.
As the colors are created in greyscale, it’s easy to convert it to other colors or gradients via a colornode.
Mandelbrot Code
//Mandelbrot function
function int Mandelbrot(float x1, y1; int maxIter)
{
float x0 = x1;
float y0 = y1;
for(int i=0; i<maxIter; i++)
{
float x2 = x0*x0 - y0*y0 + x1;
float y2 = 2*x0*y0 + y1;
if(x2*x2 + y2*y2 > maxIter) return(i);
x0 = x2;
y0 = y2;
}
return(maxIter);
}
//--- Main ---
v@Cd = 0; //set color to black
int maxiter = 30; //maximum iterations ~ resolution of the Mandelbrot set
int result = Mandelbrot(@P.x, @P.y, maxiter); //Main execution
//visualization
if(result < maxiter)
{
float step = 1-(1/float(maxiter)*result); //step calculation for each iteration
v@Cd = set(step,step,step); //color gradient
v@P.z = (v@P.z+0.1)*step; //Z-point offset (optional) the 0.1 is a scaling factor
}
Julia set
The Julia set(s) are part of the Mandelbrot set and can easily achieved by replacing the x1 and y1 in the for loop of our main function with a fixed value (see examples below). For the animation below, I replaced those values with a formula based on the current Framenumber.
data:image/s3,"s3://crabby-images/58789/587899d7d47622b76ec0382ced9d4d73fb210db4" alt=""
y1 = -0.494
data:image/s3,"s3://crabby-images/e51d0/e51d0cec56fea00dde0d3bddc0ed3ebd880fc89e" alt=""
y1 = -0.3842
data:image/s3,"s3://crabby-images/97a4a/97a4ad223a97e97b1c570db2a192111b3469ec67" alt=""
y1 = -0.2321
data:image/s3,"s3://crabby-images/35d89/35d8959734b5ae6460215818a3d75fb2cd85da7e" alt=""
y1 = 0.1889
data:image/s3,"s3://crabby-images/37bf7/37bf7f1ede255806e0f57c06e576fbedb313d711" alt=""
y1 = -0.0225
data:image/s3,"s3://crabby-images/ec6ed/ec6ed5b44e34ac10bf9230fc4dd9ebbee75cc156" alt=""
y1 = -0.651
data:image/s3,"s3://crabby-images/70f9e/70f9ed018e6d6d3ae44f39d796d995d3ee19fb35" alt=""
y1 = 0.3667
data:image/s3,"s3://crabby-images/54173/5417311c7b00d0bbfea374aa0ff1d946a9ebc121" alt=""
y1 = 0.651
Misc
data:image/s3,"s3://crabby-images/93c12/93c1278fe13fce582e67ad40c30b3c1bbce46c65" alt=""
Sierpinski triangle
Pretty simple to create as a loop iterating over a single triangle. Each iteration can be either done as a split or inverted inset. The center triangle is then deleted before the next iteration starts.
Sierpinski Code
data:image/s3,"s3://crabby-images/67b92/67b927869224f700dd210f472de611a663164769" alt=""
int pts[] = primpoints(0, @primnum);
for(int i=0; i<len(pts); i++)
{
int pt = pts[i];
vector pos = point(0, "P", pt);
int triprim = addprim(0,"poly");
for(int n=0; n<len(pts); n++)
{
int npt = pts[n];
vector npos = point(0, "P", npt);
npos -= pos;
npos *= 0.5;
npos += pos;
int newpoint = addpoint(0, npos);
addvertex(0, triprim, newpoint);
}
}
removeprim(0, @primnum, 1);
data:image/s3,"s3://crabby-images/552d0/552d06b882a026c696d962e02dae56e58eee8c89" alt=""
data:image/s3,"s3://crabby-images/1f03b/1f03bdfff4b560c3472f31cef709b2df36b50947" alt=""
2D Fractal Tree
Created as a line which splits in 3 branches in each iteration. Additionally with a channel parameter to control the angle.
At an angle of 90 degree, we get a squared shape, while 120 results in a sierpinski triangle type tree.
2D Fractal Tree Code
data:image/s3,"s3://crabby-images/5e179/5e179147ff9dd59a931c209102d5a509137a42fc" alt=""
float steplenx = chf('steplenx');
float stepleny = chf('stepleny');
float stepangle = chf('stepangle');
vector pos = @P;
pos = pos + v@dir * steplenx;
matrix mat = ident();
rotate(mat, radians(stepangle), set(0,1,0));
pos *= mat;
pos += set(0,1,0) * stepleny;
int newpoint = addpoint(0, pos);
setpointattrib(0, "dir", newpoint, v@dir);
setpointgroup(0, "last", newpoint, 1);
setpointgroup(0, "last", @ptnum, 0);
data:image/s3,"s3://crabby-images/b72c1/b72c18513812b0e87bac120d90d9f258843175ba" alt=""
data:image/s3,"s3://crabby-images/6f18a/6f18a55806fe8bec23ae115f2a87dc3a99535cd4" alt=""
3D Fractal Tree
Adding a third dimension to the 2D tree and additional parameters for control of several aspects.
data:image/s3,"s3://crabby-images/ee22d/ee22da701c1d0a34849d7f13d3a30928395958d9" alt=""
Adding a color and polywire node at the output of the 3D fractal tree to colorize the lines and add volume.