Search code examples
mathematical-optimizationcplexopl

I'm having multi errors, one of them saying: "Exception from IBM ILOG CPLEX: CPLEX Error 5002: 'q1' is not convex.->."


I was trying to run this model in CPLEX but I'm having a few errors.

  1. My objective function e2 is having error saying: "cannot extract expression: (q[i][j]*n[i][j])*m[i][j]"

  2. I'm trying to use "minimize staticLex(e1, e2)" to solve this 2 objectives problem but it's saying: "cannot extract expression: minimize nulti crit [2] {-> e1-> e2->}->". I think it has something to do with the function e2's error claimed above.

  3. When I try to run minimize only function e1, it's saying that: "Exception from IBM ILOG Concert: not enough memory.", my laptop has 8Gb of RAM, intel i7-7700HQ, GTX 1050 4GB (Im running cplex with my NVIDIA processor)

Here is my model in CPLEX:

int NumbDay =...;
int NumbTask =...;


range Day = 1 .. NumbDay;
range Task = 1 .. NumbTask;

int maxRepetition = NumbDay;
dvar int F [Task] in 1..maxRepetition;
range Repetition = 1 .. maxRepetition;


float h [Day]=...;
float R [Task]=...;
float c [Day]=...;
float E [Task]=...;
float d [Day]=...;
float O [Task]=...;
float t [Task]=...;
float T = NumbDay;
float P [Task] =...;


dvar float+ r [Task][Repetition];
dvar float+ e [Task][Repetition];
dvar float+ o [Task][Repetition];
dvar float+ q [Task][Repetition];
dvar float+ n [Task][Repetition];
dvar float+ m [Task][Repetition];
dvar float+ W [Day];
dvar boolean X [Day][Task][Repetition];


execute PRE_PROCESSING {
  cplex.epgap = 0.1;
  cplex.tilim = 100;
}


dexpr float e1 = sum(k in Day)(((sum(k in Day, i in Task, j in Repetition) t[i]*X[k][i][j])/30) - W [k])^2; //error: out of memory (I use 8GB of RAM laptop)

dexpr float e2 = sum(i in Task, j in Repetition) q [i][j] * n [i][j] * m [i][j]; //error: CPLEX(default) cannot extract expression: (q[i][j]*n[i][j])*m[i][j].

minimize staticLex(e1, e2); //error: CPLEX(default) cannot extract expression: minimize nulti crit [2] {->  e1->  e2->}->.

subject to 
{
    constraint_1:
        forall (i in Task){
            F [i] >= P [i];
    }

    constraint_2:
        forall (k in Day, j in Repetition){
            sum(i in Task) t [i]*X [k][i][j]*(j<=F[i]) == W [k];
    }  
  
    constraint_3:
        forall (i in Task, j in Repetition){
            sum(k in Day) X [k][i][j] == 1;
    }

    constraint_4:
        forall (i in Task, j in Repetition, k in Day){
            X [k][i][j] == 0 || X [k][i][j] == 1;
    }
  

//Constraints related to flight hour (FH):
    constraint_5:
        forall (i in Task, j in Repetition){
            sum(k in Day) X [k][i][j] * h [k] <= r [i][j];
    }

    constraint_6:
        forall (i in Task, j in Repetition){
            q [i][j] == r [i][j] - sum(k in Day) X [k][i][j] * h [k];
    }

    constraint_7:
        forall (i in Task, j in Repetition){
            r [i][j] <= 10 * T;
    }

    constraint_8:
        forall (i in Task){
            r [i][1] == R [i];
    }

    constraint_9:
        forall (i in Task, j in Repetition: (j + 1) in Repetition){
            r [i][j+1] == R [i] + sum(k in Day) X [k][i][j] * h [k];
    }
 
//Constraints related to flight cycle (FC):
    constraint_10:
        forall (i in Task, j in Repetition){
            sum(k in Day) X [k][i][j] * c [k] <= e [i][j];
    }

    constraint_11:
        forall (i in Task, j in Repetition){
            n [i][j] == e [i][j] - sum(k in Day) X [k][i][j] * c [k];
    }

    constraint_12:
        forall (i in Task, j in Repetition){
            e [i][j] <= 8 * T;
    }

    constraint_13:
        forall (i in Task){
            e [i][1] == E [i];
    }

    constraint_14:
        forall (i in Task, j in Repetition: (j + 1) in Repetition){
            e [i][j+1] == E [i] + sum(k in Day) X [k][i][j] * c [k];
    }

//Constraints related to day (DY):
    constraint_15:
        forall (i in Task, j in Repetition){
            sum(k in Day) X [k][i][j] * d [k] <= o [i][j];
    }

    constraint_16:
        forall (i in Task, j in Repetition){
            m [i][j] == o [i][j] - sum(k in Day) X [k][i][j] * d [k];
    }

    constraint_17:
        forall (i in Task, j in Repetition){
            o [i][j] <= 1 * T;
    }

    constraint_18:
        forall (i in Task){
            o [i][1] == O [i];
    }   

    constraint_19:
        forall (i in Task, j in Repetition: (j + 1) in Repetition){
            o [i][j+1] == O [i] + sum(k in Day) X [k][i][j] * d [k];
    }
}

After receiving these errors, I tried changing the objective function e1 to:

dexpr float e1 = sum(k in Day)(W [k])^2;
minimize e1;

But then, I'm having the error "Exception from IBM ILOG CPLEX: CPLEX Error 5002: 'q1' is not convex.->."

Could you help me solving or giving me advices on these errors while still using this multi objectives problem model?

Thank you so much in advance.


Solution

  • q [i][j] * n [i][j] * m [i][j]
    

    is not linear.

    Do deal with this you could try to use CPOptimizer within OPL CPLEX

    With CPO, you can use decimal decision variables : CPO with decimal decision variables

    using CP;

    int nbKids=310;
    float costBus40=500;
    float costBus30=400;
    int scale=100;
    
     
    dvar int+ scalenbBus40;
    dvar int+ scalenbBus30;
    
    dexpr float nbBus40=scalenbBus40/scale;
    dexpr float nbBus30=scalenbBus30/scale;
     
    minimize
     costBus40*nbBus40  +nbBus30*costBus30;
     
    subject to
    {
     40*nbBus40+nbBus30*30>=nbKids;
    }
    
    execute
    {
      writeln("nbBus40 = ",nbBus40);
      writeln("nbBus30 = ",nbBus30);
    }