Mandelbrot

Code available at GitHub

Visualisation of Mandelbrot calculations
ƒ (Z) = Z 2 + C
with possible variants in Z and C, using the mouse.

Variant 1

Working example can be viewed here

Have a look at this video.

Mandelbrot version 1
mandelbrot

Variant 2

Working example can be viewed here

Have a look at this video.

Mandelbrot version 2
mandelbrot

Variant 3

Working example can be viewed here

Have a look at this video.

Mandelbrot version 3
mandelbrot

Variant 4

Working example can be viewed here

This version was heavily optimised using a complete different way of drawing the pixels. This results in a dramatic boost in performance. First the step was made to create a palette only once, in stead of calculating the colors for every pixels. With a maximum number of iterations the palette only has 200 items which isn" a big deal memory-wise.
Second the way of drawing the pixels is changed: in stead of of drawing each pixel separately directly on the canvas, the pixels are first stored in an ImageData. Thanks to this Stack Overflow answer this works well.

The resulting performance boost can be viewed in this source-code image, enriched with data from the Javascript profiler.
Optimised code
Compare with old code:
Optimised code

The resulting code is so fast that even on a decent computer a live-preview of the zoombox is possible. This can be enabled using the checkbox on the right.

Mandelbrot version 4

Variant 5

Working example can be viewed here

And yet another fun Mandelbrot project.
Completely refactored the code to speed things up. Now it's possible to have a live preview in the zoombox.
The new method separates the calculations from the drawing, making it possible to swap the color palette without doing all the recalculations. So, now the slider for the palette immediately sends a request to calculate a new palette and immediately apply it to the current situation.
When zooming in the previous situation is stored in a history list. So, using the right mouse-button you can quickly go back to your previous situation, even preserving the palette.

Have a look at this video.

Mandelbrot version 5
mandelbrot

Variant 7

Working example can be viewed here

Lots of improvements

Have a look at this video.

Mandelbrot version 7
mandelbrot

Variant 8

Working example can be viewed here

Lots of improvements

Have a look at this video.

Mandelbrot version 8
mandelbrot

Variant 9

Working example can be viewed here

Added Julia Set fractal (large and preview)

Have a look at this video.

Mandelbrot version 9
mandelbrot

Variant 10

Working example can be viewed here

Reintroduced the iterator points and connector lines.

Have a look at this video.

Mandelbrot version 10
mandelbrot

Variant 11

Working example can be viewed here

Added RGB palette files from Fractint that can be loaded through the GUI.

Have a look at this video.

Mandelbrot version 11
mandelbrot