The need for speed
Aren’t today’s computers fast enough? Justification for Better Performance complex applications text graphics video real-time applications computational science
How do we create faster computation? 1) Faster Hardware 2) Faster Algorithms
How to achieve Moore’s Law? 1)Miniaturization 3) Different technologies limitations: manufacturing & speed of light optical computers? biological computers? 2) Multiple processors (supercomputers) quantum computers?
Algorithm speed can be estimated by counting...the number of instructions executed...the number of variable/memory assignments...the number of data comparisons A benchmark is a program execution used to measure execution time. (a single experimental result) Benchmarks are one way to analyze algorithms. empirical approach analytic approach How would you know which algorithm is faster?
Counting the Cost Recall linear search & binary search Number of items Worst CaseExpected Case Number of probes (comparisons) LinearBinary Linear Binary NNlog 2 NN/2log 2 N Note that 1000 processors could search 1000 items with a single probe per processor.
Algorithm to find the maximum Consider 8 numbers. abcdefgh max of a & b max of c & d max of e & f max of g & h max of a - d max of e - h max of a - h comparisons Total number of comparisons?
Algorithm to find the maximum What about 7 numbers. abcdefg max of a & b max of c & d max of e & f max of a - d max of e - g max of a - g Total number of comparisons?
Algorithm to find the maximum What about 6 numbers. abcdef max of a & b max of c & d max of e & f max of a - d max of a - f Total number of comparisons?
Algorithm to find the maximum The performance of this algorithm is similar to the linear search. Number of items Number of comparisons NN-1 However, using many processors doesn’t help as much for the maximum finder algorithm.
Sorting Algorithms Sorting algorithms rearrange items from smallest to largest (or largest to smallest). One sorting algorithm: - repeatedly find the maximum and move it immediately ahead of all prior maximums. Example (sort 100 values) Step 1 - find the maximum of 100 values 99 comparisons Step 2 - find the maximum of 99 values 98 comparisons Step 3 - find the maximum of 98 values 97 comparisons Total comparisons for sorting 100: Total comparisons for sorting N: (N-1)+(N-2)+(N-3) = N*(N-1) 2
Comparing Algorithm Performance binary search linear search sorting algorithm
Are there slower algorithms? Consider an algorithm to crack your password. One such algorithm attempts every possible keystroke. Analysis Password lengthComparisons *94 = 8, *94*94 = 830, = 6 x N 94 N......
Comparing Algorithm Performance password cracker other algorithms
Functional Growth x (note 1) (note 2) nlog 2 nn2n2 94 n note 1 - roughly five years of computation for a 1 petaflop supercomputer note 2 - about 5 times the age of the universe linear search binary search sort password cracker not practical for any large number of items
Important Results #1 -- There are algorithms that take too long to be practically executed on a computer. #2 -- These slow algorithms tend of be of the type that attempt a brute force approach of attempting all possible combinations. #3 -- Moore’s Law cannot fix the problem.
So what do we know? Many algorithms can be processed by modern computers. Some algorithms will be processed with faster computers. Computers will never be fast enough for some algorithms.