Cplex 优化——我的决策变量“没有价值”

如何解决Cplex 优化——我的决策变量“没有价值”

我是 Cplex 优化的新手。 我正在尝试在某些情况下实现优化问题。它是一个两阶段随机模型,有 5 个场景和场景发生的概率。 我用 5 个场景、参数、变量和约束编写了我的模型。我的决策变量收到以下消息“无值”。我认为我的模型不起作用,我不知道我应该在代码中更改什么?。有人可以帮助我吗?非常感谢。

--Parameter-- 
int NbWarehause=3;
int NbRegion=138;
int NbSchool=631;
int NbScenario=5;

range Warehouse=1..NbWarehause;
range Region=1..NbRegion;
range School=1..NbSchool;
range Scenario=1..NbScenario;

int TraveldistanceWarehouseRegion[Warehouse][Region]=...;
int CapacitySchool[School] =...;
int ScenarioDemandMatrix[Scenario][Region]=...;
int Fixedcost1  = 14232;
float Transportcost1perkm=1.40;
int Fixedcost2  = 14232;
float Transportcost2perkm=3;
int Unusedcostperitem=50;
int Depriviationcost[Region]=...;
int Penaltycost=100;
float ProbabilityScenario[Scenario]=...;

--Decision variables---
dvar boolean open1[School][Region];
dvar int Allocated1[School][Region];
dvar boolean open2[School][Region];
dvar int Allocated2[School][Region];
dvar int UnusedInventory[School][Region];
dvar int LateSatisfiedDemand[Region];
dvar int UnSatisfiedDemand[Region];

--Objective function--
  minimize --the first stage--

        sum(j in School,r in Region) Fixedcost1 * open1[j][r] + 
         sum( j in School,w in Warehouse,r in Region) Allocated1[j][r] * 
         TraveldistanceWarehouseRegion[w][r]*Transportcost1perkm +

     --the second stage--

    sum(s in Scenario) ProbabilityScenario[s]*( 

    sum(j in School,r in Region)Fixedcost2 *open2[j][r]

    +sum( j in School,r in Region) Allocated2[j] 
     [r]*TraveldistanceWarehouseRegion[w][r]*Transportcost2perkm

    +sum( j in School,r in Region)UnusedInventory[j][r]*Unusedcostperitem

    +sum(r in Region) Depriviationcost[r]*LateSatisfiedDemand[r]+

     sum(r in Region)UnSatisfiedDemand[r]*Penaltycost    );

  --Constraint--
  subject to 
  {
       //C1: capacity of each school in its region//
        forall (r in Region ) sum (j in School) (Allocated1[j] 
        [r]+Allocated2[j] [r]+UnusedInventory[j][r])== sum (j in 
           School)CapacitySchool[j];

    //C2: Demand of each region //
      forall (s in Scenario,r in Region) sum (j in School)(Allocated1[j] 
      [r]+Allocated2[j][r])+LateSatisfiedDemand[r]+UnSatisfiedDemand[r] ==   
       ScenarioDemandMatrix[s][r];

      //C3: open a school maximal one time //
     sum (j in School,r in Region ) (open1[j][r]+open2[j][r]) <= 1;


     //C4: school can not supply more than its capacity in the second 
    stage I dont kNow how do I  write under scenario //
    forall (j in School,r in Region)Allocated2[j][r]<=CapacitySchool[j] - 
        Allocated1[j][r]*(open1[j][r]+open2[j][r]);


    //C5: Sum of all probability is equal 1
     sum (s in Scenario)ProbabilityScenario[s]==1;

    // C6: Nonnegative Constraint 

   forall (r in Region,j in School) Allocated1[j][r]>=0;
   forall (r in Region,j in School)Allocated2[j][r]>=0;
   forall (r in Region,j in School)UnusedInventory[j][r]>=0;
   forall (r in Region)LateSatisfiedDemand[r]>=0;
   forall (r in Region) UnSatisfiedDemand[r]>=0;

}

解决方法

我猜你的模型不可行。 了解为什么您可以命名约束,然后 CPLEX 将为您提供一些放松和冲突。

一开始你可以改变

//C3: open a school maximal one time //
     sum (j in School,r in Region ) (open1[j][r]+open2[j][r]) <= 1;

进入

//C3: open a school maximal one time //
     C3:sum (j in School,r in Region ) (open1[j][r]+open2[j][r]) <= 1;

然后依靠

https://www.ibm.com/support/pages/display-full-indices-or-real-map-item-name-variables-and-constraints

获取真实索引

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?