1 / 20

APPROXIMATION ALGORITHMS

Explore the use of approximation algorithms in solving complex problems such as bin packing, knapsack, traveling salesperson, graph colouring, and systems of equations. Learn how to trim exhaustive searches, implement time-outs, and strike a balance between time and accuracy.

donaldp
Download Presentation

APPROXIMATION ALGORITHMS

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. APPROXIMATION ALGORITHMS Dario Fanucchi

  2. Why Approximate? Exact Solution Exists But Searching… Takes time

  3. Outline Specific Algorithms: • Bin Packing • Real Valued Knapsack • Traveling Salesperson • Graph Colouring • Systems of Equations General Considerations • Trimming an exhaustive search • Time-outs and implementation

  4. Packing the Rubbish • The Problem: • n real numbers {s1, s2, .., sn} in [0;1] • pack them into minimum number of bins of size 1. Exact Algorithm = O(nn/2) Approximate Algorithm(FFD) = O(n2) At most 0.3n extra bins used.

  5. FFD Strategy First Fit Decreasing Strategy • Sort the values of si • Pack values into first bins they fit in. S = {0.2, 0.4, 0.3, 0.4, 0.2, 0.5, 0.2, 0.8} Sorted: {0.8, 0.5, 0.4, 0.4, 0.3, 0.2, 0.2, 0.2} 0.2(s6 ) 0.2(s7 ) 0.4(s3 ) 0.3(s5 ) 0.8(s1 ) 0.5(s2 ) 0.4(s4 ) 0.2(s9 )

  6. Packing the Bags • The Problem: • Knapsack: real (weight, value) pairs • Find a combination of maximal value that fits in boundry weight C. Problem is NP-complete Many Approximations: Time vs. Accuracy Tradeoff…

  7. The Algorithm • sKnapk Algorithm • Choose k • Generate k-subsets of items • Greedily add to subsets • Take maximum

  8. How close are we? • sKnapk accuracy • Ratio of 1+1/k to optimal!! • O(knk+1) • Choose k wisely!

  9. World Tour • The Problem: • Traveling Salesperson Problem • Find minimal tour of the graph that visits each vertex exactly once. Famous NP-complete problem Several Approximation strategies exist But none is very accurate

  10. Nearest Neighbour • Start at an arbitrary vertex • At each step add the shortest edge to the end of the path • No guarantee of being within a constant bound of accuracy. 20 1 2 15 35 10 25 4 3 12

  11. Shortest-Link • Works like Kruskal’s Algorithm • Find shortest edges • Ensure no cycles • Ensure no vertex with 3 edges • Add edge 20 1 2 15 35 10 25 4 3 12

  12. Salesperson’s Dilemma • Exact = Time Drain? • Approximate = only a guess? • Solution: Branch and Bound?

  13. Colouring in • The Problem: • Graph colouring problem • Exhibit a colouring of vertices with the smallest number of colours such that no edge connects two vertices of the same colour NP-Complete problem Like TSP, approximations are unbounded

  14. The Greedy One • Sequential Colouring Strategy • Assign minimum possible colour to each vertex that is not assigned to one of it’s neighbours.

  15. Widgerson Arrives • Recursive Algorithm • Base Case: 2 Colourable Graphs • Find the subgraph of the Neighbourhood of a given vertex, recursively colour this subgraph. • At most 3n colours for an n-colourable graph.

  16. Trace of Widgerson • First run recursively on highest degree vertex • Then run SC on the rest of the graph, deleting edges incident to N(v)

  17. Solving Systems of Equations in Linear Time • Exact Algorithm = Gaussian Elimination: O(n3) • Approximate Algorithm=Jacobi Method: Faster • x[m+1]=D-1[b-(L+U)x[m]] • xk[m+1] =(1/akk)(bk-ak1x1[m]-…-aknx1[m])

  18. Gardening • Trimming exhaustive search • Branch&Bound • Backtracking • Mark a node as infeasible, and stop searching that point.

  19. Leave while you’re ahead • Keep track always of the best solution so far • Write this out when time is up • Keeping track of time (C++) #include<ctime> clock_t t1, t2; t1 = clock(); //do stuff t2 = clock(); double Time; Time=double(t1)-double(t2); Time/=CLOCKS_PER_SEC;

  20. In Summation • When exact code takes too long (and there are marks for being close to correct) approximate. • Trade-off: Time vs. Accuracy • Search for simplifications to problems that do not need Approx. Solutions.

More Related