summaryrefslogtreecommitdiff
path: root/examples/mandelbrot.lali
blob: c07b07dbd2feb6ac11a71f4a65aa783d9565cf92 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
(defun for (from to func)
  (cond ((< from to) (func from) (for (+ from +1) to func))))

(set 'mandelbrot-chars
  (list " " "." "," "`" "'" "\"" ":" ";" "-" "+" "o" "O" "0" "1"
        "2" "3" "4" "5" "6" "7" "8" "9" "%" "*" "&" "$" "@" "#"))

(defun mandelbrot-iter (x y x0 y0 i)
  (fill ((dif i +28) " ")
        ((not (> (+ (* x0 x0) (* y0 y0)) +4)) (nth i mandelbrot-chars))
        (f (mandelbrot-iter x y
                            (+ (- (* x0 x0) (* y0 y0)) x) (+ (* +2 x0 y0) y)
                            (+ i +1)))))

(defun mandelbrot-char (x y)
  (mandelbrot-iter x y
                   (+ (- (* x x) (* y y)) x) (+ (* +2 x y) y)
                   +0))

(defun mandelbrot (xmin xmax ymin ymax)
  (for +0 +24 (lambda (py)
    (for +0 +80 (lambda (px)
      (princ
        (mandelbrot-char
          (+ (* (/ px +80) (- xmax xmin)) xmin)
          (+ (* (/ py +24) (- ymax ymin)) ymin)))))
    (newline))))

(mandelbrot -2.15 +1.25 -1.25 +1.25)
; (mandelbrot -1.5 -1.1 -0.2 +0.1)