A bare-bones mandelbrot and buddhabrot renderer.
Find a file
2020-12-14 18:31:54 +01:00
src fix usage option name for max_iter 2020-12-14 18:25:03 +01:00
.gitignore add ppm files to gitignore 2020-11-26 15:16:34 +01:00
LICENSE add MIT license 2020-12-12 15:30:33 +01:00
meson.build add buddhabrot calculation 2020-11-26 15:16:34 +01:00
README.md add basic README 2020-12-14 18:31:54 +01:00

Buddhabrot

This is a very simple binary to create images of the Mandelbrot set and Buddhabrot set. The final goal is to use the Metropolis-Hastings sampling algorithm and Simulated Annealing.

Building the project

You need Meson to build the project, and I recommend using Ninja as a build system. Issue the following commands:

42sh$ meson build
42sh$ ninja -C build

This compiles the buddhabrot binary at the root of the build directory.

Using the binary

By default, the binary writes the output image to its standard output, in the PPM file format.

You can choose which visualisation you want by using the -r options with either buddhabrot or mandelbrot. Use -m to choose the maximum number of iterated samples.

You can specify the height and width of the image by using -h and -w.

Sample usage:

42sh$ ./buddhabrot -r buddhabrot -o out.ppm  -m 1000 -h 1080 -w 1920

Creating images

The binary outputs a grayscale image of the buddhabrot for the given sampling rate.

The project's logo has been created by outputting three different buddhabrot sets for 100, 1000, and 10000 samples. Once done, use the following command to create the image (using ImageMagick).

42sh$ convert \
    10000.ppm -channel R \
    1000.ppm -channel G \
    100.ppm -channel B \
    -combine -channel RGB \
    -alpha off -colorspace sRGB \
    out.png