Amortized Analysis - PowerPoint PPT Presentation

About This Presentation
Title:

Amortized Analysis

Description:

Competitive analysis. Make quantitative statements ... Amortized analysis. Any sequence of n insert / delete operations take O(n) time. ... Splay Tree Analysis ... – PowerPoint PPT presentation

Number of Views:360
Avg rating:3.0/5.0
Slides: 48
Provided by: kevin59
Category:

less

Transcript and Presenter's Notes

Title: Amortized Analysis


1
Amortized Analysis
Some of these lecture slides are adaptedfrom
CLRS.
2
Beyond Worst Case Analysis
  • Worst-case analysis.
  • Analyze running time as function of worst input
    of a given size.
  • Average case analysis.
  • Analyze average running time over some
    distribution of inputs.
  • Ex quicksort.
  • Amortized analysis.
  • Worst-case bound on sequence of operations.
  • Ex splay trees, union-find.
  • Competitive analysis.
  • Make quantitative statements about online
    algorithms.
  • Ex paging, load balancing.

3
Amortized Analysis
  • Amortized analysis.
  • Worst-case bound on sequence of operations.
  • no probability involved
  • Ex union-find.
  • sequence of m union and find operations starting
    with n singleton sets takes O((mn) ?(n)) time.
  • single union or find operation might be
    expensive, but only ?(n) on average

4
Dynamic Table
  • Dynamic tables.
  • Store items in a table (e.g., for open-address
    hash table, heap).
  • Items are inserted and deleted.
  • too many items inserted ? copy all items to
    larger table
  • too many items deleted ? copy all items to
    smaller table
  • Amortized analysis.
  • Any sequence of n insert / delete operations take
    O(n) time.
  • Space used is proportional to space required.
  • Note actual cost of a single insert / delete
    can be proportional to n if it triggers a table
    expansion or contraction.
  • Bottleneck operation.
  • We count insertions (or re-insertions) and
    deletions.
  • Overhead of memory management is dominated by (or
    proportional to) cost of transferring items.

5
Dynamic Table Insert
  • Aggregate method.
  • Sequence of n insert ops takes O(n) time.
  • Let ci cost of ith insert.

6
Dynamic Table Insert
  • Accounting method.
  • Charge each insert operation 3 (amortized cost).
  • use 1 to perform immediate insert
  • store 2 in with new item
  • When table doubles
  • 1 re-inserts item
  • 1 re-inserts another old item

7
Dynamic Table Insert and Delete
  • Insert and delete.
  • Table overflows ? double table size.
  • Table ? ½ full ? halve table size.
  • Bad idea can cause thrashing.

1
1
1
1
2
2
2
2
3
3
3
3
4
4
4
4
5
5
8
Dynamic Table Insert and Delete
  • Insert and delete.
  • Table overflows ? double table size.
  • Table ? ¼ full ? halve table size.

9
Dynamic Table Insert and Delete
  • Accounting analysis.
  • Charge each insert operation 3 (amortized cost).
  • use 1 to perform immediate insert
  • store 2 with new item
  • When table doubles
  • 1 re-inserts item
  • 1 re-inserts another old item
  • Charge each delete operation 2 (amortized cost).
  • use 1 to perform delete
  • store 1 in emptied slot
  • When table halves
  • 1 in emptied slot pays to re-insert a remaining
    item into new half-size table

10
Dynamic Table Delete
11
Dynamic Table Insert and Delete
  • Theorem. Sequence of n inserts and deletes takes
    O(n) time.
  • Amortized cost of insert 3.
  • Amortized cost of delete 2.

12
Binary Search Tree
  • Binary tree in "sorted" order.
  • Maintain ordering property for ALL sub-trees.

13
Binary Search Tree
  • Binary tree in "sorted" order.
  • Maintain ordering property for ALL sub-trees.

14
Binary Search Tree
  • Binary tree in "sorted" order.
  • Maintain ordering property for ALL sub-trees.

15
Binary Search Tree
  • Insert, delete, find (symbol table).
  • Amount of work proportional to height of tree.
  • O(N) in "unbalanced" search tree.
  • O(log N) in "balanced" search tree.
  • Types of BSTs.
  • AVL trees, 2-3-4 trees, red-black trees.
  • Treaps, skip lists, splay trees.
  • BST vs. hash tables.
  • Guaranteed vs. expected performance.
  • Growing and shrinking.
  • Augmented data structures order statistic
    trees, interval trees.

Search
Insert
16
Splay Trees
  • Splay trees (Sleator-Tarjan, 1983a).
    Self-adjusting BST.
  • Most frequently accessed items are close to root.
  • Tree automatically reorganizes itself after each
    operation.
  • no balance information is explicitly maintained
  • Tree remains "nicely" balanced, but height can
    potentially be n - 1.
  • Sequence of m ops involving n inserts takes O(m
    log n) time.
  • Theorem (Sleator-Tarjan, 1983a). Splay trees are
    as efficient (in amortized sense) as static
    optimal BST.
  • Theorem (Sleator-Tarjan, 1983b). Shortest
    augmenting path algorithm for max flow can be
    implemented in O(mn log n) time.
  • Sequence of mn augmentations takes O(mn log n)
    time!
  • Splay trees used to implement dynamic trees
    (link-cut trees).

17
Splay
  • Find(x, S) Determine whether element x is in
    splay tree S.
  • Insert(x, S) Insert x into S if it is not
    already there.
  • Delete(x, S) Delete x from S if it is there.
  • Join(S, S') Join S and S' into a single splay
    tree, assuming that x lt y for all x ? S, and y
    ? S'.
  • All operations are implemented in terms of basic
    operation
  • Splay(x, S) Reorganize splay tree S so that
    element x is at the root if x ? S otherwise
    the new root is either max k ? S k lt x or
    min k ? S k gt x .
  • Implementing Find(x, S).
  • Call Splay(x, S).
  • If x is root, then return x otherwise return NO.

18
Splay
  • Implementing Join(S, S').
  • Call Splay(?, S) so that largest element of S is
    at root and all other elements are in left
    subtree.
  • Make S' the right subtree of the root of S.
  • Implementing Delete(x, S).
  • Call Splay(x, S) to bring x to the root if it is
    there.
  • Remove x let S' and S'' be the resulting
    subtrees.
  • Call Join(S', S'').
  • Implementing Insert(x, S).
  • Call Splay(x, S) and break tree at root to form
    S' and S''.
  • Call Join(Join(S', x), S'').

19
Implementing Splay(x, S)
  • Splay(x, S) do following operations until x is
    root.
  • ZIG If x has a parent but no grandparent, then
    rotate(x).
  • ZIG-ZIG If x has a parent y and a grandparent,
    and if both x and y are either both left children
    or both right children.
  • ZIG-ZAG If x has a parent y and a grandparent,
    and if one of x, y is a left child and the other
    is a right child.

root
x
y
y
A
x
C
ZIG(x)
A
B
C
B
ZAG(y)
20
Implementing Splay(x, S)
  • Splay(x, S) do following operations until x is
    root.
  • ZIG If x has a parent but no grandparent.
  • ZIG-ZIG If x has a parent y and a grandparent,
    and if both x and y are either both left children
    or both right children.
  • ZIG-ZAG If x has a parent y and a grandparent,
    and if one of x, y is a left child and the other
    is a right child.

ZIG-ZIG
21
Implementing Splay(x, S)
  • Splay(x, S) do following operations until x is
    root.
  • ZIG If x has a parent but no grandparent.
  • ZIG-ZIG If x has a parent y and a grandparent,
    and if both x and y are either both left children
    or both right children.
  • ZIG-ZAG If x has a parent y and a grandparent,
    and if one of x, y is a left child and the other
    is a right child.

ZIG-ZAG
22
Splay Example
  • Apply Splay(1, S) to tree S

10
9
8
7
6
ZIG-ZIG
5
4
3
2
1
23
Splay Example
  • Apply Splay(1, S) to tree S

10
9
8
7
ZIG-ZIG
6
5
4
1
2
3
24
Splay Example
  • Apply Splay(1, S) to tree S

10
9
8
7
ZIG-ZIG
6
1
4
5
2
3
25
Splay Example
  • Apply Splay(1, S) to tree S

10
9
8
1
ZIG-ZIG
6
7
4
2
5
3
26
Splay Example
  • Apply Splay(1, S) to tree S

10
1
8
9
6
ZIG
7
4
2
5
3
27
Splay Example
  • Apply Splay(1, S) to tree S

1
10
8
9
6
7
4
2
5
3
28
Splay Example
  • Apply Splay(2, S) to tree S

2
1
10
1
8
4
8
10
6
3
9
6
9
Splay(2)
7
4
5
7
2
5
3
29
Splay Tree Analysis
  • Definitions.
  • Let S(x) denote subtree of S rooted at x.
  • S number of nodes in tree S.
  • ?(S) rank ? log S ?.
  • ?(x) ? (S(x)).

2
S(8)
1
8
S 10 ?(2) 3 ?(8) 3 ?(4) 2 ?(6) 1 ?(5)
0
4
10
6
3
9
5
7
30
Splay Tree Analysis
  • Splay invariant node x always has at least ?(x)
    credits on deposit.
  • Splay lemma each splay(x, S) operation requires
    ? 3(?(S) - ?(x)) 1 credits to perform the
    splay operation and maintain the invariant.
  • Theorem A sequence of m operations involving n
    inserts takesO(m log n) time.
  • Proof
  • ?(x) ? ? log n ? ? at most 3 ? log n ? 1
    credits are needed for each splay operation.
  • Find, insert, delete, join all take constant
    number of splays plus low-level operations
    (pointer manipulations, comparisons).
  • Inserting x requires ? ? log n ? credits to be
    deposited to maintain invariant for new node x.
  • Joining two trees requires ? ? log n ? credits
    to be deposited to maintain invariant for new
    root.

31
Splay Tree Analysis
  • Splay invariant node x always has at least ?(x)
    credits on deposit.
  • Splay lemma each splay(x, S) operation requires
    ? 3(?(S) - ?(x)) 1 credits to perform the
    splay operation and maintain the invariant.
  • Proof of splay lemma Let ?(x) and ?'(x) be rank
    before and single ZIG, ZIG-ZIG, or ZIG-ZAG
    operation on tree S.
  • We show invariant is maintained (after paying for
    low-level operations) using at most
  • 3(?(S) - ?(x)) 1 credits for each ZIG
    operation.
  • 3(?'(x) - ?(x)) credits for each ZIG-ZIG
    operation.
  • 3(?'(x) - ?(x)) credits for each ZIG-ZAG
    operation.
  • Thus, if a sequence of of these are done to move
    x up the tree, we get a telescoping sum ? total
    credits ? 3(?(S) - ?(x)) 1.

32
Splay Tree Analysis
  • Proof of splay lemma (ZIG) It takes ? 3(?(S) -
    ?(x)) 1 credits to perform a ZIG operation and
    maintain the splay invariant.
  • In order to maintain invariant, we must pay
  • Use extra credit to pay forlow-level operations.

root
S
S'
y
x
x
y
C
A
ZIG
A
B
C
B
?(y) ?'(x)
?'(x) ?(S)
33
Splay Tree Analysis
  • Proof of splay lemma (ZIG-ZIG) It takes ?
    3(?'(x) - ?(x)) credits to perform a ZIG-ZIG
    operation and maintain the splay invariant.
  • If ?'(x) gt ?(x), then can afford topay for
    constant number of low-leveloperations and
    maintain invariant using ? 3(?'(x) - ?(x))
    credits.

S
S'
z
y
D
x
C
ZIG-ZIG
A
B
34
Splay Tree Analysis
  • Proof of splay lemma (ZIG-ZIG) It takes ?
    3(?'(x) - ?(x)) credits to perform a ZIG-ZIG
    operation and maintain the splay invariant.
  • Nasty case ?(x) ?'(x).
  • We show in this case ?'(x) ?'(y) ?'(z) lt
    ?(x) ?(y) ?(z).
  • don't need any credit to pay for invariant
  • 1 credit left to pay for low-level operations
  • so, for contradiction, suppose ?'(x) ?'(y)
    ?'(z) ? ?(x) ?(y) ?(z).
  • Since ?(x) ?'(x) ?(z), by monotonicity ?(x)
    ?(y) ?(z).
  • After some algebra, it follows that ?(x) ?'(z)
    ?(z).
  • Let a 1 A B, b 1 C D, then?
    log a ? ? log b ? ? log (ab1) ?
  • WLOG assume b ? a.

S
S'
z
y
D
x
C
ZIG-ZIG
A
B
35
Splay Tree Analysis
  • Proof of splay lemma (ZIG-ZAG) It takes ?
    3(?'(x) - ?(x)) credits to perform a ZIG-ZAG
    operation and maintain the splay invariant.
  • Argument similar to ZIG-ZIG.

ZIG-ZAG
36
Augmented Search Trees
37
Interval Trees
  • Support following operations.
  • Interval-Insert(i, S) Insert interval i (?i,
    ri ) into tree S.
  • Interval-Delete(i, S) Delete interval i (?i,
    ri ) from tree S.
  • Interval-Find(i, S) Return an interval x that
    overlaps i, or report that no such interval
    exists.

(17, 19)
(7, 10)
(15, 18)
(5, 11)
(4, 8)
(21, 23)
38
Interval Trees
  • Key ideas
  • Tree nodes contain interval.
  • BST keyed on left endpoint.

(17, 19)
(7, 10)
(15, 18)
(5, 11)
(4, 8)
(21, 23)
(17, 19)
(5, 11)
(21, 23)
(4, 8)
(15, 18)
(7, 10)
Key
Interval
39
Interval Trees
  • Key ideas
  • Tree nodes contain interval.
  • BST keyed on left endpoint.
  • Additional info store maxendpoint in subtree
    rootedat node.

(17, 19)
(7, 10)
(15, 18)
(5, 11)
(4, 8)
(21, 23)
(17, 19)
23
(5, 11)
18
(21, 23)
23
(4, 8)
8
(15, 18)
18
max in subtree
(7, 10)
10
40
Finding an Overlapping Interval
  • Interval-Find(i, S) return an interval x that
    overlaps i (?i, ri ), or report that no such
    interval exists.

(17, 19)
23
(5, 11)
18
(21, 23)
23
(4, 8)
8
(15, 18)
18
(7, 10)
10
41
Finding an Overlapping Interval
  • Interval-Find(i, S) return an interval x that
    overlaps i (?i, ri ), or report that no such
    interval exists.
  • Case 1 (right). If search goes right,then there
    exists an overlap in rightsubtree or no overlap
    in either.
  • Proof. Suppose no overlap in right.
  • leftx NULL ?no overlap in left.
  • maxleftx lt ?i ?no overlap in left.

leftx
i (?i, ri )
max
42
Finding an Overlapping Interval
  • Interval-Find(i, S) return an interval x that
    overlaps i (?i, ri ), or report that no such
    interval exists.
  • Case 2 (left). If search goes left,then there
    exists an overlap in leftsubtree or no overlap
    in either.
  • Proof. Suppose no overlap in left.
  • ?i ? maxleftx rj forsome interval j in
    left subtree.
  • Since i and j don't overlap, we have ?i ? ri ?
    ?j ? rj.
  • Tree sorted by ? ? for any intervalk in right
    subtree ri ? ?j ? ?k ?no overlap in right
    subtree.

i (?i, ri )
j (?j, rj)
k (?k, rk)
43
Interval Trees Running Time
  • Need to maintain augmented data structure during
    tree-modifying ops.
  • Rotate can fix sizes in O(1) time by looking at
    children

(6, 20)
?
35
(11, 35)
35
(6, 20)
20
(11, 35)
?
35
C30
A14
ZIG
A14
B19
C30
B19
ZAG
44
VLSI Database Problem
  • VLSI database problem.
  • Input integrated circuit represented as a list
    of rectangles.
  • Goal decide whether any two rectangles overlap.
  • Algorithm idea.
  • Move a vertical "sweep line" from left to right.
  • Store set of rectangles that intersect the sweep
    line in an interval search tree (using y interval
    of rectangle).

45
VLSI Database Problem
46
Order Statistic Trees
  • Add following two operations to BST.
  • Select(i, S) Return ith smallest key in tree S.
  • Rank(i, S) Return rank of x in linear order of
    tree S.
  • Key idea store size of subtrees in nodes.

Subtree size
Key
47
Order Statistic Trees
  • Need to ensure augmented data structure can be
    maintained during tree-modifying ops.
  • Rotate can fix sizes in O(1) time by looking at
    children.

ZIG
Z17
V6
X4
ZAG
Write a Comment
User Comments (0)
About PowerShow.com