English 中文(简体)
Coding self similar fractals in computer graphics using C
原标题:

Can anyone help me with the programming code for self similar fractals in computer graphics using c language?

问题回答

This should be enough to get you started. This plots a julia set in ascii. If you want to plot the mandelbrot set instead, iterate over 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)
{
  /*   a * b = (a_real + i*a_imag)(b_real + i*b_imag) */
  /* i*i = -1, hence imag*imag becomes -(imag*imag) */     
  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 the point escapes the radius 2
       in the complex plane, it s in the set */
    if(lengthSquared > 4.0)
      return iter;
  }
  /* Point didn t escape. Either it s not in the set,
     or we need more iterations.*/
  return 0;
}

int main(int argc, char* argv[])
{
  const int width = 80;
  const int height = 40;
  const int maxIter = 512;

  /* step in the range [0, 4] since the set
     lives within [-2, 2] in the complex space */
  const double step_height = 4.0 / (double)height;
  const double step_width = 4.0 / (double)width;

  /*c is constant for julia sets. z is iterated over */
  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){
      /* Get interpolants within [-2, 2] range */
      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("
");
    fflush(stdout);
  }
}




相关问题
Fastest method for running a binary search on a file in C?

For example, let s say I want to find a particular word or number in a file. The contents are in sorted order (obviously). Since I want to run a binary search on the file, it seems like a real waste ...

Print possible strings created from a Number

Given a 10 digit Telephone Number, we have to print all possible strings created from that. The mapping of the numbers is the one as exactly on a phone s keypad. i.e. for 1,0-> No Letter for 2->...

Tips for debugging a made-for-linux application on windows?

I m trying to find the source of a bug I have found in an open-source application. I have managed to get a build up and running on my Windows machine, but I m having trouble finding the spot in the ...

Trying to split by two delimiters and it doesn t work - C

I wrote below code to readin line by line from stdin ex. city=Boston;city=New York;city=Chicago and then split each line by ; delimiter and print each record. Then in yet another loop I try to ...

Good, free, easy-to-use C graphics libraries? [closed]

I was wondering if there were any good free graphics libraries for C that are easy to use? It s for plotting 2d and 3d graphs and then saving to a file. It s on a Linux system and there s no gnuplot ...

Encoding, decoding an integer to a char array

Please note that this is not homework and i did search before starting this new thread. I got Store an int in a char array? I was looking for an answer but didn t get any satisfactory answer in the ...

热门标签