« previous | Friday, January 21, 2011 | next »
Asymptotically Comparing Functions
Let
and
:
- When
, data:image/s3,"s3://crabby-images/c65c8/c65c822efba2061cd1edd63e6a07cd5022502b87" alt="{\displaystyle f(n)>g(n)}"
- Asymptotically,
"grows faster" than
, so
≥
when data:image/s3,"s3://crabby-images/8fbdb/8fbdb0fefc5b99f510429271b6f4028e4acaabac" alt="{\displaystyle n>5}"
- In general, we say
is asymptotically less than or equal to
if and only if there exists a natural number
such that
≥
for all
→
[1][2][3][4][5]
- Therefore
data:image/s3,"s3://crabby-images/3467a/3467aa26afad703aa5e3f688cba8a3b25620be20" alt="{\displaystyle 5n\preccurlyeq n^{2}}"
For more complex problems like
, take limit to infinity and put it in order notation:
is order
(
)
Big O
An upper bound on a function
:
data:image/s3,"s3://crabby-images/1dd59/1dd59f776f836d9a7a0ea387c602de4bd2b01ced" alt="{\displaystyle f(n)=O(n)\rightarrow f(n)\leq Cn\rightarrow f(n)\preccurlyeq n}"
Precise Definition: data:image/s3,"s3://crabby-images/31ead/31ead0f14fce47c8cb6965e6a3912dd57945ca4a" alt="{\displaystyle f(n)}"
is big oh of (order)
data:image/s3,"s3://crabby-images/b13dd/b13ddd667e5bd71c2c314b031e622ccf1cb6df31" alt="{\displaystyle g(n)}"
if and only if there exists a constant
data:image/s3,"s3://crabby-images/b940e/b940efd891366f34b3de7bb6c11e45079312b664" alt="{\displaystyle C}"
and a natural number
data:image/s3,"s3://crabby-images/8eddb/8eddb785ca343839af0037ab6a45a23dbf2f7af5" alt="{\displaystyle n_{0}}"
such that
data:image/s3,"s3://crabby-images/06024/06024ab67ca0c820571c695d3f4a988a96d9d28b" alt="{\displaystyle |f(n)|}"
≤
data:image/s3,"s3://crabby-images/24819/24819cb92ff2e1bfcf505facfe8f03a036a39235" alt="{\displaystyle C|g(n)|}"
for all
data:image/s3,"s3://crabby-images/9ffc9/9ffc98d1a7978cd480aee0dea2916f2adb0317f8" alt="{\displaystyle f(n)=O(g(n))\Leftrightarrow \exists \ C;n_{0}\in \mathbb {N} :|f(n)|\leq C|g(n)|\ \forall \ n\geq n_{0}}"
Precise definition
Big Ω
A lower bound on a function
[6]:
data:image/s3,"s3://crabby-images/1854b/1854b4669fa86b56d6f4914b6b752a9c899d0515" alt="{\displaystyle f(n)=\Omega (n)\rightarrow f(n)\geq Cn\rightarrow f(n)\succcurlyeq n}"
Precise Definition: data:image/s3,"s3://crabby-images/31ead/31ead0f14fce47c8cb6965e6a3912dd57945ca4a" alt="{\displaystyle f(n)}"
is big omega of
data:image/s3,"s3://crabby-images/b13dd/b13ddd667e5bd71c2c314b031e622ccf1cb6df31" alt="{\displaystyle g(n)}"
if and only if there exists a constant
data:image/s3,"s3://crabby-images/b940e/b940efd891366f34b3de7bb6c11e45079312b664" alt="{\displaystyle C}"
and a natural number
data:image/s3,"s3://crabby-images/8eddb/8eddb785ca343839af0037ab6a45a23dbf2f7af5" alt="{\displaystyle n_{0}}"
such that
data:image/s3,"s3://crabby-images/06024/06024ab67ca0c820571c695d3f4a988a96d9d28b" alt="{\displaystyle |f(n)|}"
≥
data:image/s3,"s3://crabby-images/24819/24819cb92ff2e1bfcf505facfe8f03a036a39235" alt="{\displaystyle C|g(n)|}"
for all
Note: data:image/s3,"s3://crabby-images/46d3f/46d3f55680e8c58a4925229d61831a6d7c418b04" alt="{\displaystyle f(n)=\Omega (g(n))\Leftrightarrow g(n)=O(f(n))}"
Big Θ
Means that function has same asymptotic growth as another function up to multiplication by constants. Similar to squeeze theorem in Calculus for proof of convergence.
data:image/s3,"s3://crabby-images/09168/091680cbb0e5a909e8346c31cd14bf23a171d95d" alt="{\displaystyle f(n)=\Theta (g(n))\Rightarrow \exists \ L<\infty :\lim _{n\to \infty }{\frac {|f(n)|}{|g(n)|}}=L}"
data:image/s3,"s3://crabby-images/56a9d/56a9dfb9313e45102c069d2c700da7c058f3bc61" alt="{\displaystyle f(n)=\Theta (g(n))\Leftrightarrow \exists \ L,U;n_{0}\in \mathbb {N} :L|g(n)|\leq |f(n)|\leq U|g(n)|\ \forall \ n\geq n_{0}}"
Precise definition
Note
Examples
Example 1
- Claim
data:image/s3,"s3://crabby-images/ec826/ec8263313f12ba1ffb3020ae7e0dafd5d51873f2" alt="{\displaystyle 5n=O\left(n^{2}\right)}"
- Choose
and data:image/s3,"s3://crabby-images/02481/0248190d34609a6b882d526ee61dad9a0fe5dcb2" alt="{\displaystyle n_{0}=1}"
data:image/s3,"s3://crabby-images/6234c/6234c6f6c10a445f2c7a9410a3452798139ebd06" alt="{\displaystyle {\begin{Bmatrix}5n&<&5n^{2}\\\left|5n\right|&\leq &5\left|n^{2}\right|\end{Bmatrix}}\ {\mbox{true}}\ \forall \ n\geq 1}"
Example 3
Example 4
(See Wikipedia:Binomial coefficient→)
Order of dominance
data:image/s3,"s3://crabby-images/40887/408871156bf4a4e0ea63ce20ec07a08e4e5d5d32" alt="{\displaystyle O(n^{n})}"
data:image/s3,"s3://crabby-images/08371/083716235864e4d03306aaa605e5c4ea40b76fb0" alt="{\displaystyle O(n!)}"
data:image/s3,"s3://crabby-images/02c55/02c5511d35cbc9dd32857c85fb9e2436296c5990" alt="{\displaystyle O(n^{2})}"
data:image/s3,"s3://crabby-images/af828/af8285a19a21816a5e458f176c1fb558b92fded1" alt="{\displaystyle O(n\log {n})}"
data:image/s3,"s3://crabby-images/1737d/1737d6a942b662ac260dfbb3ab719c963f5d721f" alt="{\displaystyle O(n)}"
data:image/s3,"s3://crabby-images/cc896/cc8964efab55d9ba05832eb0539194fda996aee5" alt="{\displaystyle O({\sqrt {n}})}"
data:image/s3,"s3://crabby-images/d042f/d042fe304996ee235c1fbb7e7e27a7b35bec1bc7" alt="{\displaystyle O(\log {n})}"
data:image/s3,"s3://crabby-images/99ba6/99ba68a937e9ce3745001460f9d5403e625289aa" alt="{\displaystyle O(1)}"
Comparing Functions
This means that
up to a constant factor
- ↑
(curved or soft version of ≤) means "is asymptotically less than or equal to"
- ↑ ⇔ means "if and only if" (iff)
- ↑ ∃ means "there exists"
- ↑ : means "such that"
- ↑ ∀ means "for all"
- ↑ comparison-based sorting algorithms need at least
comparisons.