【问题标题】:Is there a way to calculate multi objective in CPLEX?有没有办法在 CPLEX 中计算多目标?
【发布时间】:2021-06-09 18:27:18
【问题描述】:

我的问题有 2 个目标函数,我尝试了“staticLex”,但它显示错误:“CPLEX(默认)无法提取表达式:最小化 nulti crit [2] {-> e1-> e2->}-> 。”

dexpr float e1 = sum(k in Day)(W [k])^2;
dexpr float e2 = sum(i in Task) (q [i]*n[i]*m[i]);
minimize staticLex(e1, e2);
//Error:"CPLEX(default) cannot extract expression: minimize nulti crit [2] {-> e1-> e2->}->."   

是否有任何方法可以修复此错误或任何其他方法来计算 CPLEX 中的多目标问题? 提前非常感谢您!

我的完整代码:

int NumbDay =...;
int NumbTask =...;

range Day = 1 .. NumbDay;
range Task = 1 .. NumbTask;

float h [Day]=...;
float c [Day]=...;
float d [Day]=...;
float R [Task]=...;
float E [Task]=...;
float O [Task]=...;
float t [Task]=...;

dvar float+ q [Task];
dvar float+ n [Task];
dvar float+ m [Task];
dvar float+ W [Day];
dvar boolean X [Day][Task];

execute PRE_PROCESSING {
  cplex.epgap = 0.1;
  cplex.tilim = 100;
}

dexpr float e1 = sum(k in Day)(W [k])^2;

dexpr float e2 = sum(i in Task) (q [i]*n[i]*m[i]);

minimize staticLex(e1, e2);

subject to 
{
    constraint_1:
        forall (k in Day){
            sum(i in Task) t [i]*X [k][i] == W [k];
    }  
    constraint_2:
        forall (i in Task){
            sum(k in Day) X [k][i] == 1;
    }
    constraint_3:
        forall (k in Day, i in Task){
            X [k][i] == 0 || X [k][i] == 1;
    }
    constraint_4:
        forall (i in Task){
            sum(k in Day) X [k][i] * h [k] <= R [i];
    }
    constraint_5:
        forall (k in Day, i in Task){
            q [i] == R [i] - sum(k in Day) X [k][i] * h [k];
    }
    constraint_6:
        forall (i in Task){
            sum(k in Day) X [k][i] * c [k] <= E [i];
    }
    constraint_7:
        forall (k in Day, i in Task){
            n [i] == E [i] - sum(k in Day) X [k][i] * c [k];
    }
    constraint_8:
        forall (i in Task){
            sum(k in Day) X [k][i] * d [k] <= O [i];
    }
    constraint_9:
        forall (k in Day, i in Task){
            m [i] == O [i] - sum(k in Day) X [k][i] * d [k];
    }
}       

【问题讨论】:

    标签: mathematical-optimization cplex opl


    【解决方案1】:
      q [i] * n [i]* m [i]
    

    不是线性的。

    您可以尝试使用线性表达式或使用 cpoptimizer 吗?

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-09-01
      • 1970-01-01
      • 2012-10-16
      • 2022-01-14
      • 2018-02-24
      • 2019-02-06
      • 1970-01-01
      • 2016-12-01
      相关资源
      最近更新 更多