Skip to content

Latest commit

 

History

History
68 lines (63 loc) · 3.91 KB

README.md

File metadata and controls

68 lines (63 loc) · 3.91 KB

mndbrt

Repository for the Mandelbrot project.

Mandelbrot

M = {c ∈ ℂ | lim Z_n (n -> ∞) ≠ ∞}

  • Z_o = 0 + 0i
  • Z_(n+1) = (Z_n)^2 + c

Getting Started

This project generates an image of the Mandelbrot set given the viewing coordinates and an image size. The program can be compiled by using cmake and make in the build directory. The program "mndbrt" can be supplied with the image coordinates from the command line. The output is a bitmap of the Mandelbrot set that can be opened and exported by most media software. A sample of what the program can produce is provided below.

Coloring Schemes

Currently main uses the distance algorithm adapted from the corresponding website and chromatic uses the classic escapce algorithms with a polynomail and a non-linear variant. A brief introduction to the various coloring schemes is presented below.

  1. Classic Escape Algorithms
  • Based on number of iterations until the point escapes the orbit
    • Black and White:
      • Uses only two colors
      • First color is for points inside the orbit
      • Second color is for points that escape the orbit
    • Linear color function:
      • Uses a linear transformation to map iterations to a color
      • Typically maps the single interation value into a rgb triplet
      • Usally an interpolating function is used to produce a linear gradient
      • Easy to understand and implement
      • Produces unfavorable wide "bands" when the iteration count changes slowly at low iteration values
      • Produces unfavorable rapid short "bands" when the iteration count changes rapidly at high iteration values
    • Polynomial color function:
      • Uses a polynomial to map iterations to a color.
      • Typically maps the single interation value into a rgb triplet
      • Usally an aproximating function is used to produce a changing color gradient
      • Easy to understant and implement
      • More variation in colors and more interesting
      • Produces unfavorable wide "bands" when the iteration count changes slowly at low iteration values
      • Produces unfavorable rapid short "bands" when the iteration count changes rapidly at high iteration values
    • Non linear color function:
      • Uses a non linear function to map iterations to a color.
      • Typically maps the single interation value into a rgb triplet
      • Usally an aproximating function of an exp form is used to produce a changing color gradient
      • Easy to understant and implement
      • More variation in colors and more interesting
      • Reduces unfavorable wide "bands" when the iteration count changes slowly at low iteration values
      • Reduces unfavorable rapid short "bands" when the iteration count changes rapidly at high iteration values
      • The nature of a exp function allows for smaller iterations to change more rapidly and larger iterations to change more slowly
    • Smooth escape function:
      • Uses a normalized iteration function
      • Smooths the iteration count
      • Reduces harsh "banding"
      • Much more complicated
    • Histogram:
      • Uses a histogram of iterations
      • Applies a linear color map to the histogram values from smallest iteration to largest iteration
      • smooth
      • Slow and annoying to implement
  1. Distance Algorithm
  • Based on the distance from neighboring points
    • Distance estimator algorithm:
      • Uses the derivative of the iteration function to produce the distance between dwell bands
      • Maps both the iteration and distance to a HB or HSB if the angle is calculated
      • More complicated
      • Much more visually pleasing
      • Utilizes hue saturation and brightness which feels more balanced
      • Better at displaying the filaments
      • This algorithm borrows ideas from this website