That should be enough to get you started. This plot includes Julia set in ascii. If you want to build the mandelbrot collection instead, go to c instead of z.
#include <stdio.h>
typedef struct tag_complex
{
double real, imag;
} complex;
static complex complex_mul(
const complex* a,
const complex* b)
{
complex ret;
ret.real = a->real*b->real - a->imag*b->imag;
ret.imag = a->real*b->imag + a->imag*b->real;
return ret;
}
static complex complex_add(
const complex* a,
const complex* b)
{
complex ret;
ret.real = a->real + b->real;
ret.imag = a->imag + b->imag;
return ret;
}
static int julia(
complex* z,
const complex* c,
int maxIter)
{
double lengthSquared;
int iter = 0;
while(iter < maxIter){
++iter;
*z = complex_mul(z, z);
*z = complex_add(z, c);
lengthSquared = z->real*z->real + z->imag*z->imag;
if(lengthSquared > 4.0)
return iter;
}
return 0;
}
int main(int argc, char* argv[])
{
const int width = 80;
const int height = 40;
const int maxIter = 512;
const double step_height = 4.0 / (double)height;
const double step_width = 4.0 / (double)width;
const complex c = {0.285, 0.0};
complex z;
int index;
char ch;
for(int j=0; j<height; ++j){
for(int i=0; i<width; ++i){
z.imag = ((double)j * step_height) - 2.0;
z.real = ((double)i * step_width) - 2.0;
index = julia(&z, &c, maxIter);
ch = (index % ('Z' - ' ')) + ' ';
printf("%c", ch);
}
printf("\n");
fflush(stdout);
}
}
Mads elvheim
source
share