12,623,511 members (31,343 online)
alternative version

113.8K views
161 bookmarked
Posted

# The beauty of fractals - A simple fractal rendering program done in C#

, 27 Jul 2009 CPOL
 Rate this:
A fractal rendering application demonstrating many .NET programming techniques.

## Introduction

I have written many fractal applications in my life. Starting on the C64, on the Amiga, on the PC, using different languages (even on a TI calculator in BASIC). Rendering fractals is a good practice when learning programming. Last week, I spent some time writing a simple fractal engine in C#. The purpose was to pack many of the programming techniques I was using during the last years into one application. In this application, you will find many interesting topics covered like:

• General C# programming
• MDI applications done in .NET
• Usage of interface classes in C#
• Use of delegate functions
• Asynchronous calculations
• Making use of multiple CPU cores
• Bilinear filtering of bitmaps
• Complex number class done in C#
• Mathematic background of Mandelbrot, Julia, and Newton fractals
• and many more ...

## Background

I have been fascinated by fractals ever since I was a kid. I can remember the first Mandelbrot engines on the commodore 64. Again and again, I am fascinated by the beauty of the outcome of such simple algorithms:

A Newton fractal

The Mandelbrot fractal from a bird's eye view

The Julia fractal

A Mandelbrot fractal without and with 'exact' rendering

Exact rendering means that the number of iteration steps is not interpreted as `int` but as `double`, and the color used to represent the result is interpolated between the previous and the next color in the palette. Using exact rendering does not need much more CPU power, but greatly improves the quality of the outcome.

Somewhere inside the Mandelbrot fractal

## The code

I don't want to put any code snippets here. Just open the solution and have a look into it. I think the code is very simple and clear, everything should be self-explanatory. I think it will be a good tutorial for beginners going through the code. You will find many things here that took me a long time to learn ;-)

There is one interface class `IFractal` from which a base fractal class will be derived. From this base fractal class, the Mandelbrot, Julia, and Newton fractals are derived.

You have an MDI container and a general MDI child form that can handle displaying dragging and zooming of fractals. You can drag a rectangle with the left mouse button pressed to zoom into a fractal. You can move the mouse with the right button pressed to scroll the fractal around. You can move the mouse with the middle parameter pressed, to change the control point used for the Julia fractal.

Fractals can be stored to and loaded from XML files. Fractal renderings can be stored as PNG files.

The engine renders at decent speed. It detects the number of available CPU cores and creates one rendering thread for each. The time needed to render a fractal nearly halves when going from a single core to a dual core machine. On my dual core Notebook, rendering a bird's eye Mandelbrot fractal with 2000x2000 pixels and 256 iterations per pixel takes approximately 650 ms, which is an acceptable speed.

This program is far from being finished, and probably will never be, due to lack of time. But, it is already capable of doing very beautiful fractal renderings. And, it shows how simple things can be done in C#. I remember doing the same in C++ some years ago, and it was a lot more work.

## Next steps ...

There are some things that I want to implement in the near future, for the next release (I hope I will find the time):

• A screensaver generating random fractals.
• A fractal movie renderer.
• Handle dynamic palette sizes up to an unlimited amount of colors. Right now, the palette is fixed to 256 colors, though the palette form can display an arbitrary amount of colors.

If you have any good suggestions, just post them here.

## History

• 27.07.2009: Initial version.

## Share

 Software Developer (Senior) Austria
I have started programming at the age of 13 on the commodore 64.

Ever since then I have been programming on many systems in many languages.

During the last 12 years I have been working as professional programmer in different companies and different areas.

Now I am working as freelancer programmer / consultant

## You may also be interested in...

 Pro

 First PrevNext
 xc and yc not are in settings Member 1127527530-Nov-14 9:53 Member 11275275 30-Nov-14 9:53
 Can't open the code ganesh19962-Jul-13 0:32 ganesh1996 2-Jul-13 0:32
 My vote of 4 Member 327776020-Sep-12 5:14 Member 3277760 20-Sep-12 5:14
 My vote of 5 yumeng.liu12-Jul-12 19:32 yumeng.liu 12-Jul-12 19:32
 My vote of 5 conmajia8-Jul-12 1:45 conmajia 8-Jul-12 1:45
 My vote of 5 descartes18-Jun-12 23:59 descartes 18-Jun-12 23:59
 My vote of 2 Guillaume Waser21-May-12 2:08 Guillaume Waser 21-May-12 2:08
 My vote of 5 Sergio Andrés Gutiérrez Rojas30-Mar-12 8:49 Sergio Andrés Gutiérrez Rojas 30-Mar-12 8:49
 My vote of 5 Akram El Assas22-Feb-12 13:25 Akram El Assas 22-Feb-12 13:25
 My vote of 5 Member 337837323-Jun-11 10:38 Member 3378373 23-Jun-11 10:38
 My vote of 5 FIRMANSYAH.MS6-May-11 10:51 FIRMANSYAH.MS 6-May-11 10:51
 My vote of 5 Sauruxum27-Jan-11 0:05 Sauruxum 27-Jan-11 0:05
 My vote of 5 dim13122-Jan-11 1:43 dim131 22-Jan-11 1:43
 awesome JFergulbops10-Oct-10 23:58 JFergulbops 10-Oct-10 23:58
 My vote of 3 Left of Zen6-Oct-10 1:21 Left of Zen 6-Oct-10 1:21
 Comments Left of Zen5-Oct-10 23:53 Left of Zen 5-Oct-10 23:53
 Nice CIDev1-Oct-10 7:16 CIDev 1-Oct-10 7:16
 Nice little article and well written code. Just because the code works, it doesn't mean that it is good code.
 My vote of 5 velkanzi2-Aug-10 17:52 velkanzi 2-Aug-10 17:52
 My vote of 5 jack48822-Jul-10 11:58 jack488 22-Jul-10 11:58
 Really Nice KenJohnson17-Jul-10 21:15 KenJohnson 17-Jul-10 21:15
 My vote of 5 Mohsen Kazemi1-Jul-10 11:15 Mohsen Kazemi 1-Jul-10 11:15
 Thank you very much tianweiCn15-Sep-09 16:43 tianweiCn 15-Sep-09 16:43
 Cool thbernt4-Sep-09 1:59 thbernt 4-Sep-09 1:59
 Last Visit: 31-Dec-99 19:00     Last Update: 4-Dec-16 2:43 Refresh 12 Next »

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Web02 | 2.8.161128.1 | Last Updated 27 Jul 2009
Article Copyright 2009 by Zimmermann Stephan