gurobipy.MConstr#
- class MConstr#
Gurobi 矩阵约束对象。一个
MConstr
对象是一个类似数组的数据结构,表示多个线性约束(与表示单个约束的Constr
对象相对)。它的行为类似于 NumPy 的ndarray
,例如,它具有形状并且可以被索引和切片。矩阵约束总是与特定模型相关联。通常,您可以通过Model.addConstr
使用重载的比较运算符在matrix variables
和linear matrix expressions
上创建这些对象,或者使用Model.addMConstr
方法。约束对象有许多属性。完整的列表可以在本文档的属性部分找到。一些约束属性只能查询,而其他属性也可以设置。请记住,Gurobi优化器采用延迟更新方法,因此对属性的更改在下次调用
Model.update
、Model.optimize
或Model.write
之前不会生效。我们应该指出一些关于约束属性的事情。考虑
rhs
属性。矩阵约束mc
的值可以使用mc.rhs
来查询。Gurobi库在属性名称中忽略字母大小写,因此也可以使用mc.RHS
来查询。属性值以NumPy的ndarray
形式返回,其形状与mc
相同。可以使用标准的赋值语句(例如,constr.rhs = b
)来设置属性,其中b
可以是具有适当形状的ndarray
,也可以是应用于所有相关约束的标量。然而,如前所述,属性修改是以惰性方式完成的,因此您不会立即看到更改的效果。并且某些属性无法设置(例如,Pi属性),因此尝试为它们分配新值将引发异常。你也可以使用
MConstr.getAttr
/MConstr.setAttr
来访问属性。属性 名称可以作为字符串传递给这些例程,或者你可以使用GRB.Attr
类中定义的常量(例如,GRB.Attr.RHS
)。- fromlist(constrlist)#
将约束列表转换为
MConstr
对象。形状是从列表内容推断出来的 - 一个Constr
对象列表生成一个一维的MConstr
对象,一个Constr
对象列表的列表生成一个二维的MConstr
,等等。- Parameters:
constrlist – 一个用于填充返回的MConstr的Constr对象列表。
- Returns:
MConstr 对象对应于输入约束。
- Example:
constrs = model.getConstrs() mc = MConstr.fromlist(constrs) # 1-D MConstr
- getAttr(attrname)#
查询矩阵约束的某个属性的值。完整的可用属性列表可以在属性部分找到。
如果请求的属性不存在或无法查询,则引发
AttributeError
。如果MConstr
对象存在问题(例如,它已从模型中移除),则引发GurobiError
。结果以与
MConstr
对象形状相同的NumPyndarray
形式返回。- Parameters:
attrname – 被查询的属性。
- Returns:
ndarray
请求属性的当前值。- Example:
mc = model.addConstr(A @ x <= b) rhs = mc.getAttr("RHS")
- setAttr(attrname, newvalue)#
设置矩阵约束属性的值。
请注意,由于我们采用了延迟更新的方法,更改实际上不会生效,直到您更新模型(使用
Model.update
)、优化模型(使用Model.optimize
)或将模型写入磁盘(使用Model.write
)。可用属性的完整列表可以在 属性 部分找到。
如果指定的属性不存在或无法设置,则引发
AttributeError
。如果MConstr
对象存在问题(例如,它已从模型中移除),则引发GurobiError
。- Parameters:
attrname – 正在修改的属性。
newvalue –
ndarray
属性的期望新值。 形状必须与MConstr
对象相同。或者,您可以传递一个标量参数,它将自动提升为具有正确形状。
- Example:
mc = model.addConstr(A @ x <= b) mc.setAttr("RHS", np.arange(A.shape[0])) mc.setAttr(GRB.Attr.RHS, 0.0) # broadcast