Multibrot set


[Image:Multibrot.ogv|thumb|right|256px|Multibrot exponent 0 - 8]
In mathematics, a Multibrot set is the set of values in the complex plane whose absolute value remains below some finite value throughout iterations by a member of the general monic univariate polynomial family of recursions. The name is a portmanteau of multiple and Mandelbrot set. The same can be applied to the Julia set, this being called Multijulia set.
where d ≥ 2. The exponent d may be further generalized to negative and fractional values.

Examples

Sources:
The case of
is the classic Mandelbrot set from which the name is derived.
The sets for other values of d also show fractal images when they are plotted on the complex plane.
Each of the examples of various powers d shown below is plotted to the same scale. Values of c belonging to the set are black. Values of c that have unbounded value under recursion, and thus do not belong in the set, are plotted in different colours, that show as contours, depending on the number of recursions that caused a value to exceed a fixed magnitude in the Escape Time algorithm.

Positive powers

The example is the original Mandelbrot set. The examples for are often called multibrot sets. These sets include the origin and have fractal perimeters, with rotational symmetry.

Negative powers

When d is negative the set appears to surround but does not include the origin, However this is just an artifact of the fixed maximum radius allowed by the Escape Time algorithm, and is not a limit of the sets that actually have a shape in the middle with an no hole. There is interesting complex behaviour in the contours between the set and the origin, in a star-shaped area with rotational symmetry. The sets appear to have a circular perimeter, however this is an artifact of the fixed maximum radius allowed by the Escape Time algorithm, and is not a limit of the sets that actually extend in all directions to infinity.

Rendering along the exponent

An alternative method is to render the exponent along the vertical axis. This requires either fixing the real or the imaginary value, and rendering the remaining value along the horizontal axis. The resulting set rises vertically from the origin in a narrow column to infinity. Magnification reveals increasing complexity. The first prominent bump or spike is seen at an exponent of 2, the location of the traditional Mandelbrot set at its cross-section. The third image here renders on a plane that is fixed at a 45-degree angle between the real and imaginary axes.

Rendering images

All the above images are rendered using an Escape Time algorithm that identifies points outside the set in a simple way. Much greater fractal detail is revealed by plotting the Lyapunov exponent, as shown by the example below. The Lyapunov exponent is the error growth-rate of a given sequence. First calculate the iteration sequence with N iterations, then calculate the exponent as
and if the exponent is negative the sequence is stable. The white pixels in the picture are the parameters c for which the exponent is positive aka unstable. The colours show the periods of the cycles which the orbits are attracted to. All points colored dark-blue are attracted by a fixed point, all points in the middle are attracted by a period 2 cycle and so on.
[Image:Power-2pe.png|thumb|200px|Enlarged first quadrant of the multibrot set for the iteration z rendered with the Escape Time algorithm]
[Image:Multibrot Lupanov power-2 Q1.png|thumb|200px|Enlarged first quadrant of the multibrot set for the iteration z rendered using the Lyapunov exponent of the sequence as a stability criterion rather than using the Escape Time algorithm. Periodicity checking was used to colour the set according to the period of the cycles of the orbits.]

Pseudocode

ESCAPE TIME ALGORITHM
for each pixel on the screen do
x = x0 = x co-ordinate of pixel
y = y0 = y co-ordinate of pixel

iteration := 0
max_iteration := 1000

while 'and iteration < max_iteration do
/* INSERT CODEFOR Z^d FROM TABLE BELOW */
iteration := iteration + 1

if iteration = max_iteration then
colour := black
else'

colour := iteration

plot
The complex value z has coordinates on the complex plane and is raised to various powers inside the iteration loop by codes shown in this table. Powers not shown in the table can be obtained by concatenating the codes shown.
z−2z−1z2
z3z5zn
d=x^4+2*x^2*y^2+y^4
assert d != 0
xtmp = /d+a
y = -2*x*y/d+b
x = xtmp
d=x^2+y^2
assert d != 0
x = x/d + a
y= -y/d + b
xtmp=x^2-y^2 + a
y=2*x*y + b
x=xtmp
xtmp=x^3-3*x*y^2 + a
y=3*x^2*y-y^3 + b
x=xtmp
xtmp=x^5-10*x^3*y^2+5*x*y^4 + a
y=5*x^4*y-10*x^2*y^3+y^5 + b
x=xtmp
xtmp=^*cos + a
y=^*sin + b
x=xtmp