首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LP / MILP (CPLEX)困难

LP / MILP (CPLEX)困难
EN

Stack Overflow用户
提问于 2019-11-04 02:31:41
回答 1查看 58关注 0票数 2

我正在尝试用CPLEX解决一个优化问题。

代码语言:javascript
复制
//Variables 

int n = ...;
range time =1..n; //n definido em data

dvar float+ c[time] in 0..0.9;
dvar float+ d[time] in 0..0.9;
dvar float+ x[time];

int beta[time]=...;
float pc[time]=...;
float pd[time]=...;

//Expressions

dexpr float objective = sum(t in time) (d[t]*pd[t]-c[t]*pc[t]); 

//Model

maximize objective;

subject to {

    x[1] == 0.5;
    c[1] == 0;
    d[1] == 0;

    forall(t in time)
        const1:
            x[t] <= 1;          

    forall(t in time: t!=1)
        const2:
            (x[t] == x[t-1] + c[t] - beta[t]*d[t]);             
 }

谁能告诉我如何防止dt和ct同时大于0?

基本上,我想这样写:

代码语言:javascript
复制
if( d[t] > 0) c[t] = 0; 

谢谢,

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-04 02:40:03

您可以使用逻辑约束:

代码语言:javascript
复制
( d[t] <= 0) || (c[t] <= 0);
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58683360

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档