Давайте проверим этот код
{int} part ={1, 2};
{int} time = {1, 2, 3, 4, 5};
int livraison [part][time] =[[20, 30, 46, 24, 53], [12, 12, 14, 65, 34]];
dvar int S[part][time];
dvar int order[part][time];
int iniS[part] = [0, 0];
int iniorder[part] = [0, 0];
subject to {
forall(i in part, t in time) {
if (t == 1){
S[i][t + 1] == iniS[i]-livraison[i][t]+iniorder[i];
}
else if (t >= 2){
(S[i][t-1] <=0) => (S[i][t] == S[i][t-1]-livraison[i][t-1]+order[i][t-1]);
}
}
}
Я надеюсь, что это может вам помочь, или проверьте это обсуждение: https://www.ibm.com/developerworks/community/forums/html/topic?id=77777777-0000-0000-0000-000014923153