aboutsummaryrefslogtreecommitdiff
path: root/examples/mandelbrot.sloth
diff options
context:
space:
mode:
authornic-gaffney <gaffney_nic@protonmail.com>2023-09-30 00:18:27 -0500
committernic-gaffney <gaffney_nic@protonmail.com>2023-09-30 00:18:27 -0500
commitc748aedbc265fdc7d62768d368161a1f1d88b9a4 (patch)
tree2371ae4c1ce98e72c9e414f0e4176c3d8bf35778 /examples/mandelbrot.sloth
parent84c77656e1d5f0414050d8a2dae6c86b022bf125 (diff)
downloadsloth-c748aedbc265fdc7d62768d368161a1f1d88b9a4.tar.gz
spacing
Diffstat (limited to 'examples/mandelbrot.sloth')
-rw-r--r--examples/mandelbrot.sloth55
1 files changed, 28 insertions, 27 deletions
diff --git a/examples/mandelbrot.sloth b/examples/mandelbrot.sloth
index 275d32b..09286bd 100644
--- a/examples/mandelbrot.sloth
+++ b/examples/mandelbrot.sloth
@@ -1,3 +1,26 @@
+fn printMan(size: Float, maxVal: Float, maxIter: Float, plane: Float, x: Int, y: Int)
+{
+ var cReal = (as_float(x) * plane / size) - 2.0;
+ var cImg = (as_float(y) * plane / size) - 2.0;
+ var zReal = 0.0;
+ var zImg = 0.0;
+ var count = 0.0;
+
+ # Calculate
+ while (zReal * zReal + zImg * zImg) <= maxVal && count < maxIter {
+ var temp = (zReal * zReal) - (zImg * zImg) + cReal;
+ zImg = 2.0 * zReal * zImg + cImg;
+ zReal = temp;
+ count = count + 1.0;
+
+ # Check
+ if as_int(count) == as_int(maxIter) {
+ termpos(x, y);
+ print("█");
+ }
+ }
+}
+
fn main() Int {
# Configure
var size = 1000.0;
@@ -6,35 +29,13 @@ fn main() Int {
var plane = 4.0;
# loop over coordinates
- var x = 0.0;
- while x < size {
- var y = 0.0;
- while y < size {
- # Initialize
- var cReal = (x * plane / size) - 2.0;
- var cImg = (y * plane / size) - 2.0;
- var zReal = 0.0;
- var zImg = 0.0;
- var count = 0.0;
-
- # Calculate
- while (zReal * zReal + zImg * zImg) <= maxVal && count < maxIter {
- var temp = (zReal * zReal) - (zImg * zImg) + cReal;
- zImg = 2.0 * zReal * zImg + cImg;
- zReal = temp;
- count = count + 1.0;
- }
- # Check
- if as_int(count) == as_int(maxIter) {
- termpos(as_int(x), as_int(y));
- print("█");
- }
-
- y = y + 1.0;
+ for x in 0..as_int(size) {
+ for y in 0..as_int(size) {
+ # Initialize
+ printMan(size, maxVal, maxIter, plane, x, y);
}
- x = x + 1.0;
+
}
return 0;
}
-