运筹系列86:MIP问题的建模tips

1. Either-or constraint

添加辅助变量y。
比如
Either 3 x 1 + 2 x 2 ≤ 18 3x_1+2x_2 \le 18 3x1+2x218
or x 1 + 4 x 2 ≤ 16 x_1+4x_2 \le 16 x1+4x216

可以用

3 x 1 + 2 x 2 ≤ 18 + M y 3x_1+2x_2 \le 18+My 3x1+2x218+My
x 1 + 4 x 2 ≤ 16 + M ( 1 − y ) x_1+4x_2 \le 16+M(1-y) x1+4x216+M(1y)
来代替。

2. k out of N constraints must hold

类似上面,添加辅助变量 y 1 y_1 y1 y N y_N yN

f 1 ( . . . ) ≤ d 1 f_1(...)\le d_1 f1(...)d1

f N ( . . . ) ≤ d N f_N(...)\le d_N fN(...)dN

变为

f 1 ( . . . ) ≤ d 1 + M y 1 f_1(...)\le d_1+My_1 f1(...)d1+My1

f N ( . . . ) ≤ d N + M y N f_N(...)\le d_N+My_N fN(...)dN+MyN
Σ 1 N y i = N − k , y i \Sigma_1^N y_i=N-k, y_i Σ1Nyi=Nk,yi binary.

3. functions with N possible values

f ( x ) ∈ ( d 1 , . . . , d N ) f(x)\in (d_1,...,d_N) f(x)(d1,...,dN)

添加辅助变量 y 1 y_1 y1 y N y_N yN
f ( x ) = Σ d i y i f(x)=\Sigma d_iy_i f(x)=Σdiyi
Σ y i = 1 \Sigma y_i=1 Σyi=1 (mutally exclusive alternatives)

4. fixed-charge problem

f ( x ) = { k + c x , x > 0 0 , x = 0 f(x)=\begin {equation} \begin{cases} k+cx, x>0\\ 0,x=0\\ \end{cases} \end {equation} f(x)={k+cx,x>00,x=0
可以变为
f ( x ) = c x + k y f(x)=cx+ky f(x)=cx+ky
x ≤ M y x\le My xMy
y y y binary.

5. 综合例子

在这里插入图片描述
在这里插入图片描述

如果没有题目中的两个restriction,那么模型为:
在这里插入图片描述
接下来我们看约束1,要求 x 1 , x 2 , x 3 x_1,x_2,x_3 x1,x2,x3最多只能有2个,因此添加 y 1 + y 2 + y 3 ≤ 2 y_1+y_2+y_3\le 2 y1+y2+y32的约束。
然后是约束2,要求两座工厂二选一,因此添加Either-or变量 y 4 y_4 y4,最终模型为:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值