summaryrefslogtreecommitdiffstats
path: root/Demo
diff options
context:
space:
mode:
authorAlexander Belopolsky <alexander.belopolsky@gmail.com>2010-07-05 21:44:05 (GMT)
committerAlexander Belopolsky <alexander.belopolsky@gmail.com>2010-07-05 21:44:05 (GMT)
commit31c2740760329ff49813231e2f5e7df4ea8cfcc4 (patch)
treea7747a011ade906d8252143cb2f789e7c4e80ea5 /Demo
parent1f1ccc038641533312a1e55964ff2e0e16861dd9 (diff)
downloadcpython-31c2740760329ff49813231e2f5e7df4ea8cfcc4.zip
cpython-31c2740760329ff49813231e2f5e7df4ea8cfcc4.tar.gz
cpython-31c2740760329ff49813231e2f5e7df4ea8cfcc4.tar.bz2
"Modernized" the demo a little.
Diffstat (limited to 'Demo')
-rw-r--r--Demo/classes/Vec.py42
1 files changed, 28 insertions, 14 deletions
diff --git a/Demo/classes/Vec.py b/Demo/classes/Vec.py
index 7e3e3ae..787af69 100644
--- a/Demo/classes/Vec.py
+++ b/Demo/classes/Vec.py
@@ -1,10 +1,27 @@
-# A simple vector class
+class Vec:
+ """ A simple vector class
-import operator
+ Instances of the Vec class can be constructed from numbers
+ >>> a = Vec(1, 2, 3)
+ >>> b = Vec(3, 2, 1)
-class Vec:
+ added
+ >>> a + b
+ Vec(4, 4, 4)
+
+ subtracted
+ >>> a - b
+ Vec(-2, 0, 2)
+
+ and multiplied by a scalar on the left
+ >>> 3.0 * a
+ Vec(3.0, 6.0, 9.0)
+ or on the right
+ >>> a * 3.0
+ Vec(3.0, 6.0, 9.0)
+ """
def __init__(self, *v):
self.v = list(v)
@@ -17,7 +34,8 @@ class Vec:
return inst
def __repr__(self):
- return 'Vec(' + repr(self.v)[1:-1] + ')'
+ args = ', '.join(repr(x) for x in self.v)
+ return 'Vec({})'.format(args)
def __len__(self):
return len(self.v)
@@ -27,28 +45,24 @@ class Vec:
def __add__(self, other):
# Element-wise addition
- v = list(map(operator.add, self, other))
+ v = [x + y for x, y in zip(self.v, other.v)]
return Vec.fromlist(v)
def __sub__(self, other):
# Element-wise subtraction
- v = list(map(operator.sub, self, other))
+ v = [x - y for x, y in zip(self.v, other.v)]
return Vec.fromlist(v)
def __mul__(self, scalar):
# Multiply by scalar
- v = [x*scalar for x in self.v]
+ v = [x * scalar for x in self.v]
return Vec.fromlist(v)
+ __rmul__ = __mul__
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)
+ import doctest
+ doctest.testmod()
test()