blob: 0a56ddbe1fe83c7a0938e630248ff9fcb12d6264 [file] [log] [blame]
Guido van Rossume8769491992-08-13 12:14:11 +00001# A simple vector class
2
3
4def vec(*v):
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +00005 return apply(Vec, v)
Guido van Rossume8769491992-08-13 12:14:11 +00006
7
8class Vec:
9
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000010 def __init__(self, *v):
11 self.v = []
12 for x in v:
13 self.v.append(x)
Guido van Rossume8769491992-08-13 12:14:11 +000014
15
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000016 def fromlist(self, v):
17 self.v = []
18 if type(v) <> type([]):
19 raise TypeError
20 self.v = v[:]
21 return self
Guido van Rossume8769491992-08-13 12:14:11 +000022
23
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000024 def __repr__(self):
25 return 'vec(' + `self.v`[1:-1] + ')'
Guido van Rossume8769491992-08-13 12:14:11 +000026
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000027 def __len__(self):
28 return len(self.v)
Guido van Rossume8769491992-08-13 12:14:11 +000029
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000030 def __getitem__(self, i):
31 return self.v[i]
Guido van Rossume8769491992-08-13 12:14:11 +000032
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000033 def __add__(a, b):
34 # Element-wise addition
35 v = []
36 for i in range(len(a)):
37 v.append(a[i] + b[i])
38 return Vec().fromlist(v)
Guido van Rossume8769491992-08-13 12:14:11 +000039
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000040 def __sub__(a, b):
41 # Element-wise subtraction
42 v = []
43 for i in range(len(a)):
44 v.append(a[i] - b[i])
45 return Vec().fromlist(v)
Guido van Rossume8769491992-08-13 12:14:11 +000046
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000047 def __mul__(self, scalar):
48 # Multiply by scalar
49 v = []
50 for i in range(len(self.v)):
51 v.append(self.v[i]*scalar)
52 return Vec().fromlist(v)
Guido van Rossume8769491992-08-13 12:14:11 +000053
54
55
56def test():
Andrew M. Kuchling946c53e2003-04-24 17:13:18 +000057 a = vec(1, 2, 3)
58 b = vec(3, 2, 1)
59 print a
60 print b
61 print a+b
62 print a*3.0
Guido van Rossume8769491992-08-13 12:14:11 +000063
64test()