Křížový algoritmus - Criss-cross algorithm

Trojrozměrná kostka
Křížový algoritmus navštíví všech 8 rohů Klee – Minty kostka v nejhorším případě. V průměru navštíví 3 další rohy. Klee-Mintyova kostka je narušení zde zobrazené krychle.

v matematická optimalizace, křížový algoritmus je někdo z rodiny algoritmy pro lineární programování. Varianty křížového algoritmu také řeší obecnější problémy s omezení lineární nerovnosti a nelineární objektivní funkce; existují křížové algoritmy pro lineární-zlomkové programování problémy,[1][2] kvadratické programování problémy a problémy lineární komplementarity.[3]

Jako simplexní algoritmus z George B. Dantzig, křížový algoritmus není a algoritmus polynomiálního času pro lineární programování. Oba algoritmy navštíví všechny 2D rohy (rozrušený) krychle v rozměruD, Klee – Minty kostka (po Victor Klee a George J. Minty ), v nejhorší případ.[4][5] Když je však spuštěn v náhodném rohu, křížový algoritmus v průměru pouze návštěvyD další rohy.[6][7][8] U trojrozměrné krychle tedy algoritmus v nejhorším případě navštíví všech 8 rohů a v průměru přesně 3 další rohy.

Dějiny

Algoritmus křížení byl publikován nezávisle uživatelem Tamas Terlaky[9] a Zhe-Min Wang;[10] související algoritmy se objevily v nepublikovaných zprávách jiných autorů.[3]

Srovnání s simplexním algoritmem pro lineární optimalizaci

Ve své druhé fázi simplexní algoritmus plazí se po okrajích mnohostěnu, až nakonec dosáhne optima vrchol. The křížový algoritmus bere v úvahu základy, které nejsou spojeny s vrcholy, takže některé iterace mohou být v interiér proveditelné oblasti, jako jsou algoritmy vnitřních bodů; křížový algoritmus může také mít nemožné iteruje mimo proveditelný region.

V lineárním programování se křížový algoritmus otáčí mezi řadou bází, ale liší se od simplexní algoritmus z George Dantzig. Algoritmus simplexu nejprve najde (prvotní) proveditelný základ řešením „fáze jedna problém "; ve" fázi dvě "se simplexní algoritmus otáčí mezi posloupností základních proveditelný řešení tak, aby objektivní funkce neklesala s každým otočným čepem, končící optimálním řešením (také konečně nalezení „duálního“ řešení).[3][11]

Křížový algoritmus je jednodušší než simplexní algoritmus, protože křížový algoritmus má pouze jednu fázi. Jeho pravidla otáčení jsou podobná pravidlům Blandovo pravidlo otočení s nejmenším indexem.[12] Blandovo pravidlo používá pouze znamení spíše než jejich koeficientů (reálné číslo) objednávka při rozhodování o vhodných otočných čepech. Blandovo pravidlo vybírá vstupující proměnné porovnáním hodnot snížených nákladů pomocí uspořádání způsobilých otočných bodů v reálném čísle.[12][13] Na rozdíl od Blandova pravidla je křížový algoritmus „čistě kombinatorický“, přičemž se vybírá vstupní proměnná a opouštějící proměnná tím, že se berou v úvahu pouze znaky koeficientů, nikoli jejich pořadí v reálném čísle.[3][11] Křížový křížový algoritmus byl použit k poskytnutí konstruktivních důkazů základních výsledků v nemovitý lineární algebra, tak jako Farkasovo lema.[14]

Zatímco většina simplexních variant je v objektivu monotónních (striktně v nedegenerovaném případě), většině variant křížového algoritmu chybí monotónní záslužná funkce, což může být v praxi nevýhodou.

Popis

Algoritmus křížení funguje na standardním pivotním tablo (nebo za běhu vypočítané části tabla, pokud jsou implementovány jako revidovaná simplexní metoda). V obecném kroku, pokud je tablo primitivní nebo dvojité, je možné vybrat jeden z neproveditelných řádků / sloupců jako kontingenční řádek / sloupec pomocí pravidla výběru indexu. Důležitou vlastností je, že výběr se provádí na sjednocení neproveditelných indexů a standardní verze algoritmu nerozlišuje indexy sloupců a řádků (tj. Indexy sloupců základní v řádcích). Pokud je vybrán řádek, pak algoritmus použije pravidlo pro výběr indexu k identifikaci polohy na pivot dvojitého typu, zatímco pokud je vybrán sloupec, použije pravidlo pro výběr indexu k vyhledání pozice řádku a provede pivot primárního typu.

Výpočetní složitost: Nejhorší a průměrné případy

Nejhorší výpočetní složitost Khachiyanovy elipsoidní algoritmus je polynom. The křížový algoritmus má exponenciální složitost.

The časová složitost z algoritmus počítá počet aritmetické operace dostačující pro algoritmus k vyřešení problému. Například, Gaussova eliminace vyžaduje na řád D3 operace, a tak se říká, že má polynomiální časovou složitost, protože její složitost je ohraničena a kubický polynom. Existují příklady algoritmů, které nemají polynomiálně-časovou složitost. Například se nazývá generalizace Gaussovské eliminace Buchbergerův algoritmus má pro svou složitost exponenciální funkci problémových dat ( stupeň polynomů a počet proměnných vícerozměrné polynomy ). Protože exponenciální funkce nakonec rostou mnohem rychleji než polynomiální funkce, exponenciální složitost znamená, že algoritmus má při velkých problémech pomalý výkon.

Několik algoritmů pro lineární programování—Khachiyan je elipsoidní algoritmus, Karmarkar je projektivní algoritmus, a algoritmy centrální cesty —Mají polynomiální časovou složitost (v nejhorší případ a tudíž v průměru ). Elipsoidní a projektivní algoritmy byly publikovány před křížovým algoritmem.

Stejně jako Dantzigův simplexní algoritmus je však křížový algoritmus ne algoritmus polynomiálního času pro lineární programování. Terlakyho křížový algoritmus navštěvuje všechny 2D rohy (narušené) krychle v rozměruD, podle článku Roos; Roosův článek upravuje Klee –Minty konstrukce a krychle na kterém simplexní algoritmus trvá 2D kroky.[3][4][5] Stejně jako simplexní algoritmus, i křížový algoritmus v nejhorším případě navštíví všech 8 rohů trojrozměrné krychle.

Když je inicializován v náhodném rohu krychle, křížový algoritmus navštíví pouzeD další rohy, nicméně, podle 1994 papíru Fukuda a Namiki.[6][7] Triviálně jednostranný algoritmus trvá v průměruD kroky pro krychli.[8][15] Stejně jako simplexní algoritmus, i křížový algoritmus navštěvuje v průměru přesně 3 další rohy trojrozměrné krychle.

Varianty

Křížový algoritmus byl rozšířen tak, aby řešil obecnější problémy než problémy lineárního programování.

Další optimalizační problémy s lineárními omezeními

Existují varianty křížového algoritmu pro lineární programování pro kvadratické programování a pro problém lineární komplementarity s „dostatečným počtem matic“;[3][6][16][17][18][19] naopak, u problémů lineární komplementarity se algoritmus křížového přechodu definitivně ukončí, pouze pokud je matice dostatečnou maticí.[18][19] A dostatečná matice je zobecnění a pozitivně definitivní matice a P-matice, jehož hlavní nezletilí jsou každý pozitivní.[18][19][20] Křížový algoritmus byl upraven také pro lineární-zlomkové programování.[1][2]

Výčet vrcholů

Algoritmus křížení byl použit v algoritmu pro výčet všech vrcholů mnohostěnu, kterou vydalo David Avis a Komei Fukuda v roce 1992.[21] Avis a Fukuda představili algoritmus, který najdeproti vrcholy a mnohostěn definované nedegenerovaným systémemn lineární nerovnosti vD rozměry (nebo, duálně,proti fazety z konvexní obal zn body vD rozměry, kde každá fazeta obsahuje přesněD dané body) v časeÓ (nDv) a O (nD) prostor.[22]

Orientované matroidy

The věta o maximálním toku o minimálním řezu uvádí, že maximální průtok sítí je přesně kapacita jeho minimálního snížení. Tuto větu lze dokázat pomocí křížového algoritmu pro orientované matroidy.

Křížový algoritmus je často studován pomocí teorie orientované matroidy (OMs), což je a kombinační abstrakce teorie lineární optimalizace.[17][23] Ve skutečnosti bylo Blandovo otočné pravidlo založeno na jeho předchozích dokumentech o teorii orientovaných matroidů. Blandovo pravidlo však vykazuje cyklování na některých problémech lineárního programování s orientovaným matroidem.[17] První čistě kombinatorický algoritmus pro lineární programování byl vytvořen pomocí Michael J. Todd.[17][24] Toddův algoritmus byl vyvinut nejen pro lineární programování v nastavení orientovaných matroidů, ale také pro problémy s kvadratickým programováním a problémy lineární komplementarity.[17][24] Toddův algoritmus je bohužel dokonce komplikovaný, a jeho důkazy o konečné konvergenci jsou poněkud komplikované.[17]

Křížový algoritmus a jeho důkaz konečného ukončení lze jednoduše určit a snadno rozšířit nastavení orientovaných matroidů. Algoritmus lze dále zjednodušit lineární problémy proveditelnosti, to je pro lineární systémy s nezáporné proměnné; tyto problémy lze formulovat pro orientované matroidy.[14] Algoritmus křížení byl upraven pro problémy, které jsou složitější než lineární programování: Existují varianty orientovaných matroidů také pro problém kvadratického programování a pro problém lineární komplementarity.[3][16][17]

souhrn

Křížový algoritmus je jednoduše uvedený algoritmus pro lineární programování. Byl to druhý plně kombinatorický algoritmus pro lineární programování. Částečně kombinatorický simplexní algoritmus Blandových cyklů na některých (nerealizovatelných) orientovaných matroidech. První plně kombinatorický algoritmus publikoval Todd a je také jako simplexní algoritmus v tom, že zachovává proveditelnost po vygenerování prvního proveditelného základu; Toddova vláda je však komplikovaná. Křížový algoritmus není simplexní algoritmus, protože nemusí udržovat proveditelnost. Křížový algoritmus však nemá polynomiální časovou složitost.

Vědci rozšířili křížový algoritmus o mnoho optimalizačních problémů, včetně lineárního zlomkového programování. Křížový algoritmus může vyřešit problémy s kvadratickým programováním a problémy s lineární komplementaritou, a to i v nastavení orientovaných matroidů. I když je zobecněný, algoritmus křížového přechodu zůstává jednoduše uveden.

Viz také

  • Jack Edmonds (průkopník kombinatorické optimalizace a teoretik orientovaného matroidu; doktorský poradce Komei Fukuda)

Poznámky

  1. ^ A b Illés, Szirmai a Terlaky (1999)
  2. ^ A b Stancu-Minasian, I. M. (srpen 2006). "Šestá bibliografie částečného programování". Optimalizace. 55 (4): 405–428. doi:10.1080/02331930600819613. PAN  2258634.
  3. ^ A b C d E F G Fukuda & Terlaky (1997)
  4. ^ A b Roos (1990)
  5. ^ A b Klee, Victor; Minty, George J. (1972). "Jak dobrý je simplexní algoritmus?". V Shisha, Oved (ed.). Nerovnosti III (Proceedings of the Third Symposium on Nerovnosti konané na University of California, Los Angeles, Kalifornie, 1. - 9. září 1969, věnovaná památce Theodora S. Motzkina). New York-Londýn: Academic Press. str. 159–175. PAN  0332165.CS1 maint: ref = harv (odkaz)
  6. ^ A b C Fukuda & Terlaky (1997, str. 385)
  7. ^ A b Fukuda a Namiki (1994, str. 367)
  8. ^ A b Simplexový algoritmus trvá průměrněD kroky pro krychli. Borgwardt (1987): Borgwardt, Karl-Heinz (1987). Metoda simplex: Pravděpodobnostní analýza. Algoritmy a kombinatorika (studijní a výzkumné texty). 1. Berlín: Springer-Verlag. str. xii + 268. ISBN  978-3-540-17096-9. PAN  0868467.CS1 maint: ref = harv (odkaz)
  9. ^ Terlaky (1985) a Terlaky (1987)
  10. ^ Wang (1987)
  11. ^ A b Terlaky & Zhang (1993)
  12. ^ A b Bland, Robert G. (květen 1977). Msgstr "Nová pravidla konečného otočení pro simplexní metodu". Matematika operačního výzkumu. 2 (2): 103–107. doi:10,1287 / bř. 2.2.23. JSTOR  3689647. PAN  0459599.CS1 maint: ref = harv (odkaz)
  13. ^ Blandovo pravidlo souvisí také s dřívějším pravidlem nejnižšího indexu, které navrhla Katta G. Murtyová pro problém lineární komplementarity, podle Fukuda a Namiki (1994).
  14. ^ A b Klafszky & Terlaky (1991)
  15. ^ Obecněji řečeno, pro simplexní algoritmus je očekávaný počet kroků úměrnýD pro problémy lineárního programování, které jsou náhodně čerpány z Euklidovský jednotková koule, jak dokazují Borgwardt a Smale.
  16. ^ A b Fukuda a Namiki (1994)
  17. ^ A b C d E F G Björner, Anders; Las Vergnas, Michel; Sturmfels, Bernd; White, Neil; Ziegler, Günter (1999). "10 Lineární programování". Orientované matroidy. Cambridge University Press. 417–479. doi:10.1017 / CBO9780511586507. ISBN  978-0-521-77750-6. PAN  1744046.
  18. ^ A b C den Hertog, D .; Roos, C .; Terlaky, T. (1. července 1993). „Problém lineární komplementarity, dostatek matic a křížová metoda“ (PDF). Lineární algebra a její aplikace. 187: 1–14. doi:10.1016/0024-3795(93)90124-7.
  19. ^ A b C Csizmadia, Zsolt; Illés, Tibor (2006). „Nové křížové algoritmy pro problémy lineární komplementarity s dostatečnými maticemi“ (pdf). Optimalizační metody a software. 21 (2): 247–266. doi:10.1080/10556780500095009. PAN  2195759.
  20. ^ Cottle, R. W.; Pang, J.-S .; Venkateswaran, V. (březen – duben 1989). "Dostatečné matice a problém lineární komplementarity". Lineární algebra a její aplikace. 114–115: 231–249. doi:10.1016/0024-3795(89)90463-1. PAN  0986877.
  21. ^ Avis & Fukuda (1992, str. 297)
  22. ^ Theproti vrcholy v jednoduchém uspořádánín hyperplanes vD rozměry najdete v O (n2Dv) čas a O (nD) složitost prostoru.
  23. ^ Teorie orientované matroidy byl zahájen uživatelem R. Tyrrell Rockafellar. (Rockafellar 1969 ):

    Rockafellar, R. T. (1969). "Elementární vektory podprostoru o (1967)" (PDF). v R. C. Bose a T. A. Dowling (ed.). Kombinatorická matematika a její aplikace. The University of North Carolina Monograph Series in Probability and Statistics. Chapel Hill, Severní Karolína: University of North Carolina Press. str. 104–127. PAN  0278972. Dotisk PDF.

    Rockafellar byl ovlivněn dřívějšími studiemi o Albert W. Tucker a George J. Minty. Tucker a Minty studovali znaménkové vzorce matic vznikající otočnými operacemi Dantzigova simplexního algoritmu.

  24. ^ A b Todd, Michael J. (1985). "Lineární a kvadratické programování v orientovaných matroidech". Journal of Combinatorial Theory. Řada B. 39 (2): 105–133. doi:10.1016/0095-8956(85)90042-5. PAN  0811116.

Reference

externí odkazy