return '({})'.format(string)
def __repr__(self):
- string = '{}({{'.format(self.__class__.__name__)
- for i, (symbol, coefficient) in enumerate(self.coefficients()):
- if i != 0:
- string += ', '
- string += '{!r}: {!r}'.format(symbol, coefficient)
- string += '}}, {!r})'.format(self.constant)
- return string
+ return '{}({!r})'.format(self.__class__.__name__, str(self))
@_polymorphic_method
def __eq__(self, other):
constraints.append('{} == 0'.format(constraint))
for constraint in self.inequalities:
constraints.append('{} >= 0'.format(constraint))
- return '{{{}}}'.format(', '.join(constraints))
+ return '{}'.format(', '.join(constraints))
def __repr__(self):
if self.isempty():
elif self.isuniverse():
return 'Universe'
else:
- equalities = list(self.equalities)
- inequalities = list(self.inequalities)
- return '{}(equalities={!r}, inequalities={!r})' \
- ''.format(self.__class__.__name__, equalities, inequalities)
+ return '{}({!r})'.format(self.__class__.__name__, str(self))
+
+ @classmethod
+ def _fromsympy(cls, expr):
+ import sympy
+ equalities = []
+ inequalities = []
+ if expr.func == sympy.And:
+ for arg in expr.args:
+ arg_eqs, arg_ins = cls._fromsympy(arg)
+ equalities.extend(arg_eqs)
+ inequalities.extend(arg_ins)
+ elif expr.func == sympy.Eq:
+ expr = Expression.fromsympy(expr.args[0] - expr.args[1])
+ equalities.append(expr)
+ else:
+ if expr.func == sympy.Lt:
+ expr = Expression.fromsympy(expr.args[1] - expr.args[0] - 1)
+ elif expr.func == sympy.Le:
+ expr = Expression.fromsympy(expr.args[1] - expr.args[0])
+ elif expr.func == sympy.Ge:
+ expr = Expression.fromsympy(expr.args[0] - expr.args[1])
+ elif expr.func == sympy.Gt:
+ expr = Expression.fromsympy(expr.args[0] - expr.args[1] - 1)
+ else:
+ raise ValueError('non-polyhedral expression: {!r}'.format(expr))
+ inequalities.append(expr)
+ return equalities, inequalities
+
+ @classmethod
+ def fromsympy(cls, expr):
+ import sympy
+ equalities, inequalities = cls._fromsympy(expr)
+ return cls(equalities, inequalities)
+
+ def tosympy(self):
+ import sympy
+ constraints = []
+ for equality in self.equalities:
+ constraints.append(sympy.Eq(equality.tosympy(), 0))
+ for inequality in self.inequalities:
+ constraints.append(sympy.Ge(inequality.tosympy(), 0))
+ return sympy.And(*constraints)
def _symbolunion(self, *others):
symbols = set(self.symbols)