aboutsummaryrefslogtreecommitdiff
path: root/ass2/q4/fibonacci.md
diff options
context:
space:
mode:
Diffstat (limited to 'ass2/q4/fibonacci.md')
-rw-r--r--ass2/q4/fibonacci.md82
1 files changed, 82 insertions, 0 deletions
diff --git a/ass2/q4/fibonacci.md b/ass2/q4/fibonacci.md
index 7cda442..f550e1b 100644
--- a/ass2/q4/fibonacci.md
+++ b/ass2/q4/fibonacci.md
@@ -234,3 +234,85 @@ This is not what I expected, since the amortised cost should take into account t
In a large amount of cases, a single operation does not need to go through every level of depth in the tree of the highest degree. It doesn't seem to take into account that a some operations consist of just decreasing the key and not deleting anything at all. I would expect something closer to constant time.
# Part i
+
+There are 3 cases to consider when performing `decrease_key`.
+
+## Case 1
+
+In the case where a node's key is decreased without violating the properties of the heap, the number of marked nodes and number of nodes in the root list doesn't change. This means $\Phi$ is unaffected in these situations,
+meaning $\alpha$ does not matter. This means the amortised cost for this trivial case is $ac_i = O(1)$. So we must only consider situations where the heap property *is* violated.
+
+## Case 2a
+
+When a node with an **unmarked** parent is deleted, the original node is moved to the root list. One node (the parent) is also marked (leading the next case): $\Delta T(H) = 1$ and $\Delta M(H) = 1$.
+
+## Case 2b
+
+When a node with a **marked** parent is deleted, two nodes (the original node and the parent) are moved to the root list. That parent loses its mark, decreasing the overall marked nodes by one.
+One node (the grandparent) is also marked, but that credit is to be used up when one of the grandparent's other children are deleted later, so it is not relevant for this calculation.
+$\Delta T(H) = 2$ and $\Delta M(H) = -1$.
+
+The difference in each parameter is summarised in this table:
+
+|$\Delta$|1|2a|2b|
+|-|-|-|-|
+|T(H)|0|$+1$|$+2$|
+|M(H)|0|$+1$|$-1$|
+
+## Deriving $\alpha$
+
+Consulting the above table, $1 + 2 = 3$ nodes are added to the root list when a mark is added then removed, since a Case 2a creates a case 2b.
+
+After either of these two cases are complete, we want the total change in cost of the heap to be *just* the number of trees added to the root list (*i.e.* $T(H)$) cancelling out $M(H)$.
+This is because an `extract_min` operation will consolidate the stack, using exactly $T(H)$ potential. This leaves us with 0 net potential after a consolidation is done.
+
+We can form the following equation:
+\begin{align*}
+ \Phi(D_i) - \Phi(D_{i-1}) &= 3 \\
+ \Big[\Delta T(H) + \alpha \Delta M(H)\Big]_{i} - \Big[]\Delta T(H) + \alpha \Delta M(H)\Big]_{i-1} &= 3 \\
+ (1+ 1\alpha) - (2 + -\alpha) &= 3 \\
+ (1+ \alpha) - (2 -\alpha) &= 3
+\end{align*}
+
+Then solve for $\alpha$:
+
+\begin{align*}
+ (1 + \alpha) - (2 -\alpha) &= 3 \\
+ 2\alpha - 1 &= 3 \\
+ \alpha &= \frac{3 + 1}{2} \\
+ \alpha &= 2
+\end{align*}
+
+Therefore, the value for $\alpha$ is 2.
+
+## Amortised cost
+
+Plugging this information in gives us: $\Phi = T(H) + 2M(H)$
+
+Since we know that the true cost $tc_i$ for `decrease_key` is $O(1)$ for reasons shown in Part g we can say that: $$ac_i = O(1) + (\Phi(D_{i}) - \Phi(D_{i-1}))$$
+
+In a Case 1 situation, $\Phi(D_{i}) - \Phi(D_{i-1}) = 0$ since simply updating the key without violating the heap property does not affect the potential $\Phi$. This makes Case 1: $ac_i = O(1) + O(1) = O(1)$.
+
+In Case 2a and 2b, we know that once a case 2a is done, it marks a node, creating a case 2b (as explained earlier).
+This means that:
+\begin{align*}
+ ac_i &= O(1) + \Phi(D_i) - \Phi(D_{i-1}) \\
+ &= O(1) + \Big[\Delta T(H) + 2\Delta M(H)\Big]_{i} - \Big[\Delta T(H) + 2\Delta M(H)\Big]_{i-1} \\
+ &= O(1) + (1 + 2 \times 1) - (2 + 2 \times -1) \\
+ &= O(1) + (1 + 2) - (2 - 2) \\
+ &= O(1) + 3\\
+ &= O(1)\\
+\end{align*}
+
+Therefore, using $\alpha = 2$ the amortised cost of `extract_min` is $O(1)$.
+
+# Part j
+
+Intuitively, $\alpha = 2$ makes sense because the marking of a node is exactly two delete operations (and therefore two new root nodes) ``waiting to happen''.
+
+A node can only be marked once before it itself is deleted. In order to ``get rid of'' a mark on a node, two nodes (a child and the node itself) need to be deleted.
+This is why it makes sense for each marking operation to be worth 2 cost.
+
+Another thing to note is that 2 is the only positive integer constant that is related marking nodes, regardless of all parameters for the reasons stated above.
+The number 2 in this case is kind of baked into the idea of marking nodes in a Fibonacci heap.
+