Model rozhodovacího stromu - Decision tree model - Wikipedia
v výpočetní složitost the model rozhodovacího stromu je model výpočtu ve kterém je algoritmus považován v zásadě za rozhodovací strom posloupnost dotazy nebo testy které se provádějí adaptivně, takže výsledek předchozích testů může ovlivnit test, který se provede dále.
Tyto testy mají obvykle malý počet výstupů (například otázku ano-ne) a lze je provést rychle (řekněme s jednotkovými výpočetními náklady), takže nejhorší časová složitost algoritmu v modelu rozhodovacího stromu odpovídá hloubku odpovídajícího rozhodovacího stromu. Tento pojem výpočetní složitosti problému nebo algoritmu v modelu rozhodovacího stromu se nazývá jeho složitost rozhodovacího stromu nebo složitost dotazu.
Při vytváření jsou rozhodující modely rozhodovacích stromů dolní hranice pro teorie složitosti pro určité třídy výpočetních problémů a algoritmů. Bylo zavedeno několik variant modelů rozhodovacích stromů, v závislosti na výpočetní model a typ dotazovacích algoritmů je povoleno provádět.
Například argument rozhodovacího stromu se používá k označení, že a porovnání řazení z položky musí vzít srovnání. Pro srovnávací druhy je dotaz porovnáním dvou položek , se dvěma výsledky (za předpokladu, že žádné položky nejsou stejné): buď nebo . Srovnávací druhy lze v tomto modelu vyjádřit jako rozhodovací strom, protože takové třídicí algoritmy provádějí pouze tyto typy dotazů.
Srovnání stromů a dolních mezí pro třídění
Rozhodovací stromy se často používají k pochopení algoritmů pro třídění a dalších podobných problémů; toto poprvé provedli Ford a Johnson.[1]
Například mnoho třídicích algoritmů je druhy porovnání, což znamená, že získávají pouze informace o vstupní sekvenci prostřednictvím místních srovnání: testování zda , nebo . Za předpokladu, že položky, které mají být tříděny, jsou odlišné a srovnatelné, lze to přeformulovat jako otázku ano-ne-ne: je ?
Tyto algoritmy lze modelovat jako binární rozhodovací stromy, kde jsou dotazy srovnáním: interní uzel odpovídá dotazu a podřízené uzly odpovídají dalšímu dotazu, když je odpověď na otázku ano nebo ne. U listových uzlů odpovídá výstup a permutace který popisuje, jak byla vstupní sekvence zakódována z plně seřazeného seznamu položek. (Opak této permutace, , znovu objedná vstupní sekvenci.)
Lze ukázat, že je nutné použít druhy porovnání srovnání pomocí jednoduchého argumentu: aby byl algoritmus správný, musí být schopen generovat každou možnou permutaci elementy; jinak by algoritmus pro danou permutaci jako vstup selhal. Jeho odpovídající rozhodovací strom tedy musí mít alespoň tolik listů jako permutací: listy. Libovolný binární strom s minimem listy mají alespoň hloubku , jedná se tedy o spodní hranici doby běhu srovnávacího třídicího algoritmu. V tomto případě existence mnoha algoritmů pro porovnání porovnání, které mají tuto časovou složitost, například Sloučit třídění a heapsort, ukazuje, že svazek je těsný.[2]:91
Tento argument nepoužívá nic o typu dotazu, takže ve skutečnosti prokazuje dolní mez pro jakýkoli třídicí algoritmus, který lze modelovat jako binární rozhodovací strom. V podstatě se jedná o přeformulování informační-teoretický argument že správný třídicí algoritmus se musí alespoň naučit bity informací o vstupní posloupnosti. Ve výsledku to funguje také pro randomizované rozhodovací stromy.
Ostatní dolní hranice rozhodovacího stromu používají, že dotaz je srovnání. Zvažte například úkol pouze pomocí porovnání najít nejmenší číslo mezi čísla. Než bude možné určit nejmenší číslo, musí se každé číslo kromě nejmenšího „ztratit“ (porovnat větší) alespoň v jednom srovnání. Takže to trvá minimálně srovnání k nalezení minima. (Informační-teoretický argument zde udává pouze dolní mez .) Podobný argument funguje pro obecné dolní meze pro výpočet statistika objednávek.[2]:214
Lineární a algebraické rozhodovací stromy
Lineární rozhodovací stromy zobecňují výše uvedené srovnávací rozhodovací stromy na výpočetní funkce, které jsou skutečné vektory jako vstup. Testy v lineárních rozhodovacích stromech jsou lineární funkce: pro konkrétní výběr reálných čísel , výstup znaménko . (Algoritmy v tomto modelu mohou záviset pouze na znaménku výstupu.) Srovnávací stromy jsou lineární rozhodovací stromy, protože srovnání mezi a odpovídá lineární funkci . Ze své definice mohou lineární rozhodovací stromy specifikovat pouze funkce jehož vlákna lze sestrojit spojením a průsečíky poloprostorů.
Algebraické rozhodovací stromy jsou zobecněním lineárních rozhodovacích stromů, které umožňují, aby testovací funkce byly polynomy stupně . Geometricky je prostor rozdělen na semi-algebraické množiny (zobecnění nadroviny).
Tyto modely rozhodovacích stromů, definované Rabinem[3] a Reingold,[4] se často používají k prokázání dolních mezí v výpočetní geometrie.[5] Například Ben-Or ukázal jedinečnost tohoto prvku (výpočetní úloha , kde je 0 právě tehdy, pokud existují odlišné souřadnice takhle ) vyžaduje algebraický rozhodovací strom hloubky .[6] To bylo poprvé ukázáno pro lineární rozhodovací modely Dobkinem a Liptonem.[7] Ukazují také a dolní mez pro lineární rozhodovací stromy o problému batohu, zobecněnou na algebraické rozhodovací stromy Steele a Yao.[8]
Složitost logického rozhodovacího stromu
U booleovských rozhodovacích stromů je úkolem vypočítat hodnotu n-bitu Booleovská funkce pro vstup . Dotazy odpovídají přečtení trochu vstupu, a výstup je . Každý dotaz může záviset na předchozích dotazech. Existuje mnoho typů výpočetních modelů využívajících rozhodovací stromy, které by bylo možné vzít v úvahu, a které připouštějí několik pojmů složitosti, tzv opatření složitosti.
Deterministický rozhodovací strom
Pokud je výstup rozhodovacího stromu , pro všechny , říká se, že rozhodovací strom „počítá“ . Hloubka stromu je maximální počet dotazů, které se mohou stát před dosažením listu a dosažením výsledku. , deterministický rozhodovací strom složitost je nejmenší hloubka mezi všemi deterministickými rozhodovacími stromy, které se počítají .
Randomizovaný rozhodovací strom
Jedním ze způsobů, jak definovat a randomizovaný rozhodovací strom je přidat do stromu další uzly, z nichž každý je řízen pravděpodobností . Další ekvivalentní definice je definovat jako distribuci přes deterministické rozhodovací stromy. Na základě této druhé definice je složitost randomizovaného stromu definována jako největší hloubka mezi všemi stromy na podporu podkladové distribuce. je definována jako složitost randomizovaného rozhodovacího stromu s nejnižší hloubkou, jehož výsledkem je alespoň s pravděpodobností pro všechny (tj. s ohraničenou oboustrannou chybou).
je známý jako Monte Carlo složitost randomizovaného rozhodovacího stromu, protože výsledek může být nesprávný s ohraničenou oboustrannou chybou. The Las Vegas složitost rozhodovacího stromu měří očekávaný hloubka rozhodovacího stromu, který musí být správný (tj. má nulovou chybu). K dispozici je také jednostranná verze s omezenou chybou, která je označena .
Nedeterministický rozhodovací strom
Nedeterministická složitost rozhodovacího stromu funkce je známá častěji jako složitost certifikátu této funkce. Měří počet vstupních bitů, které a nedeterministický algoritmus by bylo potřeba se podívat, aby bylo možné vyhodnotit funkci s jistotou.
Formálně je složitost certifikátu na je velikost nejmenší podmnožiny indexů takové, že pro všechny , pokud pro všechny , pak . Složitost certifikátu je maximální složitost certifikátu Označuje se analogická představa, kde se vyžaduje pouze správnost ověřovatele s pravděpodobností 2/3 .
Kvantový rozhodovací strom
Složitost kvantového rozhodovacího stromu je hloubka kvantového rozhodovacího stromu s nejnižší hloubkou, která dává výsledek alespoň s pravděpodobností pro všechny . Další množství, , je definována jako hloubka kvantového rozhodovacího stromu s nejnižší hloubkou, který dává výsledek s pravděpodobností 1 ve všech případech (tj. počítá přesně). a jsou běžněji známé jako složitost kvantových dotazů, protože přímá definice kvantového rozhodovacího stromu je složitější než v klasickém případě. Podobně jako v náhodném případě definujeme a .
Tyto pojmy jsou obvykle omezeny pojmy stupeň a přibližný stupeň. The stupeň z , označeno , je nejmenší stupeň ze všech polynomů uspokojující pro všechny . The přibližný stupeň z , označeno , je nejmenší stupeň ze všech polynomů uspokojující kdykoli a kdykoli .
Beals et al. stanovil, že a .[9]
Vztahy mezi měřítky složitosti booleovských funkcí
Z definic to bezprostředně vyplývá, že pro všechny -bit Booleovské funkce ,, a . Nalezení nejlepších horních mezí v opačném směru je hlavním cílem v oblasti složitosti dotazů.
Všechny tyto typy složitosti dotazů jsou polynomiálně příbuzné. Blum a Impagliazzo,[10] Hartmanis a Hemachandra,[11] a Tardos[12] nezávisle na tom zjistili . Noam Nisan zjistili, že složitost randomizovaného rozhodovacího stromu Monte Carlo také polynomiálně souvisí se složitostí deterministického rozhodovacího stromu: .[13] (Nisan to také ukázal .) Mezi modely Monte Carlo a Las Vegas je znám těsnější vztah: .[14] Tento vztah je optimální až do polylogaritmických faktorů.[15] Pokud jde o složitost kvantového rozhodovacího stromu, a tato vazba je pevná.[16][15] Midrijanis to ukázal ,[17][18] zlepšení kvartické vazby v důsledku Beals et al.[9]
Je důležité si uvědomit, že tyto polynomiální vztahy jsou platné pouze pro celkový Booleovské funkce. Pro částečné booleovské funkce, které mají doménu podmnožinu , exponenciální oddělení mezi a je možné; první příklad takového problému objevil Deutsch a Jozsa.
Domněnka o citlivosti
Pro Booleovská funkce , citlivost z je definována jako maximální citlivost nade vše , kde citlivost na je počet jednobitových změn v které mění hodnotu . Citlivost souvisí s představou celkového vlivu z analýza booleovských funkcí, což se rovná průměrný citlivost nade vše .
The domněnka citlivosti je domněnka, že citlivost polynomiálně souvisí se složitostí dotazu; to znamená, že existuje exponent takové, že pro všechny , a . Jeden může ukázat jednoduchým argumentem, že , takže domněnka se konkrétně týká hledání dolní meze citlivosti. Protože všechna dříve diskutovaná měřítka složitosti jsou polynomiálně příbuzná, přesný typ míry složitosti není relevantní. To je však obvykle formulováno jako otázka souvislosti citlivosti s citlivostí bloku.
The citlivost bloku z , označeno , je definována jako maximální citlivost bloku nade vše . Citlivost bloku na je maximální počet disjunktních podmnožin takové, že pro kteroukoli z podskupin , převrácení bitů souhlasí s změní hodnotu .[13]
Vzhledem k tomu, že citlivost bloku trvá více u více možností podmnožin, . Citlivost bloku dále polynomiálně souvisí s dříve diskutovanými měřítky složitosti; například to ukázal Nisanův článek představující blokovou citlivost .[13] Dalo by se tedy přeformulovat domněnku citlivosti tak, že to pro některé ukazuje , . V roce 1992 se Nisan a Szegedy domnívali stačí.[19] To by bylo těsné, protože Rubinstein v roce 1995 ukázal kvadratické oddělení mezi citlivostí a citlivostí bloku.[20]
V červenci 2019, 27 let poté, co byla původně domněnka, Hao Huang z Emory University prokázal domněnku citlivosti a ukázal to .[21] Tento důkaz je pozoruhodně výstižný, což dokazuje toto tvrzení na dvou stránkách, když byl omezen předchozí pokrok směrem k domněnce citlivosti.[22][23]
Souhrn známých výsledků
2 | 2, 3 | 2 | 2, 3 | 2, 3 | 3, 6 | 2, 3 | 2, 3 | 4 | 4 | ||
1 | 2 | 2 | 2, 3 | 2, 3 | 3, 6 | 2, 3 | 2, 3 | 3, 4 | 4 | ||
1 | 1 | 2 | 2, 3 | 2, 3 | 3, 6 | 1.5, 3 | 2, 3 | 3, 4 | 4 | ||
1 | 1 | 1, 2 | 2 | 2 | 2.22, 5 | 1.15, 3 | 1.63, 3 | 2, 4 | 2, 4 | ||
1 | 1 | 1 | 1 | 1.5, 2 | 2, 4 | 1.15, 2 | 1.63, 2 | 2 | 2 | ||
1 | 1 | 1 | 1 | 1 | 2, 4 | 1.15, 2 | 1.63, 2 | 2 | 2 | ||
1 | 1 | 1 | 1 | 1 | 1 | 1.15, 2 | 1.63, 2 | 2 | 2 | ||
1 | 1.33, 2 | 1.33, 3 | 2 | 2, 3 | 2, 3 | 3, 6 | 2, 3 | 2, 4 | 4 | ||
1 | 1.33, 2 | 1.33, 2 | 2 | 2 | 2 | 2 | 1 | 2 | 2 | ||
1 | 1 | 1 | 2 | 2, 3 | 2, 3 | 3, 6 | 1 | 2, 3 | 4 | ||
1 | 1 | 1 | 2 | 2 | 2 | 2 | 1 | 1 | 1 |
Tato tabulka shrnuje výsledky separací mezi měřítky booleovské funkce. Míry složitosti jsou v pořadí deterministické, randomizované s nulovou chybou, randomizované s oboustrannou chybou, certifikát, randomizovaný certifikát, citlivost bloku, citlivost, přesné kvantum, stupeň, kvantum a přibližná složitost stupně.
Číslo v -tá řada a -tý sloupec označuje hranice exponentu , což je infimum všech uspokojující pro všechny booleovské funkce . Například položka v D-tom řádku a v S-tom sloupci je „3, 6“, takže pro všechny a existuje funkce takhle .
Viz také
- Třídění srovnání
- Rozhodovací strom
- Aanderaa – Karp – Rosenbergova domněnka
- Minimální kostra # Rozhodovací stromy
Reference
- ^ Jr, Lester R. Ford; Johnson, Selmer M. (01.05.1959). „Problém s turnajem“. Americký matematický měsíčník. 66 (5): 387–389. doi:10.1080/00029890.1959.11989306. ISSN 0002-9890.
- ^ A b Úvod do algoritmů. Cormen, Thomas H. (třetí vydání). Cambridge, Massachusetts: MIT Press. 2009. ISBN 978-0-262-27083-0. OCLC 676697295.CS1 maint: ostatní (odkaz)
- ^ Rabin, Michael O. (01.12.1972). „Prokázání současné pozitivity lineárních forem“. Journal of Computer and System Sciences. 6 (6): 639–650. doi:10.1016 / S0022-0000 (72) 80034-5. ISSN 0022-0000.
- ^ Reingold, Edward M. (01.10.1972). „O optimalitě některých nastavených algoritmů“. Deník ACM. 19 (4): 649–659. doi:10.1145/321724.321730. ISSN 0004-5411. S2CID 18605212.
- ^ Preparata, Franco P. (1985). Výpočetní geometrie: úvod. Shamos, Michael Ian. New York: Springer-Verlag. ISBN 0-387-96131-3. OCLC 11970840.
- ^ Ben-Or, Michael (01.12.1983). "Dolní hranice pro algebraické výpočetní stromy". Sborník z patnáctého ročníku ACM symposia o teorii práce s počítačem. STOC '83. New York, NY, USA: Sdružení pro výpočetní techniku: 80–86. doi:10.1145/800061.808735. ISBN 978-0-89791-099-6. S2CID 1499957.
- ^ Dobkin, David; Lipton, Richard J. (06.06.1976). „Problémy s vícerozměrným vyhledáváním“. SIAM Journal on Computing. 5 (2): 181–186. doi:10.1137/0205015. ISSN 0097-5397.
- ^ Michael Steele, J; Yao, Andrew C (01.03.1982). "Dolní hranice pro algebraické rozhodovací stromy". Journal of Algorithms. 3 (1): 1–8. doi:10.1016/0196-6774(82)90002-5. ISSN 0196-6774.
- ^ A b Beals, R .; Buhrman, H .; Cleve, R .; Mosca, M .; de Wolf, R. (2001). "Kvantové dolní meze polynomy". Deník ACM. 48 (4): 778–797. arXiv:quant-ph / 9802049. doi:10.1145/502090.502097. S2CID 1078168.
- ^ Blum, M .; Impagliazzo, R. (1987). Msgstr "Obecné věštci a věštecké třídy". Sborník 18. IEEE FOCS. str. 118–126.
- ^ Hartmanis, J .; Hemachandra, L. (1987), „Jednosměrné funkce, robustnost a neizomorfismus NP-kompletních sad“, Technická zpráva DCS TR86-796, Cornell University
- ^ Tardos, G. (1989). „Složitost dotazu, nebo proč je těžké jej oddělit NPA ∩ coNPA z PA náhodnými věštci A?". Combinatorica. 9 (4): 385–392. doi:10.1007 / BF02125350. S2CID 45372592.
- ^ A b C Nisan, N. (1989). "POSÁDKOVÉ PRAMY a rozhodovací stromy". Sborník z 21. ACM STOC. 327–335.
- ^ Kulkarni, R. a Tal, A. O citlivosti frakčního bloku. Elektronické kolokvium o výpočetní složitosti (ECCC). Sv. 20. 2013.
- ^ A b Ambainis, Andris; Balodis, Kaspars; Belovs, Aleksandrs; Lee, Troy; Santha, Miklos; Smotrovs, Juris (04.09.2017). „Separations in Query Complexity Based on Pointer Functions“. Deník ACM. 64 (5): 32:1–32:24. arXiv:1506.04719. doi:10.1145/3106234. ISSN 0004-5411. S2CID 10214557.
- ^ A b Aaronson, Scott; Ben-David, Shalev; Kothari, Robin; Rao, Shravas; Tal, Avishay (2020-10-23). „Stupeň vs. přibližný stupeň a kvantové důsledky Huangovy věty o citlivosti“. arXiv:2010.12629 [kvant. ph ].
- ^ Midrijanis, Gatis (2004), „Přesná kvantová složitost dotazů pro celkové booleovské funkce“, arXiv:quant-ph / 0403168
- ^ Midrijanis, Gatis (2005), „O náhodných a kvantových složitostech dotazů“, arXiv:quant-ph / 0501142
- ^ Nisan, Noam; Szegedy, Mario (01.07.1992). „O míře booleovských funkcí jako skutečných polynomů“. Sborník z dvacátého čtvrtého ročníku ACM symposia o teorii práce s počítačem. STOC '92. Victoria, Britská Kolumbie, Kanada: Sdružení pro výpočetní techniku: 462–467. doi:10.1145/129712.129757. ISBN 978-0-89791-511-3. S2CID 6919144.
- ^ Rubinstein, David (01.06.1995). "Citlivost vs. bloková citlivost booleovských funkcí". Combinatorica. 15 (2): 297–299. doi:10.1007 / BF01200762. ISSN 1439-6912. S2CID 41010711.
- ^ Huang, Hao (2019). "Vyvolané podgrafy hyperkrychlí a důkaz hypotetické domněnky". Annals of Mathematics. 190 (3): 949–955. arXiv:1907.00847. doi:10 4007 / anály.2019.190.3.6. ISSN 0003-486X. JSTOR 10 4007 / anály.2019.190.3.6. S2CID 195767594.
- ^ Klarreich, Erica. „Desetiletí stará domněnka informatiky vyřešená na dvou stránkách“. Časopis Quanta. Citováno 2019-07-26.
- ^ Hatami, Pooya; Kulkarni, Raghav; Pankratov, Denis (2011-06-22). „Variace na domněnku citlivosti“. Teorie výpočtu. 1: 1–27. doi:10.4086 / toc.gs.2011.004. ISSN 1557-2862. S2CID 6918061.
Průzkumy
- Buhrman, Harry; de Wolf, Ronald (2002), „Měření složitosti a složitost rozhodovacího stromu: průzkum“ (PDF), Teoretická informatika, 288 (1): 21–43, doi:10.1016 / S0304-3975 (01) 00144-X