summaryrefslogtreecommitdiffstats
path: root/Demo
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2010-07-27 08:45:35 (GMT)
committerGeorg Brandl <georg@python.org>2010-07-27 08:45:35 (GMT)
commit406f7a99fd91e2b530a60a76d41179a57e1560cd (patch)
tree297f986e3b175834ba8ae36c40c70a108726c44c /Demo
parent3cef1de27df245a3799e178561dfe27dad0fbeb4 (diff)
downloadcpython-406f7a99fd91e2b530a60a76d41179a57e1560cd.zip
cpython-406f7a99fd91e2b530a60a76d41179a57e1560cd.tar.gz
cpython-406f7a99fd91e2b530a60a76d41179a57e1560cd.tar.bz2
Merged revisions 82594,82599 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r82594 | georg.brandl | 2010-07-05 22:13:41 +0200 (Mo, 05 Jul 2010) | 1 line Update Vec class constructor, remove indirection via function, use operator module. ........ r82599 | alexander.belopolsky | 2010-07-05 23:44:05 +0200 (Mo, 05 Jul 2010) | 1 line "Modernized" the demo a little. ........
Diffstat (limited to 'Demo')
-rw-r--r--Demo/classes/Vec.py56
1 files changed, 35 insertions, 21 deletions
diff --git a/Demo/classes/Vec.py b/Demo/classes/Vec.py
index 56cb839..b8771ea 100644
--- a/Demo/classes/Vec.py
+++ b/Demo/classes/Vec.py
@@ -1,23 +1,41 @@
-# A simple vector class
+class Vec:
+ """ A simple vector class
+ Instances of the Vec class can be constructed from numbers
-def vec(*v):
- return Vec(*v)
+ >>> a = Vec(1, 2, 3)
+ >>> b = Vec(3, 2, 1)
+ added
+ >>> a + b
+ Vec(4, 4, 4)
-class Vec:
+ 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)
- def fromlist(self, v):
+ @classmethod
+ def fromlist(cls, v):
if not isinstance(v, list):
raise TypeError
- self.v = v[:]
- return self
+ inst = cls()
+ inst.v = v
+ return inst
def __repr__(self):
- return 'vec(' + repr(self.v)[1:-1] + ')'
+ args = ', '.join(repr(x) for x in self.v)
+ return 'Vec({0})'.format(args)
def __len__(self):
return len(self.v)
@@ -27,28 +45,24 @@ class Vec:
def __add__(self, other):
# Element-wise addition
- v = map(lambda x, y: x+y, self, other)
- return Vec().fromlist(v)
+ v = [x + y for x, y in zip(self.v, other.v)]
+ return Vec.fromlist(v)
def __sub__(self, other):
# Element-wise subtraction
- v = map(lambda x, y: x-y, self, other)
- return Vec().fromlist(v)
+ v = [x - y for x, y in zip(self.v, other.v)]
+ return Vec.fromlist(v)
def __mul__(self, scalar):
# Multiply by scalar
- v = map(lambda x: x*scalar, self.v)
- return Vec().fromlist(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()