about summary refs log tree commit diff homepage
path: root/utils/hacks/TreeGraphs/Graphics/Geometry/vec3.py
blob: 5235f84417378d76766142b168f4c2fa8261ace0 (plain) (blame)
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
60
61
62
63
64
# ===-- vec3.py -----------------------------------------------------------===##
# 
#                      The KLEE Symbolic Virtual Machine
# 
#  This file is distributed under the University of Illinois Open Source
#  License. See LICENSE.TXT for details.
# 
# ===----------------------------------------------------------------------===##

from __future__ import division
from math import ceil,floor,sqrt
from random import random as _random
_min,_max= min,max

def random():
	return (_random()*2-1,_random()*2-1,_random()*2-1)

def inv(a):	return (-a[0],-a[1],-a[2])

def add(a,b):	return (a[0]+b[0], a[1]+b[1], a[2]+b[2])
def sub(a,b):	return (a[0]-b[0], a[1]-b[1], a[2]-b[2])
def mul(a,b):	return (a[0]*b[0], a[1]*b[1], a[2]*b[2])
def div(a,b):	return (a[0]/b[0], a[1]/b[1], a[2]/b[2])
def mod(a,b):	return (a[0]%b[0], a[1]%b[1], a[2]%b[2])
def dot(a,b):	return (a[0]*b[0]+ a[1]*b[1]+ a[2]*b[2])

def addN(a,n):	return (a[0]+n, a[1]+n, a[2]+n)
def subN(a,n):	return (a[0]-n, a[1]-n, a[2]-n)
def mulN(a,n):	return (a[0]*n, a[1]*n, a[2]*n)
def modN(a,n):	return (a[0]%n, a[1]%n, a[2]%n)
def divN(a,n):	return (a[0]/n, a[1]/n, a[2]/n)

def sqr(a):			return dot(a,a)
def length(a):		return sqrt(sqr(a))
def normalize(a):	return mulN(a, 1.0/length(a))
def avg(a,b):		return mulN(add(a,b),0.5)
def distance(a,b):	return length(sub(a,b))

def cross(a, b):
	return (a[1]*b[2] - a[2]*b[1],
			a[2]*b[0] - a[0]*b[2],
			a[0]*b[1] - a[1]*b[0])
def reflect(a, b):
	return sub(mulN(b, dot(a, b)*2), a)

def lerp(a,b,t):
	return add(mulN(a,1.0-t), mulN(b, t))

def min((a0,a1,a2),(b0,b1,b2)):
	return (_min(a0,b0),_min(a1,b1),_min(a2,b2))
def max((a0,a1,a2),(b0,b1,b2)):
	return (_max(a0,b0),_max(a1,b1),_max(a2,b2))

def toint(a):
	return (int(a[0]), int(a[1]), int(a[2]))
def tofloor(a):
	return (floor(a[0]), floor(a[1]), floor(a[2]))
def toceil(a):
	return (ceil(a[0]), ceil(a[1]), ceil(a[2]))

def sumlist(l):
	return reduce(add, l)
def avglist(l):
	return mulN(sumlist(l), 1.0/len(l))