Минимизация за каждый шаг по времени - PullRequest
0 голосов
/ 06 июня 2018

Я программирую оптимизатор для функции пиковой нагрузки.Проблема в том, что я хочу минимизировать свою функцию на каждом временном шаге.В настоящее время он просто запускает машины в одно и то же время и не пытается сдвинуть эти начальные точки.Моя переменная решения - это стартовый сигнал для машин.Для лучшего понимания:

//parameters
 int m1=...; //number of machines
 int m2=...; //number of machines
 int m3=...; //number of machines
 int m4=...; //number of machines
 int m=m1+m2+m3+m4; //total number of machines
 int Parts1=...; //amount of parts from machines group 1
 int Parts2=...; //amount of parts from machines group 2
 int Parts3=...; //amount of parts from machines group 3
 int Parts4=...; //amount of parts from machines group 4
 int n=...; //number of time steps in overall simulation
 int p=...; // number of time steps in power cycle
 int k= n-p+2; //Declares the range to ensure that a machine can only start if it will finish in the shift
 float MaxLoad=...; 


 range machines = 1..m; // range over all machines
 range machines1 = 1..m1; //range over first machine group
 range machines2 = (m1+1)..(m1+m2); //range over second machine group
 range machines3 = (m1+m2+1)..(m1+m2+m3); //range over third machine group
 range machines4 = (m1+m2+m3+1)..(m1+m2+m3+m4); //range over fourth machine group
 range time = 1..n; //range over time steps
 range ptime = 1..p; //range over powercycle steps
 range sumbackStart = p..n;  //machine summation backwards (i-p+1) ensures that sum starts at 1 and not at -p !!
 range sumbackFinish = k..n; //no starts to the end of the shift if the machine will not finish the working piece

 float power [machines][ptime]=...;

 // variables
 dvar int+ x[machines][time];

// Optimization Problem
minimize sum (i in time) (sum(j in machines, inew in ptime: (i-inew+1) in time) x[j][i-inew+1]*power[j][inew]);

 subject to {   
    Range_binaryVariable: //Ensures that the decision variable is only 1 or 0
    forall (j in machines, i in time){
    0 <= x[j][i] <= 1; 
    }

    /*LimitLoadPeak: //Limits the maximum Peak
    forall (i in time){
    sum (j in machines, inew in ptime: (i-inew+1) in time) x[j][i-inew+1]*power[j][inew] <= 100;
    }*/

    PartStart: //Ensures that the machine only starts 
    forall (j in machines, i in sumbackStart){
    sum (inewnew in (i-p+1)..i) x[j][inewnew] <= 1; 
    }

    PartFinisher: //Ensures that the machines only start if they will finish during the given time steps or shift
    forall (j in machines){
    sum (inewnewnew in sumbackFinish) x[j][inewnewnew] <= 0; 
    }

    //Ensures that the work pieces, which need to be produced by the machine groups, will be produced
    PartminM1:
    Parts1 <= sum (j in machines1, i in time) x[j][i];

    PartminM2:
    Parts2 <= sum (j in machines2, i in time) x[j][i];

    PartminM3:
    Parts3 <= sum (j in machines3, i in time) x[j][i];

    PartminM4:
    Parts4 <= sum (j in machines4, i in time) x[j][i];


 }

Я уже ввел пиковое ограничение, но моя функция должна сделать это сама и попытаться изменить рабочий процесс.

Надеюсь, вы понимаете мою проблему иБуду очень признателен за вашу помощь.

SheetConnection my_sheet ("OptiV7_Daten.xlsx");

n from SheetRead(my_sheet,"'Information'!timesteps");

p from SheetRead(my_sheet,"'Information'!powercycle");

MaxLoad from SheetRead(my_sheet,"'Machine_Data_timesized'!MaxLoad");

Parts1 from SheetRead(my_sheet,"'Information'!Parts1");

Parts2 from SheetRead(my_sheet,"'Information'!Parts2");

Parts3 from SheetRead(my_sheet,"'Information'!Parts3");

Parts4 from SheetRead(my_sheet,"'Information'!Parts4");

m1 from SheetRead(my_sheet,"'Information'!machines1");

m2 from SheetRead(my_sheet,"'Information'!machines2");

m3 from SheetRead(my_sheet,"'Information'!machines3");

m4 from SheetRead(my_sheet,"'Information'!machines4");

power from SheetRead(my_sheet,"'Machine_Data_timesized'!Power");

1 Ответ

0 голосов
/ 25 июня 2018

Если у кого-то есть такая же проблема, я ее решил.Я изменил ограничение LimitLoadPeak на следующее:

// variables
 dvar int+ x[machines][time];
 dvar int+ MaxLoad;

// Optimization Problem last part ensures that when the machine is not running the idle power will be added
//minimize sum (i in time, j in machines, inew in ptime: (i-inew+1) in time) (x[j][i-inew+1]*power[j][inew] + Ipower[j]*(1-x[j][i-inew+1]));
minimize MaxLoad;
 subject to {   
    Range_binaryVariable: //Ensures that the decision variable is only 1 or 0
    forall (j in machines, i in time){
    0 <= x[j][i] <= 1; 
    }

    LimitLoadPeak: //Limits the maximum Peak
    forall (i in time){
    (sum (j in machines, inew in ptime: (i-inew+1) in time)  (x[j][i-inew+1]*power[j][inew]))^2 <= MaxLoad;
    }

MaxLoad определен как переменная, а квадрат суммы гарантирует, что небольшие отклонения также влияют на результат.

...