Grote-O-notatie

In de wiskunde is de grote-O-notatie, ook het grote-O-symbool, een van de Landau-symbolen waarmee op compacte wijze aangegeven kan worden dat een functie asymptotisch gedomineerd wordt door een andere functie. Meestal is de dominerende functie van een eenvoudige vorm, zodat een overzichtelijke indruk verkregen wordt van het asymptotische gedrag van de doelfunctie.

Een andere manier om het asymptotische gedrag van de ene functie f {\displaystyle f} te vergelijken met een andere functie g {\displaystyle g} is het bepalen van de relevante limiet van het quotiënt f ( x ) / g ( x ) {\displaystyle f(x)/g(x)} . Bij de grote-O-notatie gaat het slechts om een ongelijkheid, dus dat is een zwakkere eigenschap.

Definitie

Men zegt dat de functie f : R R {\displaystyle f:\mathbb {R} \to \mathbb {R} } zich voor x {\displaystyle x\to \infty } gedraagt als grote O van g : R R {\displaystyle g:\mathbb {R} \to \mathbb {R} } , en noteert

f ( x ) = O ( g ( x ) )   ( x ) {\displaystyle f(x)=O(g(x))\ (x\to \infty )}

of

f ( x ) O ( g ( x ) )   ( x ) {\displaystyle f(x)\in O(g(x))\ (x\to \infty )} ,

als er een positief getal M R ,   M > 0 {\displaystyle M\in \mathbb {R} ,\ M>0} en een getal x 0 R {\displaystyle x_{0}\in \mathbb {R} } is, zodanig dat voor x > x 0 {\displaystyle x>x_{0}} geldt

| f ( x ) | M | g ( x ) | {\displaystyle |f(x)|\leq M\,|g(x)|}

Dit houdt in dat voor voldoend grote x {\displaystyle x} f ( x ) {\displaystyle f(x)} in absolute waarde begrensd wordt door M | g ( x ) | {\displaystyle M\,|g(x)|} .

Analoog wordt de notatie gebruikt om het gedrag van f {\displaystyle f} in de buurt van een punt a R {\displaystyle a\in \mathbb {R} } te karakteriseren.

f ( x ) = O ( g ( x ) )   ( x a ) {\displaystyle f(x)=O(g(x))\ (x\to a)}

of

f ( x ) O ( g ( x ) )   ( x a ) {\displaystyle f(x)\in O(g(x))\ (x\to a)} ,

als er positieve getallen M , δ R ,   M , δ > 0 {\displaystyle M,\delta \in \mathbb {R} ,\ M,\delta >0} zijn, zodanig dat voor | x a | < δ {\displaystyle |x-a|<\delta } geldt

| f ( x ) | M | g ( x ) | {\displaystyle |f(x)|\leq M\,|g(x)|}

Dit houdt in dat voor waarden van x {\displaystyle x} in de buurt van a {\displaystyle a} f ( x ) {\displaystyle f(x)} in absolute waarde begrensd wordt door M | g ( x ) | {\displaystyle M\,|g(x)|} .

Notatie

De notatie met het '='-teken is historisch bepaald, maar maakt eigenlijk misbruik van dat teken. In wezen wordt in de uitspraak: " f ( x ) {\displaystyle f(x)} is O ( g ( x ) ) {\displaystyle O(g(x))} " het woordje 'is' als '=' geschreven. De modernere notatie met ' {\displaystyle \in } '-teken is daarentegen wel correct, als met O ( g ( x ) ) {\displaystyle O(g(x))} de verzameling functies aangeduid wordt die de bedoelde eigenschap bezitten. Deze verzameling functies is een lineaire ruimte, zoals eenvoudig aangetoond kan worden.

Met f 1 ( x ) = f 2 ( x ) + O ( g ( x ) ) {\displaystyle f_{1}(x)=f_{2}(x)+O(g(x))} wordt bedoeld f 1 ( x ) f 2 ( x ) = O ( g ( x ) ) {\displaystyle f_{1}(x)-f_{2}(x)=O(g(x))} .

Geschiedenis

Het symbool (grote) O, dat een afkorting is van 'orde', werd voor het eerst gebruikt door de Duitse getaltheoreticus Paul Bachmann in de in 1894 verschenen 2e druk van zijn boek Analytische Zahlentheorie. Bekendheid kreeg de notatie door de eveneens Duitse getaltheoreticus Edmund Landau, wiens naam met de symboliek verbonden is.

Voorbeelden

Asymptotisch geldt:

x 3 + 2 x 2 4 x + 3 O ( x 3 ) {\displaystyle x^{3}+2x^{2}-4x+3\in O(x^{3})} ,

wat ook te begrijpen is, omdat voor grote x {\displaystyle x} de term met de hoogste macht, x 3 {\displaystyle x^{3}} , overheerst.

Met de grote-O notatie kan de restterm beschreven worden in de benadering van een functie.

e x = 1 + x + 1 2 x 2 + O ( x 3 ) ( x 0 ) {\displaystyle e^{x}=1+x+{\tfrac {1}{2}}x^{2}+O(x^{3})\quad (x\to 0)}

waarmee uitgedrukt wordt dat het verschil e x ( 1 + x + 1 2 x 2 ) {\displaystyle e^{x}-(1+x+{\tfrac {1}{2}}x^{2})} voor waarden van x {\displaystyle x} dicht bij 0 en zekere M {\displaystyle M} kleiner is dan | M x 3 | {\displaystyle |Mx^{3}|} .

Informatica

De notatie wordt in de informatica gebruikt om de (tijds)complexiteitsgraad van algoritmen uit te drukken in termen van een geheel getal als parameter, waarbij het gaat om het aantal elementaire bewerkingen als functie hiervan, als de parameter naar oneindig gaat. Deze notatie is een 'slechtste-geval' maat. Ze geeft enkel informatie over het maximaal aantal elementaire bewerkingen dat een algoritme bij gegeven invoergrootte zal uitvoeren. De notatie is machine-onafhankelijk.

Algoritmen met een complexiteit O ( n k ) ,     k N {\displaystyle O(n^{k}),\ \ k\in \mathbb {N} } en n {\displaystyle n} de invoergrootte, heten polynomiaal. Algoritmen met een complexiteit O ( k n ) ,     k R {\displaystyle O(k^{n}),\ \ k\in \mathbb {R} } , k > 1 {\displaystyle k>1} heten exponentieel. Merk opnieuw op dat polynomiale algoritmen exponentieel zijn, maar omgekeerd niet.

Merk op dat O ( n ) {\displaystyle O(n)} tevens O ( n 2 ) {\displaystyle O(n^{2})} impliceert. Immers als het algoritme trager of gelijk aan n {\displaystyle n} groeit, dan zeker trager dan n 2 {\displaystyle n^{2}} . Dit is algemeen geldig in de grote-O-notatie: een lagere complexiteit impliceert een hogere complexiteit.

Veel voorkomende ordes voor functies zijn, in volgorde van stijgende complexiteit:

O-notatie Naam Omschrijving Voorbeelden
O ( 1 ) {\displaystyle O(1)} constant tijd onafhankelijk van de grootte van het probleem, dus is de tijd om het op te lossen nooit meer dan een bepaalde bovengrens, ook al is het probleem nog zo groot
  • Bepalen of een binair getal even of oneven is
  • (-1)n berekenen
  • Een opzoektabel met constante grootte gebruiken
O ( log n ) {\displaystyle O(\log n)} logaritmisch evenredig aan logaritme van n {\displaystyle n} , als n {\displaystyle n} 10 maal zo groot wordt, neemt de tijd met een constante toe
  • Binair zoeken
O ( n ) {\displaystyle O(n)} lineair tijd evenredig aan n {\displaystyle n}
  • Een item opzoeken in een ongeordende lijst
O ( n log n ) {\displaystyle O(n\log n)} loglineair tijd evenredig aan n l o g ( n ) {\displaystyle n\cdot log(n)}
  • Beste sorteeralgoritmen die bekend zijn
  • snelle fouriertransformatie
O ( n 2 ) {\displaystyle O(n^{2})} kwadratisch tijd neemt kwadratisch toe met de grootte van het probleem
  • Twee getallen met n cijfers vermenigvuldigen zoals op school
  • Simpele sorteeralgoritmen zoals bubblesort
O ( 2 n ) {\displaystyle O(2^{n})} exponentieel tijd neemt exponentieel toe met de grootte van het probleem
O ( n ! ) {\displaystyle O(n!)} factorieel tijd is evenredig met n faculteit
  • Berekenen van permutaties
  • Brute force oplossen van het handelsreizigersprobleem