Amortizovaná analýza - Amortized analysis

v počítačová věda, amortizovaná analýza je metoda pro analyzovat daný algoritmus složitost nebo kolik zdroje, zejména času nebo paměti, je potřeba vykonat. Motivací pro amortizovanou analýzu je pohled na nejhorší dobu běhu na operaci, spíše než na algoritmus, může být příliš pesimistický.[1]

Zatímco určité operace pro daný algoritmus mohou mít značné náklady na zdroje, jiné operace nemusí být tak nákladné. Amortizovaná analýza bere v úvahu jak nákladné, tak méně nákladné operace v průběhu celé řady operací algoritmu. To může zahrnovat účtování o různých typech vstupu, délce vstupu a dalších faktorech, které ovlivňují jeho výkon.[2]

Dějiny

Amortizovaná analýza se původně vynořila z metody zvané agregovaná analýza, která je nyní zahrnuta do amortizované analýzy. Techniku ​​poprvé formálně představil Robert Tarjan ve své práci z roku 1985 Amortizovaná výpočetní složitost,[3] která se zabývala potřebou užitečnější formy analýzy než běžné použité pravděpodobnostní metody. Amortizace byla původně použita pro velmi specifické typy algoritmů, zejména pro ty, které zahrnují binární stromy a svaz operace. Nyní je však všudypřítomný a vstupuje do hry i při analýze mnoha dalších algoritmů.[2]

Metoda

Amortizovaná analýza vyžaduje znalost toho, které řady operací jsou možné. To je nejčastěji případ datové struktury, které mají Stát která přetrvává mezi operacemi. Základní myšlenkou je, že operace v nejhorším případě může změnit stav takovým způsobem, že k nejhoršímu případu již nemůže dojít po dlouhou dobu, a tak „amortizovat“ jeho náklady.

Obecně existují tři metody provádění amortizované analýzy: agregovaná metoda, účetní metoda a potenciální metoda. Všichni tito dávají správné odpovědi; výběr, který použijete, závisí na tom, co je pro konkrétní situaci nejvhodnější.[4]

  • Agregační analýza určuje horní mez T(n) o celkových nákladech na sekvenci n operace, pak vypočítá zůstatkovou cenu T(n) / n.[4]
  • The účetní metoda je forma agregátní analýzy, která přiřazuje každé operaci amortizovaná cena které se mohou lišit od skutečných nákladů. Počáteční operace mají naběhlé náklady vyšší než jejich skutečné náklady, což akumuluje uložený „kredit“, který platí za pozdější operace, které mají naběhlé náklady nižší než jejich skutečné náklady. Protože kredit začíná na nule, skutečné náklady na sekvenci operací se rovnají zůstatkové hodnotě minus akumulovaný kredit. Vzhledem k tomu, že úvěr musí být nezáporný, je amortizovaná cena horní hranicí skutečné ceny. Mnoho krátkodobých operací obvykle akumuluje takový kredit v malých přírůstcích, zatímco vzácné dlouhodobé operace jej drasticky snižují.[4]
  • The potenciální metoda je forma účetní metody, kde se uložený kredit počítá jako funkce („potenciál“) stavu datové struktury. Amortizovaná cena je okamžitá cena plus změna potenciálu.[4]

Příklady

Dynamické pole

Amortizovaná analýza operace push pro dynamické pole

Zvažte a dynamické pole který roste s tím, jak se k němu přidává více prvků, například ArrayList v Javě nebo std :: vektor v C ++. Pokud bychom začali s dynamickým polem velikosti 4, mohli bychom na něj tlačit 4 prvky a každá operace by trvala konstantní čas. Zatlačení pátého prvku na toto pole by trvalo déle, protože by pole muselo vytvořit nové pole s dvojnásobnou aktuální velikostí (8), zkopírovat staré prvky do nového pole a poté přidat nový prvek. Další tři operace push by podobně trvaly konstantní čas a následné přidání by vyžadovalo další pomalé zdvojnásobení velikosti pole.

Obecně platí, že pokud vezmeme v úvahu libovolný počet stisknutí n +1 k poli velikosti n, všimli jsme si, že operace push trvají konstantní čas, s výjimkou posledního, který trvá čas na provedení operace zdvojnásobení velikosti. Protože tam byly n + 1 celkem operací můžeme vzít průměr z toho a zjistit, že tlačit prvky na dynamické pole trvá: , konstantní čas.[4]

Fronta

Zobrazena je Ruby implementace a Fronta, a Datová struktura FIFO:

třída Fronta  def inicializovat    @vstup = []    @výstup = []  konec  def zařadit do fronty(živel)    @vstup << živel  konec  def dequeue    -li @výstup.prázdný?      zatímco @vstup.žádný?        @výstup << @vstup.pop      konec    konec    @výstup.pop  koneckonec

Operace zařazení do fronty pouze posune prvek na vstupní pole; tato operace nezávisí na délkách vstupu ani výstupu, a proto běží v konstantním čase.

Operace dequeue je však komplikovanější. Pokud výstupní pole již obsahuje některé prvky, dequeue běží v konstantním čase; jinak dequeue trvá čas přidat všechny prvky do výstupního pole ze vstupního pole, kde n je aktuální délka vstupního pole. Po kopírování n prvky ze vstupu, můžeme provést n dequeue operations, each taking constant time, before the output array is again empty. Můžeme tedy provést sekvenci n vyřadit operace pouze v time, což znamená, že amortizovaný čas každé operace dequeue je .[5]

Alternativně můžeme účtovat náklady na kopírování jakékoli položky ze vstupního pole do výstupního pole do dřívější operace zařazení do fronty pro tuto položku. Toto schéma zpoplatnění zdvojnásobuje amortizovaný čas pro zařazení do fronty, ale snižuje amortizovaný čas pro zařazení do fronty .

Běžné použití

  • „Amortizovaný algoritmus“ je běžně používaný algoritmus, u kterého se ukázalo, že amortizovaná analýza funguje dobře.
  • Online algoritmy běžně používají amortizovanou analýzu.

Reference

  • Allan Borodin a Ran El-Yaniv (1998). Online výpočet a konkurenční analýza. Cambridge University Press. 20, 141.
  1. ^ „Přednáška 7: Amortizovaná analýza“ (PDF). Univerzita Carnegie Mellon. Citováno 14. března 2015.
  2. ^ A b Rebecca Fiebrink (2007), Vysvětlení amortizované analýzy (PDF), archivovány z originál (PDF) dne 20. října 2013, vyvoláno 3. května 2011
  3. ^ Tarjan, Robert Endre (Duben 1985). „Amortizovaná výpočetní složitost“ (PDF). SIAM Journal o algebraických a diskrétních metodách. 6 (2): 306–318. doi:10.1137/0606031.
  4. ^ A b C d E Kozen, Dexter (jaro 2011). „CS 3110 Lecture 20: Amortized Analysis“. Cornell University. Citováno 14. března 2015.
  5. ^ Grossman, Dan. "CSE332: Data Abstractions" (PDF). cs.washington.edu. Citováno 14. března 2015.