optimization - CPLEX 是否能降低 MIP 的成本?

标签 optimization mathematical-optimization cplex integer-programming

我正在使用 CPLEX 解决 MIP 问题。解决之后,我想得到降低的成本。我知道 MIP 不存在降低成本的情况,因此我执行了以下操作:

     int type = CPXgetprobtype(env, lp);
     if(CPXchgprobtype(env, lp, CPXPROB_FIXEDMILP)) abort();
     if(CPXlpopt(env,lp)) abort();
     int blabla; double blublu;
     if(CPXsolution (env, lp, &blabla , &blublu , x, pi, slack, dj)) abort();
     for (int i = 0; i < CPXgetnumcols(env,lp); i++) {
        printf("v%d = %f, ", i,dj[i]);
        if ((i+1) % 10 == 0) printf("\n");
     }
     if(CPXchgprobtype(env, lp, type)) abort();

当我打印数组 dj 时,它全是 0。我还尝试使用 CPXgetdj 而不是 CPXsolution,得到了相同的结果。

阅读后this我相信我所做的事情是正确的。但它似乎不起作用。我的问题有 20000 个变量,我尝试过其中的很多变量,但它总是显示 0...

我的时间限制很小,所以它不能证明最优性(但它确实找到了整数解),我不确定这是否重要。

谢谢

最佳答案

考虑一个一般线性问题P,其中所有变量都固定为给定整数问题I的整数最优解的值。设P

enter image description here

其中上划线的bj是最优整数解中xj的值。 P 的对偶问题 D

enter image description here

成本 z(D) = z(P) = z(I) 的 D 的最优解>) 可以找到设置

enter image description here

因此降低的成本为

enter image description here

关于optimization - CPLEX 是否能降低 MIP 的成本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39968420/

相关文章:

java - 伽罗瓦域 GF(4) 中乘法的恒定时间

algorithm - 矩阵乘法子问题图顶点度

查找集合中所有连续子串之和的算法

c++ - 如何在宏 BranchCallback 中修复边界/更改变量边界? C++

java - ILOG TSP 得到空输出

python - 优化零重力二维空间中粒子的重力计算

javascript - 从 javascript 优化页面

c++ - 按照每个通用寄存器的用途对 x86 程序集进行编码是否有必要或更容易

algorithm - 加油站问题 - 最便宜和最少的加油站

java - 在 Linux 2 中用 java 编译 Cplex