CHAPTER 6
Fractal Fold Variations
Trigonometric functions create folds.
Both the Mandelbrot fold figures and the Julia fold figures use pixel dimensions that are increased by 100 pixels in both the x-direction and the y-direction for each figure.
When the pixel dimension is increased, the number of folds also increases.
data:image/s3,"s3://crabby-images/f70fe/f70fed1f7c2192c25e452abd2c89e79b09ba3297" alt="fold.jpg"
data:image/s3,"s3://crabby-images/f2d6e/f2d6e7be425b7917e7cfd9d08b7dbbf68b1aedfa" alt="fold.jpg"
- Build: (x+sin(y*x*y)+xs, y+cos(x*x*y)-1.0+ys)
- Escape: x²+y² > (2.5+m/2.0)²/k
for (int m = 0; m ≤ 4; m++) { for (int i = 0; i ≤ 500+m*100; i++) { for (int j = 0; j ≤ 500+m*100; j++) { x = 0.0; y = 0.0; xs = -2.5 - m/2.0 + (i/100.0); ys = -2.5 - m/2.0 + (j/100.0); k = 0; do { xnew = x + sin(y*x*y) + xs; ynew = y + cos(x*x*y) - 1.0 + ys; x = xnew; y = ynew; k = k + 1; } while ((k ≤ kmax) && (x²+y² ≤ (2.5+m/2.0)²/k)); color = gray; if (x²+y² ≤ (2.5+m/2.0)²) color = blue; PlotPixel(i, j, color); PlotPoint(x, y, color); } } }See Appendix F for additional fold (Seashell) figures.
data:image/s3,"s3://crabby-images/73238/732384ac74239e565591d1266504a23817ecf317" alt="fold.jpg"
data:image/s3,"s3://crabby-images/2ad7f/2ad7fb8efe6a67533561d1a1e3c58262d7c04013" alt="fold.jpg"
data:image/s3,"s3://crabby-images/7fc22/7fc22f474f321fff8e0c9800ff6dec306a4e1772" alt="fold.jpg"
data:image/s3,"s3://crabby-images/6e720/6e720e7070a8fe7119a2f371de9c8fdf8a1d5f83" alt="fold.jpg"
data:image/s3,"s3://crabby-images/571f9/571f9bdac17e454ce82a7bff947b36fe82ad1812" alt="fold.jpg"
data:image/s3,"s3://crabby-images/798c3/798c3936b548f4646f769dde2f46653e140f0f97" alt="fold.jpg"
- Build: (x+sin(y*x*y)+xs, y+cos(x*x*y)-1.0+ys, (0.0, 0.0))
- Escape: x²+y² > (2.5+m/2.0)²/k
for (int m = 0; m ≤ 4; m++) { for (int i = 0; i ≤ 500+m*100; i++) { for (int j = 0; j ≤ 500+m*100; j++) { xs = 0.0; ys = 0.0; x = -2.5 - m/2.0 + (i/100.0); y = -2.5 - m/2.0 + (j/100.0); k = 0; do { xnew = x + sin(y*x*y) + xs; ynew = y + cos(x*x*y) - 1.0 + ys; x = xnew; y = ynew; k = k + 1; } while ((k ≤ kmax) && (x²+y² ≤ (2.5+m/2.0)²/k)); color = gray; if (x²+y² ≤ (2.5+m/2.0)²) color = blue; PlotPixel(i, j, color); PlotPoint(x, y, color); } } }
data:image/s3,"s3://crabby-images/99a5f/99a5fdbe94b52265b3222b41c56d455c7d4bf0c5" alt="fold.jpg"
data:image/s3,"s3://crabby-images/2a63b/2a63bab659f027d9cfcc6a0b189e8a902ca18a9f" alt="fold.jpg"
data:image/s3,"s3://crabby-images/67373/673734a24fee7c76e0252cbbd636b3841c90d2aa" alt="fold.jpg"
data:image/s3,"s3://crabby-images/2a83b/2a83bf6ca61f14a44c78209b104fd0fb11b67123" alt="fold.jpg"