fraction.py

Tue, 02 Feb 2016 20:47:47 +0200

author
Teemu Piippo <crimsondusk64@gmail.com>
date
Tue, 02 Feb 2016 20:47:47 +0200
changeset 167
032c90f1727b
parent 164
e18f73e4c2e2
permissions
-rw-r--r--

Stuff

164
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
1 def gcd(a, b):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
2 """
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
3 Calculate the Greatest Common Divisor of a and b.
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
4
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
5 Unless b==0, the result will have the same sign as b (so that when
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
6 b is divided by it, the result comes out positive).
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
7 """
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
8 while b:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
9 a, b = b, a % b
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
10 return a
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
11
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
12 class Fraction (object):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
13 def __init__ (self, numerator, denominator = 1):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
14 if denominator == 0:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
15 raise ValueError ('Denominator may not be 0')
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
16
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
17 self.numerator = int (numerator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
18 self.denominator = int (denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
19 self.simplify()
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
20
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
21 @property
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
22 def real (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
23 if self.numerator.real:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
24 return Fraction(self.numerator.real, self.denominator.real)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
25 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
26 return Fraction(0,1)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
27
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
28 @property
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
29 def imag (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
30 if self.numerator.imag:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
31 return Fraction(self.numerator.imag, self.denominator.imag)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
32 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
33 return Fraction(0,1)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
34
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
35 def simplify (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
36 divisor = gcd (self.numerator, self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
37 self.numerator //= divisor
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
38 self.denominator //= divisor
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
39
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
40 def __repr__ (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
41 return '%s(%d, %d)' % (self.__class__.__name__, self.numerator, self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
42
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
43 def __str__ (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
44 if self.numerator > self.denominator:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
45 if self.numerator % self.denominator == 0:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
46 return str (self.numerator // self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
47 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
48 return '%d + (%d / %d)' % (self.numerator // self.denominator,
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
49 self.numerator % self.denominator, self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
50 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
51 return str (self.numerator) + '/' + str (self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
52
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
53 def __add__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
54 if isinstance (other, Fraction):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
55 n1, n2, d1, d2 = (self.numerator, other.numerator, self.denominator, other.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
56 return Fraction ((n1 * d2) + (n2 * d1), d1 * d2)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
57 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
58 return Fraction (self.numerator + (other * self.denominator), self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
59
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
60 def __radd__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
61 return self + other
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
62
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
63 def __sub__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
64 if isinstance (other, Fraction):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
65 return self.__add__ (Fraction (-other.numerator, other.denominator))
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
66 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
67 return self.__add__ (-other)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
68
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
69 def __rsub__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
70 return -self + other
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
71
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
72 def __mul__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
73 if isinstance (other, Fraction):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
74 return Fraction (self.numerator * other.numerator, self.denominator * other.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
75 elif isinstance (other, float):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
76 return (self.numerator / self.denominator) * other
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
77 elif isinstance (other, int):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
78 return Fraction (self.numerator * int (other), self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
79
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
80 def __rmul__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
81 return self * other
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
82
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
83 def __truediv__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
84 if isinstance (other, Fraction):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
85 return Fraction (self.numerator * other.denominator, self.denominator * other.numerator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
86 else:
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
87 return Fraction (self.numerator, self.denominator * int (other))
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
88
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
89 def __rtruediv__ (self, other):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
90 return other * Fraction (self.denominator, self.numerator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
91
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
92 def __neg__ (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
93 return Fraction (-self.numerator, self.denominator)
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
94
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
95 def __abs__ (self):
e18f73e4c2e2 More Python 3 support
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
96 return Fraction (abs (self.numerator), self.denominator)

mercurial