álló algoritmusosztályok. Approximációs algoritmusoknak egy olyan algoritmust. Minden algoritmusnak polinomiális idejűnek kell

Hasonló dokumentumok
Általános algoritmustervezési módszerek

Online migrációs ütemezési modellek

Az optimális megoldást adó algoritmusok

Approximációs algoritmusok

Ütemezési feladatok. Az ütemezési feladatok vizsgálata az 50-es évek elején kezdődött, majd

Miskolci Egyetem Gépészmérnöki és Informatikai Kar Informatikai Intézet Alkalmazott Informatikai Intézeti Tanszék

Korlátozás és szétválasztás elve. ADAGOLO adattípus

Gauss-Seidel iteráció

9. előadás. Programozás-elmélet. Programozási tételek Elemi prog. Sorozatszámítás Eldöntés Kiválasztás Lin. keresés Megszámolás Maximum.

1. Online kiszolgálóelhelyezés

Mohó algoritmusok. Példa:

ALGORITMUSOK ÉS BONYOLULTSÁGELMÉLET Matematika MSc hallgatók számára. 11. Előadás

Ütemezési modellek. Az ütemezési problémák osztályozása

1. előadás. Lineáris algebra numerikus módszerei. Hibaszámítás Számábrázolás Kerekítés, levágás Klasszikus hibaanalízis Abszolút hiba Relatív hiba

Diszkrét matematika I.

RSA algoritmus. P(M) = M e mod n. S(C) = C d mod n. A helyesség igazoláshoz szükséges számelméleti háttér. a φ(n) = 1 mod n, a (a 1,a 2,...

1. A k-szerver probléma

Példa Hajtsuk végre az 1 pontból a Dijkstra algoritmust az alábbi gráfra. (A mátrixban a c i j érték az (i, j) él hossza, ha nincs él.

1. Bevezet példák, síbérlés

Nagyságrendek. Kiegészítő anyag az Algoritmuselmélet tárgyhoz. Friedl Katalin BME SZIT február 1.

minden x D esetén, akkor x 0 -at a függvény maximumhelyének mondjuk, f(x 0 )-at pedig az (abszolút) maximumértékének.

Partíció probléma rekurzíómemorizálással

Gauss-Jordan módszer Legkisebb négyzetek módszere, egyenes LNM, polinom LNM, függvény. Lineáris algebra numerikus módszerei

p j p l = m ( p j ) 1

Gyakorlatok. P (n) = P (n 1) + 2P (n 2) + P (n 3) ha n 4, (utolsó lépésként l, hl, u, hu-t léphetünk).

Algoritmuselmélet 18. előadás

Hadamard-mátrixok Előadó: Hajnal Péter február 23.

1/ gyakorlat. Lineáris Programozási feladatok megoldása szimplex módszerrel. Pécsi Tudományegyetem PTI

JAVASLAT A TOP-K ELEMCSERÉK KERESÉSÉRE NAGY ONLINE KÖZÖSSÉGEKBEN

Az B sorozatban a pontok helyes preorder sorrendben vannak. A preorder bejárásban p k -t közvetlenül q m követi.

1/ gyakorlat. Lineáris Programozási feladatok megoldása szimplex módszerrel. Pécsi Tudományegyetem PTI

Algoritmusok bonyolultsága

Diszkrét matematika I.

definiálunk. Legyen egy konfiguráció, ahol és. A következő három esetet különböztetjük meg. 1. Ha, akkor 2. Ha, akkor, ahol, ha, és egyébként.

A sorozat fogalma. függvényeket sorozatoknak nevezzük. Amennyiben az értékkészlet. az értékkészlet a komplex számok halmaza, akkor komplex

út hosszát. Ha a két várost nem köti össze út, akkor legyen c ij = W, ahol W már az előzőekben is alkalmazott megfelelően nagy szám.

Online algoritmusok. Algoritmusok és bonyolultságuk. Horváth Bálint március 30. Horváth Bálint Online algoritmusok március 30.

Edényrendezés. Futási idő: Tegyük fel, hogy m = n, ekkor: legjobb eset Θ(n), legrosszabb eset Θ(n 2 ), átlagos eset Θ(n).

Algoritmusok Tervezése. 6. Előadás Algoritmusok 101 Dr. Bécsi Tamás

First Prev Next Last Go Back Full Screen Close Quit. Matematika I

GRÁFELMÉLET. 7. előadás. Javító utak, javító utak keresése, Edmonds-algoritmus

8. Előadás. Megyesi László: Lineáris algebra, , oldal. 8. előadás Mátrix rangja, Homogén lineáris egyenletrendszer

Bonyolultságelmélet. Monday 26 th September, 2016, 18:28

Programozási módszertan. Mohó algoritmusok

Ellenőrző kérdések. 36. Ha t szintű indexet használunk, mennyi a keresési költség blokkműveletek számában mérve? (1 pont) log 2 (B(I (t) )) + t

i=1 i+3n = n(2n+1). j=1 2 j < 4 2 i+2 16 k, azaz az algoritmus valóban konstans versenyképes.

Függvények növekedési korlátainak jellemzése

KOVÁCS BÉLA, MATEMATIKA I.

Nagy Gábor compalg.inf.elte.hu/ nagy ősz

Algoritmuselmélet. Függvények nagyságrendje, elágazás és korlátozás, dinamikus programozás. Katona Gyula Y.

Formális nyelvek - 9.

1. Alapfogalmak Algoritmus Számítási probléma Specifikáció Algoritmusok futási ideje

Amortizációs költségelemzés

11. Előadás. 11. előadás Bevezetés a lineáris programozásba

Nagy Gábor compalg.inf.elte.hu/ nagy

A számítástudomány alapjai

Diszkrét matematika 1. estis képzés. Komputeralgebra Tanszék ősz

1. feladat Az egyensúly algoritmus viselkedése: Tekintsük a kétdimenziós Euklideszi teret, mint metrikus teret. A pontok

Bonyolultságelmélet. Monday 26 th September, 2016, 18:27. Bonyolultságelmélet

KOVÁCS BÉLA, MATEMATIKA I.

f(x) vagy f(x) a (x x 0 )-t használjuk. lim melyekre Mivel itt ɛ > 0 tetszőlegesen kicsi, így a a = 0, a = a, ami ellentmondás, bizonyítva

Melykeres(G) for(u in V) {szin(u):=feher Apa(u):=0} for(u in V) {if szin(u)=feher then MBejar(u)}

Diszkrét matematika 2.C szakirány

Algoritmuselmélet. Bonyolultságelmélet. Katona Gyula Y.

A 2015/2016. tanévi Országos Középiskolai Tanulmányi Verseny döntő forduló MATEMATIKA III. KATEGÓRIA (a speciális tanterv szerint haladó gimnazisták)

Nagy Gábor compalg.inf.elte.hu/ nagy

19. AZ ÖSSZEHASONLÍTÁSOS RENDEZÉSEK MŰVELETIGÉNYÉNEK ALSÓ KORLÁTJAI

Formális nyelvek - 5.

Brósch Zoltán (Debreceni Egyetem Kossuth Lajos Gyakorló Gimnáziuma) Számelmélet I.

Bonyolultságelmélet. Thursday 1 st December, 2016, 22:21

Számításelmélet. Második előadás

Németh László Matematikaverseny, Hódmezővásárhely március 30. A osztályosok feladatainak javítókulcsa

Más szavakkal formálisan:, ahol olyan egész szám, hogy. Más szavakkal formálisan:, ahol olyan egész szám, hogy.

SHk rövidítéssel fogunk hivatkozni.

HALMAZOK. A racionális számok halmazát olyan számok alkotják, amelyek felírhatók b. jele:. A racionális számok halmazának végtelen sok eleme van.

Ütemezési problémák. Kis Tamás 1. ELTE Problémamegoldó Szeminárium, ősz 1 MTA SZTAKI. valamint ELTE, Operációkutatási Tanszék

Sorozatok, sorok, függvények határértéke és folytonossága Leindler Schipp - Analízis I. könyve + jegyzetek, kidolgozások alapján

Fibonacci számok. Dinamikus programozással

Az online algoritmusok k-szerver probléma

Brósch Zoltán (Debreceni Egyetem Kossuth Lajos Gyakorló Gimnáziuma) Megoldások

A lineáris programozás alapjai

Klasszikus algebra előadás. Waldhauser Tamás április 28.

Számelméleti alapfogalmak

Számjegyes vagy radix rendezés

A lineáris programozás alapfeladata Standard alak Az LP feladat megoldása Az LP megoldása: a szimplex algoritmus 2018/

Optimalizálási eljárások/operációkutatás MSc hallgatók számára

f(x) a (x x 0 )-t használjuk.

A lineáris programozás alapfeladata Standard alak Az LP feladat megoldása Az LP megoldása: a szimplex algoritmus 2017/

Minimális feszítőfák Legyen G = (V,E,c), c : E R + egy súlyozott irányítatlan gráf. Terjesszük ki a súlyfüggvényt a T E élhalmazokra:

A továbbiakban Y = {0, 1}, azaz minden szóhoz egy bináris sorozatot rendelünk

ALAPFOGALMAK 1. A reláció az program programfüggvénye, ha. Azt mondjuk, hogy az feladat szigorúbb, mint az feladat, ha

Turing-gépek. Számításelmélet (7. gyakorlat) Turing-gépek 2009/10 II. félév 1 / 1

11. Előadás. 1. Lineáris egyenlőség feltételek melletti minimalizálás

MATEMATIKA ÉRETTSÉGI TÍPUSFELADATOK MEGOLDÁSAI KÖZÉPSZINT Abszolútértékes és gyökös kifejezések

Branch-and-Bound. 1. Az egészértéketű programozás. a korlátozás és szétválasztás módszere Bevezető Definíció. 11.

Programozás alapjai. 6. gyakorlat Futásidő, rekurzió, feladatmegoldás

További forgalomirányítási és szervezési játékok. 1. Nematomi forgalomirányítási játék

Diszkrét matematika 2.

Nagyordó, Omega, Theta, Kisordó

Átírás:

Approximációs sémák Az approximációs sémák tulajdonképpen approximációs algoritmusokból álló algoritmusosztályok. Approximációs algoritmusoknak egy olyan sorozatát keressük, amely tetszőlegesen kicsi ε esetén tartalmaz 1 + ε approximációs algoritmust. Minden algoritmusnak polinomiális idejűnek kell lennie, de az időigény kiszámítása során a ε értéket konstansként kezeljük. Az időigény és a ε érték kapcsolatától függően az alábbi sémákat definiálhatjuk. Definíció: Algoritmusok egy H ε osztályát polinomiális idejű approximációs sémának nevezzük (polynomial time approximation scheme, PTAS rövidítve), amennyiben minden ε > 0 esetén H ε egy 1 + ε approximációs algoritmus, amely polinomiális időigényű, (az időigény tetszőlegesen függhet a ε konstanstól). Definíció: Amennyiben egy H ε polinomiális idejű approximációs sémára, a H ε algoritmusok időigénye nem csak az input méretében, hanem 1/εban is polinomiális az algoritmusosztályt teljesen polinomiális approximációs sémának nevezzük (fully polynomial time approximation scheme, FPTAS rövidítve). Az approximációs sémák területe igen széles körben vizsgált. Ebben a jegyzetben néhány példán keresztül bemutatjuk az alapvető technikákat, amelyeket ütemezési problémák esetén approximációs sémák kidolgozására alkalmazni szoktak, az érdeklődő olvasó az approximációs sémák területének részletes bemutatását megtalálhatja a [2], [3] munkákban. Approximációs sémák esetén polinomiális idejű algoritmussal szeretnénk kapni egy megoldást. Lényegében az eredeti problémát egyszerűsítjük le úgy, hogy egyrészt az egyszerűsített változat már megoldható legyen, másrészt ne veszítsünk sokat a megoldás pontosságából. Az approximációs algoritmusok általában három osztályba sorolhatóak aszerint, hogy a probléma egyszerűsítését hol hajtjuk végre. Egyszerűsíthetünk, az inputon, az outputon és a megoldást adó algoritmus egyes fázisai között. Elsőként az egyik legegyszerűbb NP-nehéz ütemezési problémára (amelyben két azonos gép van és a maximális befejezési időt minimalizáljuk) mutatunk be három approximációs sémát, mindhárom, a fentiekben említett megközelítésre egyet - egyet, majd egy bonyolultabb eljárást ismertetünk, amely segítségével dinamikus programozási algoritmusokat transzformálhatunk approximációs sémává. 1

Az alábbi három példában jelölje J = {j 1,..., j n } a munkák halmazát, rendre p 1,..., p n a végrehajtási időket, és legyen ε > 0 tetszőleges kicsi szám. Legyen továbbá L = max{max p i, ( n i=1 p i )/2}. Ekkor miként azt az approximációs algoritmusokat tárgyaló fejezetben igazoltuk, két gép esetén L OP T (J) 2L. Inputban egyszerűsítő PTAS a P 2 C max problémára. Az első séma alapgondolata, hogy az apró munkákat nem kezeljük egyenként, hanem olyan tölteléknek tekintjük őket, amelyeknek csak az össztöltése számít. Approximációs séma I. ( A1 ε ) 1. Lépés: Osszuk a munkákat két halmazba! Legyenek az εl/2- nél nem kisebb munkák a nagy munkák, a kisebbek a kicsi munkák. Konstruáljuk a következő J inputot. A nagy munkákat változatlanul hagyjuk, a kicsi munkákat pedig εl/2 nagyságú munkákkal helyettesítjük a következőképpen. Ragasszuk össze az összes kicsi munkát egyetlen óriásmunkába, és az így kapott óriásmunkát szeleteljük fel εl/2 nagyságú darabokra, a maradék εl/2-nél kisebb darabot dobjuk el! Nevezzük ezeket a munkákat gyűjtőmunkáknak! 2. Lépés: Oldjuk meg az I inputra a problémát, az összes lehetséges megoldást megvizsgálva! Mivel az egyes gépeken nem számít a munkák sorrendje, ezért feltehetjük, hogy a kapott optimális megoldásban, mindkét gépen először a régi nagy munkákat hajtjuk végre, utána a gyűjtőmunkákat. Továbbá a gyűjtőmunkák mind εl/2 nagyságú munkák, így feltehetjük, hogy az első gépen a gyűjtőmunkák a felszeletelt óriásmunka kezdőszeletét alkotják, a második gépen a végszeletét. Jelölje ezt az ütemezést S! 3. Lépés: Az S ütemzésből konstruáljuk meg J egy ütemezését! A nagy munkákat ütemezzük ugyanazon a gépen, mint S, a gyűjtőmunkákat pedig bontsuk vissza az eredeti kicsi munkákra, továbbá az óriásmunka konstruálásánál eldobott részt még illesszük a második gép végére! Mivel a gépeken az óriásmunka kezdő illetve végszelete van, ezért a visszabontás során csak a első gép utolsó, és a második gép első gyűjtőmunkájánál keletkezik nem visszabontható, szétvágott kicsi munka. Ezt ütemezzük az első gépen! Tétel A1 ε egy PTAS. Bizonyítás: Vizsgáljuk elsőként a futási időt! Az első és a harmadik lépés nyilvánvalóan polinomiális. A második lépésben az I inputra megvizsgáljuk 2

az összes lehetséges megoldást, ez O(2 n ) lépés, ahol n a munkák száma. Másrészt minden munka legalább εl/2 méretű, a munkák össztöltése az átdarabolás során nem növekedhetett, így a munkák száma legfeljebb 4/ε. Következésképp rögzített konstans ε mellett ezen rész futási ideje konstans. (Érdemes megjegyeznünk, hogy ez a konstans exponenciális 1/ε-ban, ezért nem FPTAS-t kapunk.) Következésképp a futási idő valóban polinomiális az input méretében minden ε-ra. Most vizsgáljuk az approximációs hányadost! Elsőként vegyük észre, hogy OP T (J ) OP T (J) + εl/2. Valóban J egy optimális ütemezésében, a nagy munkákat helyben hagyva, a kicsi munkákat kicserélve annyi εl nagyságú munkával, hogy az össztöltésük ne csökkenjen, egy olyan lehetséges megoldását kapjuk J -nek, amelyre a maximális befejezési idő legfeljebb εl/2-vel növekedett. Másrészt a gyűjtőmunkák szétdarabolása során is legfeljebb εl/2-vel növekszik a maximális befejezési idő, hiszen az első gépen az utolsó kicsi munka másik gyűjtőmunkába eső darabja, a második gépen az óriásmunkából eldobott rész növelheti meg a maximális befejezési időt. Következésképpen A1 ε (J) OP T (J ) + εl OP T (J) + 2εL/2 (1 + ε)op T (J), amivel igazoltuk, hogy a definiált eljárásosztály valóban egy approximációs sémát ad. Outputban egyszerűsítő PTAS a P 2 C max problémára. Az outputban egyszerűsítő sémák alapgondolata általában az, hogy a lehetséges megoldásokat polinomiális számú osztályba osztjuk fel, és minden osztályra alkalmazunk egy gyors algoritmust, amely kijelöl az osztályból egy reprezentánst. Amennyiben minden reprezentáns közel van az osztályba tartozó legjobb lehetséges megoldáshoz, akkor a reprezentánsok közül a legjobb közel lesz az optimális megoldáshoz, így egy jó approximációs algoritmust kapunk. Approximációs séma II. ( A2 ε ) 1. Lépés: Osszuk a munkákat két halmazba! Legyenek az εlnél nem kisebb munkák a nagy munkák, a kisebbek a kicsi munkák! Vegyük a nagy munkák összes lehetséges ütemezését, ezeket nevezzük parciális ütemezéseknek! Minden parciális ütemezésre definiáljuk a lehetséges 3

ütemezéseknek egy osztályát, amely azokat a lehetséges megoldásokat tartalmazza, amelyekben a nagy munkák az adott parciális ütemezésnek megfelelően vannak a gépekhez hozzárendelve! 2. Lépés: Minden osztályra számoljunk ki egy reprezentánst! A reprezentánst úgy kapjuk, hogy a parciális ütemezést kiterjesztjük a kicsi munkákkal, azokat a LISTA algoritmus szerint ütemezve (az aktuális munka arra a gépre kerül, ahol kisebb az aktuális töltés). 3. Lépés: Vegyük a reprezentánsok közül a legkisebb célfügvényértékkel rendelkező megoldást! Tétel A2 ε egy PTAS. Bizonyítás: Vizsgáljuk elsőként a futási időt! Mivel a nagy munkák mérete legalább εl és a munkák össztöltése legfeljebb 2L, ezért a nagy munkák száma legfeljebb 2/ε. Következésképpen a parciális ütemezések, és így az osztályok száma legfeljebb 2 2/ε. Minden osztályra a reprezentáns kijelölése lineáris időben fut, így rögzített ε mellett az algoritmus futási ideje valóban polinomiális. (Fontos megjegyeznünk, hogy 1/ε-ban exponenciális, így ismét csak PTAS-t kapunk.) Vizsgáljuk most az approximációs hányadost! Különböztessünk meg két esetet attól függően, hogy milyen reprezentánsokat kaptunk! Elsőként tegyük fel, hogy van olyan reprezentáns, amelyben egy kicsi munka éri el a maximális befejezési időt. Ez akkor fordul elő ha mindkét gépre kerül kicsi munka vagy ha csak a parciális ütemezésben kisebb töltésűre, de az utolsó kicsi munkával a töltés túlnő a parciális ütemezésben nagyobb töltésű gép töltésén. Mindkét esetben ezen reprezentánsra a gépeken a befejezési idők (esetünkben megegyeznek a töltéssel) különbsége legfeljebb εl. Másrészt az össztöltés legfeljebb 2L, így azt kaptuk, hogy A2 ε (J) L + ε L (1 + ε/2)op T (J). 2 A második esetben nincs olyan reprezentáns, amelyben kicsi munka éri el a maximális befejezési időt. Ez azt jelenti, hogy minden osztályra a reprezentáns optimális megoldást ad, hiszen a költség megegyezik a parciális ütemezés költségével. Másrészt ebből következik, hogy a reprezentánsok között szerepel egy optimális megoldás is. 4

Algoritmusban egyszerűsítő FPTAS a P 2 C max problémára. Ezt a megközelítést akkor szokás használni, ha van a problémára egy exponenciális megoldó algoritmusunk, amely több fázisból áll. Ekkor bizonyos esetekben az egyes fázisok közé valamilyen egyszerűsítő lépést beiktatva egy approximációs sémát kaphatunk. Elsőként tekintsük a következő egyszerű algoritmust, amely meghatározza az összes (a, b) párt, amelyek előállhatnak a töltésként a két gépen a J munkahalmaz ütemezése után! Egy exponenciális idejű algoritmus 1. Lépés: Legyen i = 0, S 0 =! 2. Lépés: Amennyiben i = n véget ért az eljárás, egyébként minden (a, b) S i párra képezzük az (a + p i+1, b) és (a, b + p i+1 ) párokat, és ezen párok alkossák az S i+1 halmazt! Egyszerűen igazolható teljes indukcióval, hogy az S i halmaz minden i-re azokat az (a, b) párokat tartalmazza, amelyek előállhatnak töltésként a két gépen a J munkahalmaz első i elemének az ütemezése után. Következésképp kiválasztva az S n halmazból azt a párt, amelyre az elemek maximuma a minimális megkapjuk az optimális célfüggvényértéket. Amennyiben a párokat kiegészítjük azzal (a dinamikus programozási algoritmusok esetén szokásos) információval, hogy miként kaptuk meg a párt a megelőzőből (ez egy extra bit, amely megadja, hogy az utolsó munkát melyik géphez rendeltük), akkor megkapjuk az optimális megoldást is. Tehát a fenti algoritmus alapján megkaphatjuk az optimális ütemezést. Az egyetlen probléma az, hogy az S i halmazok elemszáma rendkívül gyorsan növekedhet, elérheti a 2 i értéket. Amennyiben ezt az elemszámot korlátozni tudjuk, akkor egy polinomiális algoritmust kapunk. Az alábbiakban megvizsgáljuk miként tehetjük ezt meg oly módon, hogy ne veszítsünk sokat a pontosságból. A továbbiakban feltesszük, hogy a munkák végrehajtási idejei egészek, így minden végrehajtási idő legalább 1. Legyen = 1+ε/(2n), P = n i=1 p i! Osszuk fel a síkban a P P nagyságú négyzetet tartományokra! A P jk, j 1, k 1 tartomány tartalmazza azokat az (a, b) pontokat, amelyekre j a j+1, k b k+1 teljesül! A P 0k, k 1 tartomány tartalmazza azokat az (a, b) pontokat, amelyekre 0 a, k b k+1 teljesül! A P j0, j 1 tartomány tartalmazza azokat az (a, b) pontokat, amelyekre j a j+1, 0 b teljesül! A P 00 tartomány tartalmazza azokat az (a, b) pontokat, amelyekre 5

0 a, 0 b teljesül! Az approximációs séma alapgondolata, hogy az ugyanazon tartományba eső pontpárok közel vannak egymáshoz, így elég mindegyik tartományból egy pontot megőrizni az S i halmazokban. Approximációs séma III. ( A3 ε ) 1. Lépés: Legyen i = 0, S 0 =! 2. Lépés: Amennyiben i = n véget ért az eljárás, egyébként minden (a, b) S i párra képezzük az (a + p i+1, b) és (a, b + p i+1 ) párokat, és ezen párok alkossák az S i+1 halmazt! 3. Lépés (ritkítás) Az S i+1 azon elemeinek halmazát, amelyben egyik érték sem 0 ritkítsuk úgy, hogy minden P jk tartományból csak egy elemet tartsunk meg! Tétel A3 ε egy FPTAS-t ad az optimális célfüggvényérték meghatározására. Bizonyítás: Vizsgáljuk elsőként a futási időt! Ehhez össze kell számolnunk a tartományok számát. A defincióból egyből adódik, hogy a tartományok száma legfeljebb (log P + 1) 2 = O((log P ) 2 ). Másrészt log P = lnp ln. Továbbá ln = ln(1 + ε/(2n)) = Ω(ε/n), amiből adódik, hogy a tartományok száma polinomiális n-ben 1/ε-ban és lnp -ben, azaz az input méretében és 1/ε-ban. Ebből következik, hogy az algoritmus is polinomiális ezekben az értékekben, azaz futási idő szempontjábol valóban egy FPTAS-t adtunk meg. Vizsgáljuk az approximációs hányadost! Minden iterációban van egy ritkító fázis. A ritkító részben minden párhoz egy olyan párt őrzünk meg, amely ugyanabban a tartományban van, így mindkét komponensben a megfelelő érték legfeljebb egy multiplikatív hibában tér el. Következésképp minden lehetséges ütemezést leíró párhoz van az S n halmazban egy olyan pár, amely legfeljebb egy n multiplikatív hibában tér el. Tehát az algoritmus n approximációs. Másrészt egyszerűen adódik az (1+1/n) n e egyenlőtlenség alapján, hogy amivel az állítást igazoltuk. n = (1 + ε/2n) n 1 + ε, 6

A fenti eljárás könnyen módosítható úgy, hogy az optimális ütemezést is megkapjuk. Számhármasokat kell használnunk, ahol a harmadik komponens attól függ, hogy az utolsó munkát melyik gépen ütemeztük a töltéseket eredményező ütemezésben. Ebben az esetben az optimális (approximációs) számhármasból visszafejthető egy optimális (approximációs) ütemezés. Dinamikus programozáson alapuló FPTAS a P m C max problémára. Ebben a részben arra mutatunk példát miként transzformálhatóak bizonyos dinamikus programozási algoritmusok FPTAS-á. Az FPTAS alapötlete az, hogy az inputot kerekítjük, az így kapott új inputra végrehajtjuk a dinamikus programozási eljárást, amely a kerekített inputra polinomiális idejű lesz, és a kapott optimális megoldást visszatranszformáljuk az eredeti feladat egy lehetséges megoldásává. Tehát az alábbi algoritmus is az inputban egyszerűsítő algoritmusok családjába tartozik. A bemutatott algoritmus lényegében megegyezik a [1] cikkben ismertetett eljárással. Használjuk a dinamikus programozási részben ismertetett dinamikus programozási algoritmust, a követhetőség érdekében iott ismét ismertetjük az eljárást. Dinamikus programozási eljárás a P m C max problémára egész ütemezési dők mellett Legyen P = n j=1 p j! Definiáljuk az S i (K 1,..., K m 1 ), értékeket i = 0, 1,..., n a következőképpen! Legyen S i (K 1,..., K m 1 ) az a minimális töltés, amely elérhető az M m gépen az első i munka ütemezése során olyan ütemezéssel, amelyben az M j gépen a töltés legfeljebb K i minden j = 1,..., m 1-re. A függvény definíciója alapján adódik, hogy S i (K 1,..., K m 1 ) =, ha K j < 0 valamely j-re, hiszen ekkor nincs a j-edik gép töltésére vonatkozó feltételt kielégítő ütemezés. Továbbá S 0 (K 1,..., K m 1 ) = 0 minden 0 K j P értékre. Egyszerű esetszétválasztás alapján adódik, hogy az S i függvényekre teljesül a következő rekurzió: ahol S i+1 (K 1,..., K m 1 ) = min{p i+1 + S i (K 1,..., K m 1 ), MIN}, MIN = min j {S i (K 1,..., K j 1, K j p i+1, K j+1,..., K m 1 }. A fenti észrevételek alapján könnyű felépíteni egy dinamikus programozási algoritmust, amely megoldja a P m C max problémát egész ütemezési 7

idők mellett. A kezdeti feltételek és a rekurzió alapján kiszámoljuk az S n (K 1,..., K m 1 ) értékeket, minden egész 0 K j P, j = 1,..., m 1 értékre. Ezt követően az optimális célfüggvényérték a minimális max{s n (K 1,..., K m 1 ), max 1 j m 1 K j } érték lesz. Másrészt ha az eljárás során (mint az dinamikus programozási algoritmusoknál szokásos) mindig megjegyezzük, hogy az aktuális S i+1 függvényértéket melyik S i érték alapján kapjuk, akkor az optimális célfüggvényértéket adó S n érték alapján visszafejthető az optimális ütemezés. Tehát a fentiekben bemutatott algoritmus megoldja a problémát. Vizsgáljuk a futási időt. Az eljárás során lényegében ki kell töltenünk n darab P m 1 méretű táblázatot (a lehetséges K 1,..., K m 1 értékek), minden érték kiszámítása m műveletet igényel, tehát a futási idő O(nmP m 1 ), azaz rögzített m mellett polinomiális n-ben és P = n j=1 p j -ben. A probléma az, hogy az input mérete nem P, hanem log P, mivel binárisan reprezentáljuk a számokat. Unáris reprezentálás mellett az algoritmus polinomiális lenne. (Érdemes megjegyeznünk, hogy az ilyen algoritmusokat pszeudopolinomiális algoritmusoknak nevezzük.) Az alábbiakban bemutatjuk miként konstruálható egy FPTAS a fentiekben bemutatott dinamikus programozási eljárás alapján. FPTAS a dinamikus programozási eljárás alapján Az FPTAS előkészítő részeként hajtsunk végre egy konstans approximációs hányadossal rendelkező approximációs eljárást az inputon. A kapott célfüggvényértéket jelölje L. Esetünkben használhatjuk a LISTA algoritmust, amely lineáris időigényű. Ekkor az L számra teljesül az OP T (J) L 2OP T (J) egyenlőtlenség. Approximációs séma IV. ( A4 ε ) 1. lépés: Konstruáljuk meg a J inputból J inputot a következőképpen! Minden j-re a p j végrehajtási idővel rendelkező j-edik munkát helyettesítsük egy p j = p j /Z végrehajtási idővel rendelkező munkával, ahol Z = εl/2n! 2. lépés: Oldjuk meg az 1. lépés során kapott J inputot a fentiekben ismertetett dinamikus programozási eljárással! 3. lépés: A J input optimális ütemezéséből J egy közelítő megoldását kapjuk, ha minden munkát ugyanazon a gépen ütemezünk, amelyen a módósított input optimális megoldása a megfelelő módosított munkát ütemezi. Tétel A4 ε egy FPTAS. 8

Bizonyítás: Elsőként vizsgáljuk a futási időt! A dinamikus programozási algoritmus időigénye O(nmP m 1 ). A módosított J inputra n n P p j /Z p j /Z mop T (J)/Z = j=1 j=1 mop T (J) εl/2n 4mn/ε. Következésképp az eljárás időigénye rögzített m mellett valóban polinomiális az input méretében és 1/ε-ban. Vizsgáljuk meg az approximációs hányadost! Mivel Z OP T (J ) OP T (J) és A4 ε (J) Z OP T (J) + nz, ezért A4 ε (J) OP T (J) nz. Következésképpen: A4 ε (J) OP T (J) OP T (J) nz OP T (J εl 2OP T (I) ε. References [1] E. Horowitz, S. Sahni: Exact and approximate algorithms for scheduling non identical processors, Journal of the ACM, 23, 317 327, 1976. [2] P. Schuurman, G. J. Woeginger, Approximation Schemes - A Tutorial, megjelenés alatt (elérhető Woeginger weboldaláról) [3] V. Vazirani Approximation Algorithms, Springer-Verlag, Berlin, 2001 9