mirror of https://github.com/python/cpython
55 lines
1012 B
Python
55 lines
1012 B
Python
# A simple vector class
|
|
|
|
|
|
def vec(*v):
|
|
return Vec(*v)
|
|
|
|
|
|
class Vec:
|
|
|
|
def __init__(self, *v):
|
|
self.v = list(v)
|
|
|
|
def fromlist(self, v):
|
|
if not isinstance(v, list):
|
|
raise TypeError
|
|
self.v = v[:]
|
|
return self
|
|
|
|
def __repr__(self):
|
|
return 'vec(' + repr(self.v)[1:-1] + ')'
|
|
|
|
def __len__(self):
|
|
return len(self.v)
|
|
|
|
def __getitem__(self, i):
|
|
return self.v[i]
|
|
|
|
def __add__(self, other):
|
|
# Element-wise addition
|
|
v = list(map(lambda x, y: x+y, self, other))
|
|
return Vec().fromlist(v)
|
|
|
|
def __sub__(self, other):
|
|
# Element-wise subtraction
|
|
v = list(map(lambda x, y: x-y, self, other))
|
|
return Vec().fromlist(v)
|
|
|
|
def __mul__(self, scalar):
|
|
# Multiply by scalar
|
|
v = [x*scalar for x in self.v]
|
|
return Vec().fromlist(v)
|
|
|
|
|
|
|
|
def test():
|
|
a = vec(1, 2, 3)
|
|
b = vec(3, 2, 1)
|
|
print(a)
|
|
print(b)
|
|
print(a+b)
|
|
print(a-b)
|
|
print(a*3.0)
|
|
|
|
test()
|