A few m3 tips
Speed Tuning 1.Algorithm 2.Data structures 3.Low level code string streetName1, streetName2; if (streetName1 != streetName2) {... int streetId1, streetId2; if (streetId1 != streetId2) {... Any speed difference?
Debugging Algorithms Start with a very simple test case –Adjacent intersections! –Step / breakpoint code in debugger –Make sure it does what you expect!
Debugging Algorithms Try a slightly harder case –Two intersections apart –Step / breakpoint code in debugger again! –Make sure code behaving exactly as you expect
Bigger Cases: Graphics Helps Hard to see large amounts of data in debugger Use graphics to animate / visualize #define VISUALIZE while (wavefront.size() != 0) { waveElem = wavefront.front(); #ifdef VISUALIZE draw_street_seg (waveElem.edgeID); flushinput(); // Draw right away #endif... Can’t leave this in when I submit (will fail unit tests). How do I turn this off when speed testing & before submitting code?
Milestone 4: Courier Company
Problem Definition Return: low travel time path Starting and ending at some depot And reaching all N delivery intersections Given M courier truck depots and Given N delivery locations M = 3 here, all intersections N = 8 here, all intersections
vector of street segment ids Possible Solution
How? Idea: re-use our m3 path-finding algorithm! // Go from first depot to first delivery wholePath = find_path (depot[0], delivery[0]); // Complete other deliveries, in order they were given for (i = 0; i < N; i++) { path = find_path (delivery[i], delivery[i+1]); wholePath += path; } // Go back to the first depot to drop off the truck path = find_path (delivery[N-1], depot[0]); wholePath += path;
Lots of wasted travel! Possible Solution
Need to optimize delivery order Recall: More Logical Solution
Exhaustive Algorithm? Try all possible delivery orders Pick the one with lowest travel time How many combinations? –M truck depots, N delivery locations –Pick one of M starting locations –Then can pick one of N deliveries to do first –Then one of N-1 for the second –… (repeat until last delivery) –Then M places to drop off truck –M * N * (N-1) * (N-2) * … * 1 * M = M 2 N!
Exhaustive Algorithm? Say M = 6, N = * 40! = 2.9 x Invoke find_path () N+1 times to get path between each intersection Say find_path takes 0.1 s (very good!) 2.9 x * 41 * 0.1 s = 1.2 x s 3.77 x years! Lifetime of universe: ~14 x 10 9 years!
Traveling Salesman Problem We are solving a variation of the traveling salesman problem Computationally hard problem –For N deliveries, no guaranteed optimal (lowest travel time solution) in polynomial time i.e. > O(N k ), for any k Means at least O(2 N ) –Need to use heuristics to solve Most research problems are computationally hard –Integrated circuit design, drug design, transportation network design, …
Pioneer of Complexity Theory Stephen Cook, U of T professor in Computer Science Created the main theory of computationally hard problems NP-complete problems –No polynomial time solution known on conventional computers –Showed that if a method to solve any of these problems in polynomial time was found, then all these problems could be solved in polynomial time –P vs. NP: most famous open problem in computer science 1970: denied tenure at UC Berkeley 1971: published most famous paper 1982: won Turing award