-
Notifications
You must be signed in to change notification settings - Fork 0
/
utilities.lisp~
52 lines (39 loc) · 1.14 KB
/
utilities.lisp~
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
(defun sq (x) (* x x))
(defun mag (&rest lst)
(sqrt (apply #'+ (mapcar #'sq lst))))
(defun list-copies (thing n)
(if (= n 0)
nil
(cons thing (list-copies thing (- n 1)))))
(defun vdif (v1 v2)
(mapcar #'- v1 v2))
(defun vdot (v1 v2)
(apply #'+ (mapcar #'* v1 v2)))
(defmacro v+ (&rest list-of-vecs)
`(mapcar #'+ @list-of-vecs))
(defun vs* (s v)
(mapcar #'* v (list-copies s (length v))))
(defun unitize (v)
(vs* (/ 1 (mag v)) v))
(defun vcross (x y)
(list
(- (* (nth 2 x) (nth 1 y)) (* (nth 1 x) (nth 2 y)))
(- (* (nth 0 x) (nth 2 y)) (* (nth 2 x) (nth 0 y)))
(- (* (nth 0 x) (nth 1 y)) (* (nth 1 x) (nth 0 y)))))
(defun random-elt (choices)
"Choose an element from a list at random."
(elt choices (random (length choices))))
(defun average (&rest lst)
(/ (apply #'+ lst) (length lst)))
(defun vdistance (v1 v2)
(mag (vdif v1 v2)))
(defun minroot (a b c)
(if (zerop a)
(/ (- c) b)
(let ((disc (- (sq b) (* 4 a c))))
(unless (minusp disc)
(let ((discrt (sqrt disc)))
(min (/ (+ (- b) discrt) (* 2 a))
(/ (- (- b) discrt) (* 2 a))))))))
(defmacro mand (macro-args)
`(and ,@macro-args))