Intended to work like PuLP, but with a few convenience functions thrown in.
pip install citrus# without citrus
import pulp
p = pulp.LpProblem('and example', pulp.LpMinimize)
x = pulp.LpVariable('x', cat=pulp.LpBinary)
y = pulp.LpVariable('y', cat=pulp.LpBinary)
x_and_y = pulp.LpVariable('x_and_y', cat=pulp.LpBinary)
model.addConstraint(x_and_y >= x + y - 1)
model.addConstraint(x_and_y <= x)
model.addConstraint(x_and_y <= y)# with citrus
import citrus
p = citrus.Problem('and example', pulp.LpMinimize)
x = p.make_var('x', cat=pulp.LpBinary)
y = p.make_var('y', cat=pulp.LpBinary)
x_and_y = x & y
# alternatively, x_and_y = citrus.logical_and(x, y)# without citrus
import pulp
p = pulp.LpProblem('or example', pulp.LpMinimize)
x = pulp.LpVariable('x', cat=pulp.LpBinary)
y = pulp.LpVariable('y', cat=pulp.LpBinary)
x_or_y = pulp.LpVariable('x_or_y', cat=pulp.LpBinary)
model.addConstraint(x_or_y <= x + y)
model.addConstraint(x_or_y >= x)
model.addConstraint(x_or_y >= y)# with citrus
import citrus
p = citrus.Problem('or example', pulp.LpMinimize)
x = p.make_var('x', cat=pulp.LpBinary)
y = p.make_var('y', cat=pulp.LpBinary)
x_or_y = x | y
# alternatively, x_or_y = citrus.logical_or(x, y)# without citrus
p = pulp.LpProblem('negation test', pulp.LpMinimize)
x = pulp.LpVariable('x', cat=pulp.LpBinary)
not_x = pulp.LpVariable('not_x', cat=pulp.LpBinary)
p.addConstraint(not_x == 1 - x)# With citrus
import citrus
p = citrus.Problem('negation test', pulp.LpMinimize)
x = p.make_var('x', cat=pulp.LpBinary)
not_x = citrus.negate(x)Sometimes, you'll have many variables that you want to AND or OR together:
p = citrus.Problem('vacation at some point', pulp.Maximize)
vacation_in_x_month = [
p.make_var('vacation in ' + month, cat=pulp.LpBinary)
for month in MONTHS
]
take_a_vacation = reduce(citrus.logical_or, vacation_in_x_month)
p.addConstraint(take_a_vacation)-
Variableis a subclass ofpulp.LpVariable. It adds the following methods:- (classmethod)
from_lp_var. Upgrade apulp.LpVariableto a Variable. __or__(self, other)Compute thelogical_orof two binaryVariables__and__(self, other)Compute thelogical_andof two binaryVariables__and__(self, other)Compute thelogical_andof two binaryVariables__abs__(self)Create a new Variable restricted to the absolute value of this one.
- (classmethod)
-
ProblemA subclass ofpulp.LpProblem. It adds the following methodmake_var()accepts the same arguments aspulp.LpVariable, but produces aVariable
negate(x: Variable)Produce a newVariablewith the opposite value ofx.logical_and(x: Variable, y: Variable)Produce a newVariableconstrained to take on the AND ofxandy.logical_or(x: Variable, y: Variable)Produce a newVariableconstrained to take on the OR ofxandy.logical_xor(x: Variable, y: Variable)Produce a newVariableconstrained to take on the XOR ofxandy.implies(x: Variable, y: Variable)Produce a new variable constrained to take on the value ofx => yminimum(*xs)Produce a newVariablethat can be no larger than the smallest inxsmaximum(*xy)Produce a newVariablethat can be no smaller than the largest inxs