我正在研究舰队分配问题,我正在xpress-Mosel中建立一个模型。但是,我需要在OPL - Cplex中构建它。
我是OPL的新人,所以我有些疑惑。我不能通过某些不是约束或由输入给出的表达式来定义变量。
我的.dat文件中有以下向量,这是所有数据文件的一部分:
proc_low=[...];
cof=[...];
cov_km=[...];
dist_km=[...];
penalty=[...];
以这种方式定义:
range N0=0..n;
range N=1..n;
range Fleet=1..3;
range liga=1..30;
range POSS=1..poss;
int legs[N]=...;
int org[N]=...;
int dest[N]=...;
int proc_low[N]=...;
int tp_cod[Fleet]=...;
int cap[Fleet]=...;
int test1[Fleet]=...;
int cof[Fleet]=...;
int cov_km[Fleet]=...;
int cod_org[lig]=...;
int cod_dest[lig]=...;
int penalty[lig]=...;
float dist_km[lig]=...;
int leg_atual[POSS]=...;
int leg_after[POSS]=...;
int tp_fleet[POSS]=...;
tuple T {
int atual;
int after;
int type_f;
}
//Decicion variables
{T} tuples = { <leg_atual[k], leg_after[k], tp_fleet[k]> | k in POSS };
dvar boolean x[tuples];
所以,这是我的疑问:我无法定义这些表达方式......每条腿的乘客都会溢出,这取决于卖方(proc_low)和船队的能力,如果这条腿是由某架飞机飞行的话。上面的代码不是cplex格式...在xpress mosel中,我在这里需要帮助以cplex格式写...
forall(l in 1..n2) pass_out(l):= spill(l)>=proc_low(l)-sum(f in Fleet)cap(f)*(sum(i in n3..n)x(i,l,f)+x(0,l,f))
forall(l in n3..n) pass_in(l) := spill(l)>=proc_low(l)-sum(f in Fleet)cap(f)*sum(i in 1..n2)x(i,l,f)
然后,每个溢油乘客的目标函数的罚款
forall(j in N,i in lig|org(j)=cod_org(i) and dest(j)=cod_dest(i))do
pen(j):=penalty(i)*spill(j)
end-do
最后,某些飞机在一些航线上分配的费用
forall(j in N,i in ligs, f in Fleet|org(j)=cod_org(i) and dest(j)=cod_dest(i))do
cost(j,f):=cof(f)+cov_km(f)*dist_km(i)
end-do
我已经按照上面显示的方式定义了这些变量,但我不确定......也许是dexpr
。我真的不知道......
dvar int spill[N];
dvar float+ pen[N];
dvar float+ cost[N][Fleet];
谢谢! 此致