- **Informally:**
+ $g$ is an **upper bound** for $f$
-
**Formally:**
+ There is a constant $c>0$ such that $f(n) \le c\cdot g(n)$ for all $n\ge n_0$

## $f(n) = \Omega(g(n))$
$f$ is "big omega" of $g$
- **Informally:**
+ $g$ is an **lower bound** for $f$
-
**Formally:**
+ There is a constant $c>0$ such that $f(n) \ge c\cdot g(n)$ for all $n\ge n_0$

## $f(n) = \Theta(g(n))$
$f$ is "big theta" of $g$
- **Informally:**
+ $g$ is a **tight bound** for $f$
-
**Formally:**
+ There exist constants $c_1,c_2>0$ such that $c_1g(n) \ge f(n) \ge c_2g(n)$ for all $n\ge n_0$
-
**Alternatively:**
+ $f(n) = O(g(n)) = \Omega(g(n))$

# Daily Exercise
## Big Oh Comparison
- In practice, speeding up an algorithm by 2x is great even though $f(n)$ and $f(n)/2$ have the same asymptotic time complexity
-
However, a jump from $n^2$ to $n\log n$ is a **CRAZY HUGE IMPROVEMENT**
## Big Oh Comparison
| $n$ || $n^2$ | $n^2/2$ | $n\log n$
|--------||---------|---------|-----------
| $10$ || $100$ | $50$ | $33$
| $100$ || $10000$ | $5000$ | $664$
| $10^3$ || $10^6$ | $5\times 10^5$ | $9965$
| $10^4$ || $10^8$ | $5\times 10^7$ | $1.3\times 10^5$
| $10^5$ || $10^{10}$ | $5\times 10^9$ | $1.6\times 10^6$
# Dominance Relations
## Dominance Relations
- When $f(n) = O(g(n))$ but $f(n) \ne \Theta(g(n))$, we say that $g$ **dominates** $f$
+
Sometimes written $f(n) \ll g(n)$
+
Sometimes written $f(n) = o(g(n))$
+
$f$ is "little oh" of $g$
## Another Characterization
- With functions $f(n)$ and $g(n)$, consider the behavior of the limit:
$$\lim_{n\rightarrow\infty}\frac{f(n)}{g(n)}$$
-
What if it diverges to $\infty$?
-
What if it converges to $0$?
-
What if it converges to a constant $c > 0$?
## Another Characterization
$$\begin{aligned}
f(n) \gg g(n) &\iff \lim_{n\rightarrow\infty}\frac{f(n)}{g(n)}=\infty\\\\
f(n) \ll g(n) &\iff \lim_{n\rightarrow\infty}\frac{f(n)}{g(n)}=0\\\\
f(n) = \Theta(g(n)) &\iff \lim_{n\rightarrow\infty}\frac{f(n)}{g(n)}=c > 0
\end{aligned}$$
## Applications of Dominance

## Applications of Dominance
- Exponential algorithms are hopelessly slow
-
Quadratic algorithms get hopeless around $n=1000000$
-
$O(n\log n)$ algorithms get hopeless around $n=10^9$
-
$O(\log n)$ is extremely fast, even for extraordinary large values of $n$
## Exercises
- Determine whether each of the following statements is true or false:
+
$f(n) = O(g(n))$ is the same as $g(n) = \Omega(f(n))$
+
If $f(n) = O(g(n))$, then $f(n) = o(g(n))$