-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLinearEquation.py
85 lines (67 loc) · 2.49 KB
/
LinearEquation.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
from LinearExpression import LinearExpression
from constants import ALMOST_ZERO
class LinearEquation:
def __init__(self, left, right):
self.left = left
self.right = right
@classmethod
def from_string(cls, s):
left, right = s.split('=')
left = LinearExpression.from_string(left)
right = LinearExpression.from_string(right)
return cls(left=left, right=right)
def get_first_common_var(self, e2):
e2vars = e2.vars()
for var in self.vars():
if var in e2vars:
return var
return None
def __eq__(self, e2):
var = self.get_first_common_var(e2)
if var == None:
return False
exp1 = self.solve_for(var).right
exp2 = e2.solve_for(var).right
return exp1 == exp2
def __str__(self):
return str(self.left) + '=' + str(self.right)
def __repr__(self):
return "LinearEquation('{0}')".format(self.__str__())
def __hash__(self):
return hash(self.__str__())
def clone(self):
return LinearEquation(left=self.left.clone(), right=self.right.clone())
# balances the equation so that the right side = 0
def zero_form(self):
result = self.clone()
return LinearEquation(left = self.left - self.right,
right = LinearExpression.from_string('0'))
def solve_for(self, var):
if not var in self.vars():
return None
result = self.zero_form()
coe = result.left.terms[var]
if abs(coe) < ALMOST_ZERO:
return None
result.left, result.right = result.right, result.left * -1
result.right /= coe
result.left += LinearExpression.from_string(var)
result.right += LinearExpression.from_string(var)
return result
def vars(self):
return self.left.vars() | self.right.vars()
def substitute(self, var, expression):
result = self.clone()
result.left = result.left.substitute(var, expression)
result.right = result.right.substitute(var, expression)
return result
def is_consistent(self):
return self.right == self.left
def print_terms(self):
print(self.terms)
def simplify(self):
for k in self.sorted_keys():
solution = self.solve_for(k)
if solution:
break
return solution