Реализация импликации, где LHS не является двоичным?

Попытка реализовать и индикаторное ограничение в Python + Gurobi, где индикатор (LHS) является суммой двоичной переменной решения.

Привет, я хотел бы реализовать следующее в Python + Gurobi:

Y_i_d and U_d are binary decision variables:
Y_i_d = model.addVars(passengers, drivers, vtype=grb.GRB.BINARY, name = "Y")
U0_d = model.addVars( drivers, vtype=grb.GRB.BINARY, name = "U0")
U1_d = model.addVars( drivers, vtype=grb.GRB.BINARY, name = "U1")
U2_d = model.addVars( drivers, vtype=grb.GRB.BINARY, name = "U2")
U3_d = model.addVars( drivers, vtype=grb.GRB.BINARY, name = "U3")

и я хотел бы иметь следующее значение как-то:

model.addConstr((U0_d[d]+U1_d[d]+U2_d[d]+U3_d[d])==1)
model.addConstr( (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 0) >>     (U0_d[d] == 1))
model.addConstr( (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 1) >>     (U1_d[d] == 1))
model.addConstr( (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 2) >>     (U2_d[d] == 1))
model.addConstr( (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 3) >>     (U3_d[d] == 1))

Однако это не работает, потому что ограничение индикатора объявляет переменную индикатора как двоичный тип. Есть ли обходной путь для этого? Я должен использовать переменные U_d позже, чтобы определить дизъюнктивные ограничения.

Заранее спасибо!

0 ответов

Попробуйте записать ограничения в обратном порядке:

model.addConstr((U0_d[d] == 1) >> (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 0))
model.addConstr((U1_d[d] == 1) >> (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 1))
model.addConstr((U2_d[d] == 1) >> (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 2))
model.addConstr((U3_d[d] == 1) >> (grb.quicksum(Y_i_d[ i, d] for i in passengers) == 3))
Другие вопросы по тегам