CPLEX - определить переменные с выражениями
Я работаю над проблемой назначения флота и строю модель в 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];
Спасибо! С уважением