170 likes | 277 Views
Aplica ţie. Problema planificării activităţilor. Problema planificării activităţilor de tip sisteme de producţie bazate pe comandă (JSS). Datele problemei JSS (Job Shop Scheduling) J , un set de n sarcini, ; O , un set de operaţii;
E N D
Problema planificării activităţilor de tip sisteme de producţie bazate pe comandă (JSS) Datele problemei JSS (Job Shop Scheduling) • J, un set de n sarcini, ; • O, un set de operaţii; • fiecare sarcină , , este constituită dintr-o secvenţă de m activităţi (operaţii), m independent de : , ; evident, ; • M, o mulţime de m maşini care execută operaţii din O; activităţile fiecărei sarcini se execută pe câte o maşină din M (în cadrul unei sarcini nu există două operaţii care să fie executate pe aceeaşi maşină); • o funcţie care asociază fiecărei operaţii o durata de execuţie; durata efectuării unei operaţii este independentă de planificare;
Problema JSS Ipoteze de lucru: • în cadrul fiecărei sarcini, activităţile respectă o relaţie de precedenţă din punctul de vedere al execuţiei, astfel încât două sau mai multe activităţi nu pot fi executate simultan; cu alte cuvinte, fiecare sarcină este definită de un set ordonat de operaţii, ordinea fiind predefinită; • activităţile, odată programate, nu îşi pot întrerupe execuţia; • la fiecare moment de timp, pe oricare maşină, poate fi executată o singură operaţie. Planificarea unei operaţii o revine la a îi aloca un timp de execuţie (pe maşina corespunzătoare lui o), un plan fiind o colecţie de astfel de alocări cu proprietatea că fiecare operaţie este inclusă cel mult o dată. Problema este de a găsi un plan cu proprietăţile: • completitudine: planul conţine toate operaţiile mulţimii O; • corectitudine: sunt satisfăcute toate restricţiile impuse prin ordinea de execuţie; • optimalitate: durata totală a planului este minimă.
Problema JSS Abordarea GA. Corespondenţa fenotip-genotip • Reprezentarea unui genotip: o permutare a mulţimii posibile de operaţii. • n*mdimensiunea mulţimii de operaţii. • O permutaregenotip, pg, corespunde ordinii de analizare a operaţiilor în scopul planificării lor şi are corespondent într-un plan (fenotip), pf, care constă în programarea fiecărei operaţii conform unei analize efectuate în ordinea în care aceasta apare în permutarea genotip. • Planul corespuzător unei permutări pgesteconstruit în principiu astfel: • Pentru efectuează: • ; • determină maşina pe care este executată , ; • asignează timpul de start minim pentru , ţinând cont de ocuparea maşinii şi relaţiile de precedenţă pe care trebuie să le respecte relativ la operaţiile din cadrul sarcinii din care face parte şi care au fost deja planificate.
Problema JSS Abordarea GA. Asocierea genotip (permutare) – plan fezabil(fenotip) • În această problemă partea cea mai dificilă este aceea de a asocia unei permutări un plan fezabil, adică un fenotip care să respecte cerinţele de completitudine şi corectitudine. • Variantă de rezolvare: fie x permutarea (genotipul) a cărui plan trebuie determinat (fenotipul) şi n*m numărul de operaţii planificate. • Presupunem că şi aceasta este şi ordinea de efectuare a operaţiilor (ele sunt înscrise în sarcină în ordinea în care trebuie executate). • Fiecare operaţie este codificată (reprezentată) prin numărul . • Iniţial, planifică toate operaţiile de la momentul 0 şi marchează fiecare activitate ca neexecutată (prin intrmediul menţinerii unui vector binar, iniţializat cu toate valorile 0).
JSS. Stabilireaasocieriipermutare – plan fezabil Cât timp nu au fost planificate toate activităţile Pentru fiecare execută Pas1-Pas5 Pas 1. fie neplanificat; calculează lista operatorilor care preced o, lista operatorilor care succed oastfel: • calculează c, r: • dacă face parte din sarcina şi este pe poziţia r în aceasta evident, dacă , : primul element al sarcinii nu are predecesor • dacă o este multiplu de m ,oeste ultimul element al sarcinii şi • , dacă , , altfel
JSS. Stabilireaasocieriipermutare – plan fezabil Pas2. pentru fiecare • dacă op a fost executată, timpul de început al execuţiei operaţiei o trebuie sa fie după timpul de sfârşit al lui op (dacă o este planificată înainte, este resetat timpul de început cu timpul de sfârşit al lui op: ); Pas3. fie plan(o) timpul de start calculat până la acest moment; dacă maşina pe care trebuie să se execute o nu este liberă, adică există un interval planificat pentru o altă activitate care se intersectează cu, atunci planifică o după acel interval; operaţia este repetată până când, pe maşina corepunzătoare, nu există programări conflictuale; Pas 4. marchează o ca operaţie programată; Pas5. pentru fiecare • dacă op a fost executată, şi timpul de început al execuţiei operaţiei op este sub timpul de sfârşit al lui o(programare eronată), atunci renunţă la planificarea lui op (este scoasă programarea de pe maşina care o execută) şi marchează op ca neplanificat.
JSS. Stabilireaasocieriipermutare – plan fezabil function [asociere,plan,cost]=permutare_plan(m,nm,durate,mo,x); % pentru fiecare masina: asocierea start op, sfarsit op asociere=cell(1,m); % operatie % executat(i)=0 daca operatia i nu a fost executata; altfel executat(i)=1 executat=zeros(1,nm); % un plan -vector care asociaza fiecarei operatii un timp deinceput, plan(o) cost=0;plan=zeros(1,nm);gata=0; while(~gata) gata=1; for i=1:nm o=x(i); if(~executat(o)) % determinarea operatiilor care preced, respectiv succed o pr=[];cat=fix(o/m);rest=o-cat*m;
JSS. Stabilireaasocieriipermutare – plan fezabil if(rest) for k=1:rest-1 pr=[pr cat*m+k];end; else for k=1:m-1 pr=[pr (cat-1)*m+k];end; end; succ=[]; if(rest) for k=rest+1:m succ=[succ cat*m+k];end; end; [tt,nrp]=size(pr); %masina pe care se executa o masina=mo(o); %stabilirea timpului de executie in functie de predecesori for k=1:nrp % op precede o; op=pr(k);
JSS. Stabilireaasocieriipermutare – plan fezabil % daca op a fost efectuata if(executat(op)) if(plan(o)<plan(op)+durate(op)) plan(o)=plan(op)+durate(op);end; end;end; [d1,d2]=size(asociere{masina});gata1=0; while(~gata1) gata1=1; for tt=1:d1 % daca operatia nu pate fi planificata la plan(o) din cauza ocuparii %masinii cautam, dupa plan(o), primul interval liber in care sa incapa if(((asociere{masina}(tt,1)<plan(o))&&(asociere{masina}(tt,3)>plan(o)))||... ((asociere{masina}(tt,1)<plan(o)+durate(o))&&(asociere{masina}(tt,3)>plan(o)+durate(o)))||... ((asociere{masina}(tt,1)>=plan(o))&&(asociere{masina}(tt,3)<=plan(o)+durate(o)))) plan(o)=asociere{masina}(tt,3); gata1=0; end; end; end; %while (~gata1)
JSS. Stabilireaasocieriipermutare – plan fezabil asociere{masina}=[asociere{masina};[plan(o),o,plan(o)+durate(o)]]; executat(o)=1; if(cost<plan(o)+durate(o))cost=plan(o)+durate(o);end; [tt,nrs]=size(succ); % pentru toti succesorii executati deja, elimina, daca este cazul,planificarea lor for k=1:nrs op=succ(k); if((executat(op))&&(plan(op)<plan(o)+durate(o))) masina=mo(op); [d1,d2]=size(asociere{masina}); for tt=1:d1 if(asociere{masina}(tt,1)==plan(op))ind=tt;break;end; end; xx=asociere{masina}(1:tt-1,:);yy=asociere{masina}(tt+1:d1,:); asociere{masina}=[xx;yy];executat(op)=0; gata=0; end;end;end;end;end; end
Problema JSS Funcţia de evaluare • Funcţia de evaluare aplicată unui genotip furnizează durata de execuţie a planului corespunzător în spaţiul fenotipurilor. Scopul este de a minimiza funcţia de evaluare. • În implementarea GA este maximizată funcţia , unde cost este durata de execuţie calculată pentru un plan x asociat permutării (genotipului) p. Operatorii de variaţie • Alegerea operatorilor de variaţie este realizată astfel încât progeniturile să rămână în spaţiul genotipurilor. • Mutaţia este prin operatorul interschimbare. • Deoarece relaţiile de adiacenţă nu au nici o semnificaţie în această problemă, operaţia de recombinare poate fi aleasă din oricare dintre cele prezentate în cazul permutărilor. A fost selectat aici PMX.
Problema JSS Mecanismul de selecţie • În cazul acestei probleme operatorii de selecţie sunt independenţi de reprezentarea cromozomială, deci pot fi utilizaţi oricare dintre cei prezentaţi. • Operatorul de selecţie a părinţilor este de tip SUS cu distribuţia de probabilitate de selecţie FPS standard. • Mecanismul de supravieţuire: generaţia următoare este construită pe baza urmaşilor cu propagarea celui mai bun cromozom din generaţia curentă în locul celui mai slab urmaş, dacă progeniturile sunt sub acel cromozom din punct de vedere al funcţiei de evaluare. Populaţia iniţială şi condiţia terminală • Stabilirea populaţiei iniţiale este realizată aleatoriu • Condiţia terminală este de tip prag: de exemplu, dacă a fost atins un număr de iteraţii sau au fost evaluaţi un număr maxim de cromozomi.
Problema JSS. Exemplu de test Date de intrarea folosite: • numărul sarcinilor: 5; • numărul maşinilor: 4, maşinile fiind identificate prin numere de la 1 la 4; • numărul operaţiilor: 20, operaţiile fiind considerate numere de la 1 la 20; • duratele de execuţie ale operaţiilor de la 1 la 20 : [3 2 5 1 3 5 9 4 3 7 3 5 4 4 7 6 4 9 2 7] ; • alocarea operaţiilor (de la 1 la 20) pe maşini : • precedenţele: în fiecare sarcină operaţiile sunt identificate prin , ordinea efectuării operaţiilor fiind de la cea etichetată cu valoarea minima (), crescător până la ultima operaţie (etichetată cu valoarea minima ()).
Problema JSS. Exemplu de test • La un apel>> GA_plan(300,0.8,0.02,80) pot fi obţinute rezultatele: Durata minimă calculată: 33 Programarea operaţiilor pe maşini (câte 5 operaţii pe fiecare maşină)