我有一个混合整数编程问题(使用列生成来削减库存),我已经在 AMPL 中解决了这个问题,并且我使用 cvxopt 将其移植到了 Python。CVXOPT“op”不提供我需要的二进制变量选项,所以我用 GLPK 扩展它以使用“ILP”。我得到了 ilp 状态 =“LP 松弛是根本不可行的”,我知道这是不正确的,因为之前的 AMPL 解决方案。所以我知道我的配置不正确。我试图通过玩stackoverflow问题中的示例来了解整数“I”和二进制“B”键的使用CVXOPT中的整数线性规划(ILP)函数返回非整数。
我的问题是,I&B 键之间有什么区别,例如:
stat, sol1 = glpk.ilp(W, G.T, h, I=set([0, 1]))
stat, sol2 = glpk.ilp(W, G.T, h, I={0,1})
stat, sol3 = glpk.ilp(W, G.T, h)
有以下 3 种不同的解决方案: ( print(soli.T
)
[ 0.00e+00 0.00e+00 5.00e-01 5.00e-01 5.00e-01 -0.00e+00 ... ]
[ 0.00e+00 0.00e+00 5.00e-01 5.00e-01 5.00e-01 -0.00e+00 ... ]
[ 5.00e-01 5.00e-01 5.00e-01 5.00e-01 5.00e-01 -0.00e+00 ... ]
我看过help(ilp)
,但它只是说 I&B 是整数和二进制变量的索引集,(我理解),但它没有描述如果你同时使用两者(I&B)会发生什么,或者它们重叠,或者一个或另一个是空集,或未定义。我会认为sol1
=sol2
上面,因为它只是定义集合 I 的两种不同方法。我假设sol3
是所有整数并且没有二进制变量,因为B
未定义,但我没有任何文档来确认这一点。