summaryrefslogtreecommitdiff
path: root/Examples/GIFPlot/Common-Lisp/full/runme.lisp
blob: 48f8042012af359ce51a6a0cec769a9f11c57239 (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
;;; Plot a 3D function

;; Here is the function to plot
(defun func (x y)
  (* 5
     (cos (* 2 (sqrt (+ (* x x) (* y y)))))
     (exp (* -0.3 (sqrt (+ (* x x) (* y y)))))))

;; Here are some plotting parameters
(defvar xmin -5D0)
(defvar xmax  5D0)
(defvar ymin -5D0)
(defvar ymax  5D0)
(defvar zmin -5D0)
(defvar zmax  5D0)

;; Grid resolution
(defvar nxpoints  60)
(defvar nypoints  60)

(defun drawsolid (p3)
  (Plot3D-clear p3 0)
  (Plot3D-start p3)
  (let ((dx (/ (- xmax xmin) nxpoints))
	(dy (/ (- ymax ymin) nypoints))
	(cscale (/ 240 (- zmax zmin))))
    (loop for x from xmin by dx
	  repeat nxpoints
	  do (loop for y from ymin by dy
		   repeat nypoints
		   do (let* ((z1 (func x y))
			     (z2 (func (+ x dx) y))
			     (z3 (func (+ x dx) (+ y dy)))
			     (z4 (func x (+ y dy)))
			     (c1 (* cscale (- z1 zmin)))
			     (c2 (* cscale (- z2 zmin)))
			     (c3 (* cscale (- z3 zmin)))
			     (c4 (* cscale (- z4 zmin)))
			     (cc (/ (+ c1 c2 c3 c4) 4))
			     (c  (round (max (min cc 239) 0))))
			(Plot3D-solidquad p3 x y z1 (+ x dx) y z2 (+ x dx) (+ y dy)
					  z3 x (+ y dy) z4 (+ c 16)))))))

(defun action (cmap-filename)
  (let ((cmap (new-ColorMap cmap-filename))
	(frame (new-FrameBuffer 500 500)))
    (format t "Making a nice 3D plot...~%")
    (FrameBuffer-clear frame 0)
    (let ((p3 (new-Plot3D frame xmin ymin zmin xmax ymax zmax)))
      (Plot3D-lookat p3 (* 2 (- zmax zmin)))
      (Plot3D-autoperspective p3 40D0)
      (Plot3D-rotu p3 60D0)
      (Plot3D-rotr p3 30D0)
      (Plot3D-rotd p3 10D0)
      (drawsolid p3))
    (FrameBuffer-writeGIF frame cmap "/tmp/image.gif")
    (format t "Wrote image.gif~%")))