J. Elder COSC 3101N Thinking about Algorithms Abstractly Lecture 1. Introduction.

Slides:



Advertisements
Similar presentations
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science Anupam Gupta Danny Sleator CS Fall 2010 Lecture.
Advertisements

Analysis of Algorithms
5/1/20151 Analysis of Algorithms Introduction. 5/1/20152 Are you want to be a computer scientist?
1 Welcome Jeff Edmonds York University Lecture 0 COSC 4111 Jeff Edmonds CSB 3044, ext
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science Victor Adamchik Danny Sleator CS Spring 2010 Lecture.
Spring 2015 Lecture 5: QuickSort & Selection
Introduction Credits: Steve Rudich, Jeff Edmond, Ping Xuan.
Data Structures Review Session 1
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science Steven RudichCS Spring 2004 Lecture 16March 4,
Recursion Credits: Jeff Edmonds, Ping Xuan. MULT(X,Y): If |X| = |Y| = 1 then RETURN XY Break X into a;b and Y into c;d e = MULT(a,c) and f =MULT(b,d)
On Time Versus Input Size Great Theoretical Ideas In Computer Science Steven RudichCS Spring 2004 Lecture 15March 2, 2004Carnegie Mellon University.
Introduction By Jeff Edmonds York University COSC 3101 Lecture 1 So you want to be a computer scientist? Grade School Revisited: How To Multiply Two Numbers.
1 Welcome Jeff Edmonds York University Lecture 1 COSC 3101 Jeff Edmonds CSB 3044, ext
Design and Analysis of Algorithms – Chapter 51 Divide and Conquer (I) Dr. Ying Lu RAIK 283: Data Structures & Algorithms.
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science S. Rudich V. Adamchik CS Spring 2006 Lecture 18March.
Arithmetic.
COMPSCI 102 Introduction to Discrete Mathematics.
CSE 3101E Design and Analysis of Algorithms Prof. J. Elder.
MA/CSSE 473 Day 03 Asymptotics A Closer Look at Arithmetic With another student, try to write a precise, formal definition of “t(n) is in O(g(n))”
Divide-and-Conquer 7 2  9 4   2   4   7
Analysis of Algorithm Lecture 3 Recurrence, control structure and few examples (Part 1) Huma Ayub (Assistant Professor) Department of Software Engineering.
1 Welcome Jeff Edmonds York University Lecture 0 COSC 2011 Jeff Edmonds CSB 3044, ext
Lecture 8. How to Form Recursive relations 1. Recap Asymptotic analysis helps to highlight the order of growth of functions to compare algorithms Common.
Computer Algorithms Ch. 2
Great Theoretical Ideas in Computer Science.
2IL50 Data Structures Fall 2015 Lecture 2: Analysis of Algorithms.
Recursive Algorithms Introduction Applications to Numeric Computation.
Recursion Jeff Edmonds York University COSC 6111 Lecture 3 Friends & Steps for Recursion Derivatives Recursive Images Multiplying Parsing Ackermann.
Divide and Conquer Andreas Klappenecker [based on slides by Prof. Welch]
Analyzing algorithms & Asymptotic Notation BIO/CS 471 – Algorithms for Bioinformatics.
CS 61B Data Structures and Programming Methodology July 28, 2008 David Sun.
CMPT 438 Algorithms. Why Study Algorithms? Necessary in any computer programming problem ▫Improve algorithm efficiency: run faster, process more data,
CSIS 123A Lecture 9 Recursion Glenn Stevenson CSIS 113A MSJC.
Program Efficiency & Complexity Analysis. Algorithm Review An algorithm is a definite procedure for solving a problem in finite number of steps Algorithm.
CS 361 – Chapters 8-9 Sorting algorithms –Selection, insertion, bubble, “swap” –Merge, quick, stooge –Counting, bucket, radix How to select the n-th largest/smallest.
Algorithm Analysis CS 400/600 – Data Structures. Algorithm Analysis2 Abstract Data Types Abstract Data Type (ADT): a definition for a data type solely.
COMPSCI 102 Introduction to Discrete Mathematics.
Introduction Pizzanu Kanongchaiyos, Ph.D.
Recurrences David Kauchak cs161 Summer Administrative Algorithms graded on efficiency! Be specific about the run times (e.g. log bases) Reminder:
Divide and Conquer Andreas Klappenecker [based on slides by Prof. Welch]
COSC 3101Winter, 2004 COSC 3101 Design and Analysis of Algorithms Lecture 2. Relevant Mathematics: –The time complexity of an algorithm –Adding made easy.
Lecture 5 Today, how to solve recurrences We learned “guess and proved by induction” We also learned “substitution” method Today, we learn the “master.
Divide and Conquer. Recall Divide the problem into a number of sub-problems that are smaller instances of the same problem. Conquer the sub-problems by.
Divide and Conquer Faculty Name: Ruhi Fatima Topics Covered Divide and Conquer Matrix multiplication Recurrence.
2IL50 Data Structures Spring 2016 Lecture 2: Analysis of Algorithms.
Review Quick Sort Quick Sort Algorithm Time Complexity Examples
BITS Pilani Pilani Campus Data Structure and Algorithms Design Dr. Maheswari Karthikeyan Lecture1.
Grade School Revisited: How To Multiply Two Numbers CS Lecture 4 2 X 2 = 5.
Complexity of Algorithms Fundamental Data Structures and Algorithms Ananda Guna January 13, 2005.
On Time Versus Input Size Great Theoretical Ideas In Computer Science S. Rudich V. Adamchik CS Spring 2006 Lecture 17March 21, 2006Carnegie Mellon.
CMPT 438 Algorithms.
CS 3343: Analysis of Algorithms
Great Theoretical Ideas in Computer Science
Great Theoretical Ideas in Computer Science
How To Multiply Two Numbers
CS 3343: Analysis of Algorithms
CS 3343: Analysis of Algorithms
Grade School Revisited: How To Multiply Two Numbers
CS 3343: Analysis of Algorithms
By Jeff Edmonds York University
On Time Versus Input Size
Data Structures Review Session
Grade School Revisited: How To Multiply Two Numbers
Introduction to Discrete Mathematics
Divide-and-Conquer 7 2  9 4   2   4   7
Divide and Conquer Merge sort and quick sort Binary search
Introduction to Discrete Mathematics
Presentation transcript:

J. Elder COSC 3101N Thinking about Algorithms Abstractly Lecture 1. Introduction

J. Elder COSC 3101N So you want to be a computer scientist?

J. Elder COSC 3101N Is your goal to be a mundane programmer?

J. Elder COSC 3101N Or a great leader and thinker?

J. Elder COSC 3101N Original Thinking

J. Elder COSC 3101N Boss assigns task: Given today’s prices of pork, grain, sawdust, … Given constraints on what constitutes a hotdog. Make the cheapest hotdog. Everyday industry asks these questions.

J. Elder COSC 3101N Um? Tell me what to code. With more suffocated software engineering systems, the demand for mundane programmers will diminish. Your answer:

J. Elder COSC 3101N Your answer: I learned this great algorithm that will work. Soon all known algorithms will be available in libraries.

J. Elder COSC 3101N Your answer: I can develop a new algorithm for you. Great thinkers will always be needed.

J. Elder COSC 3101N Content: An up to date grasp of fundamental problems and solutions Method: Principles and techniques to solve the vast array of unfamiliar problems that arise in a rapidly changing field The future belongs to the computer scientist who has Rudich

J. Elder COSC 3101N Course Content A list of algorithms. Learn their code. Trace them until you are convinced that they work. Implement them. class InsertionSortAlgorithm extends SortAlgorithm { void sort(int a[]) throws Exception { for (int i = 1; i < a.length; i++) { int j = i; int B = a[i]; while ((j > 0) && (a[j-1] > B)) { a[j] = a[j-1]; j--; } a[j] = B; }}

J. Elder COSC 3101N Course Content A survey of algorithmic design techniques. Abstract thinking. How to develop new algorithms for any problem that may arise.

J. Elder COSC 3101N Study: Many experienced programmers were asked to code up binary search.

J. Elder COSC 3101N Study: Many experienced programmers were asked to code up binary search. 80% got it wrong Good thing is was not for a nuclear power plant.

J. Elder COSC 3101N What did they lack?

J. Elder COSC 3101N What did they lack? Formal proof methods?

J. Elder COSC 3101N What did they lack? Formal proof methods? Yes, likely Industry is starting to realize that formal methods are important. But even without formal methods …. ?

J. Elder COSC 3101N What did they lack? Fundamental understanding of algorithmic design techniques. Abstract thinking.

J. Elder COSC 3101N Course Content Notations, analogies, and abstractions for developing, thinking about, and describing algorithms so correctness is transparent

J. Elder COSC 3101N Slide Credits Some materials also due to Prof. A. Mirzaian (York). These in turn include some slides created by Prof. S. Rudich of Carnegie Mellon University. The slides for these 12 lectures have been adapted from slides created by Prof. J. Edmonds (York).

J. Elder COSC 3101N Please feel free to ask questions!

J. Elder COSC 3101N Useful Learning Techniques

J. Elder COSC 3101N Read Ahead You are expected to read the textbook and lecture notes before the lecture. This will facilitate more productive discussion during class.

J. Elder COSC 3101N Explaining We are going to test you on your ability to explain the material. Hence, the best way of studying is to explain the material over and over again out loud to yourself, to each other, and to your stuffed bear.

J. Elder COSC 3101N Day Dream Mathematics is not all linear thinking. Allow the essence of the material to seep into your subconscious Pursue ideas that percolate up and flashes of inspiration that appear. While going along with your day

J. Elder COSC 3101N Be Creative Ask questions. Why is it done this way and not that way?

J. Elder COSC 3101N Guesses and Counter Examples Guess at potential algorithms for solving a problem. Look for input instances for which your algorithm gives the wrong answer.

J. Elder COSC 3101N Refinement: Rudich The best solution comes from a process of repeatedly refining and inventing alternative solutions

J. Elder COSC 3101N Grade School Revisited: How To Multiply Two Numbers 2 X 2 = 5 A Few Example Algorithms Rudich

J. Elder COSC 3101N Complex Numbers Remember how to multiply 2 complex numbers? (a+bi)(c+di) = [ac –bd] + [ad + bc] i Input: a,b,c,d Output: ac-bd, ad+bc If a real multiplication costs $1 and an addition cost a penny. What is the cheapest way to obtain the output from the input? Can you do better than $4.02?

J. Elder COSC 3101N Input: a,b,c,d Output: ac-bd, ad+bc m 1 = ac m 2 = bd A 1 = m 1 – m 2 = ac-bd m 3 = (a+b)(c+d) = ac + ad + bc + bd A 2 = m 3 – m 1 – m 2 = ad+bc Gauss’ $3.05 Method:

J. Elder COSC 3101N Question: The Gauss method saves one multiplication out of four. It requires 25% less work. Could there be a context where performing 3 multiplications for every 4 provides a more dramatic savings?

J. Elder COSC 3101N Odette Bonzo

J. Elder COSC 3101N How to add 2 n-bit numbers. ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** +

J. Elder COSC 3101N How to add 2 n-bit numbers. *** *** ** ** ** ** ** ** ** ** ** ** *** *** ** ** ** ** ** ** ** ** +

J. Elder COSC 3101N How to add 2 n-bit numbers. *** *** ** ** ** ** ** ** ** ** *** *** **** **** ** ** ** ** ** ** ** ** +

J. Elder COSC 3101N How to add 2 n-bit numbers. *** *** ** ** ** ** ** ** *** *** **** **** **** **** ** ** ** ** ** ** ** ** +

J. Elder COSC 3101N How to add 2 n-bit numbers. *** *** ** ** ** ** *** *** **** **** **** **** **** **** ** ** ** ** ** ** ** ** +

J. Elder COSC 3101N How to add 2 n-bit numbers. *** *** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** * * * * + * ** *

J. Elder COSC 3101N Time complexity of grade school addition *** *** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** **** + * ** * **** **** T(n) = The amount of time grade school addition uses to add two n-bit numbers = θ(n) = linear time. On any reasonable computer adding 3 bits can be done in constant time.

J. Elder COSC 3101N # of bits in numbers time f = θ (n) means that f can be sandwiched between two lines

J. Elder COSC 3101N Is there a faster way to add? QUESTION: Is there an algorithm to add two n-bit numbers whose time grows sub-linearly in n?

J. Elder COSC 3101N Any algorithm for addition must read all of the input bits Suppose there is a mystery algorithm that does not examine each bit Give the algorithm a pair of numbers. There must be some unexamined bit position i in one of the numbers If the algorithm is not correct on the numbers, we found a bug If the algorithm is correct, flip the bit at position i and give the algorithm the new pair of numbers. It give the same answer as before so it must be wrong since the sum has changed

J. Elder COSC 3101N So any algorithm for addition must use time at least linear in the size of the numbers. Grade school addition is essentially as good as it can be.

J. Elder COSC 3101N How to multiply 2 n-bit numbers. X * * * * * * * * * * * * * * * * * * * * * * * * * * * * n2n2

J. Elder COSC 3101N I get it! The total time is bounded by cn 2.

J. Elder COSC 3101N Grade School Addition: Linear time Grade School Multiplication: Quadratic time No matter how dramatic the difference in the constants the quadratic curve will eventually dominate the linear curve # of bits in numbers time

J. Elder COSC 3101N Neat! We have demonstrated that as things scale multiplication is a harder problem than addition. Mathematical confirmation of our common sense.

J. Elder COSC 3101N Don’t jump to conclusions! We have argued that grade school multiplication uses more time than grade school addition. This is a comparison of the complexity of two algorithms. To argue that multiplication is an inherently harder problem than addition we would have to show that no possible multiplication algorithm runs in linear time.

J. Elder COSC 3101N Grade School Addition: θ (n) time Grade School Multiplication: θ (n 2 ) time Is there a clever algorithm to multiply two numbers in linear time?

J. Elder COSC 3101N Despite years of research, no one knows! If you resolve this question, York will give you a PhD!

J. Elder COSC 3101N Is there a faster way to multiply two numbers than the way you learned in grade school?

J. Elder COSC 3101N Divide And Conquer (an approach to faster algorithms) DIVIDE a problem into smaller subproblems CONQUER them recursively GLUE the answers together so as to obtain the answer to the larger problem

J. Elder COSC 3101N Multiplication of 2 n-bit numbers X = Y = X = a 2 n/2 + b Y = c 2 n/2 + d XY = ac 2 n + (ad+bc) 2 n/2 + bd ab cd

J. Elder COSC 3101N Multiplication of 2 n-bit numbers X = Y = XY = ac 2 n + (ad+bc) 2 n/2 + bd ab cd MULT(X,Y): If |X| = |Y| = 1 then RETURN XY Break X into a;b and Y into c;d RETURN MULT(a,c) 2 n + (MULT(a,d) + MULT(b,c)) 2 n/2 + MULT(b,d)

J. Elder COSC 3101N Time required by MULT T(n) = time taken by MULT on two n-bit numbers What is T(n)? What is its growth rate? Is it θ(n 2 )?

J. Elder COSC 3101N Recurrence Relation T(1) = k for some constant k T(n) = 4 T(n/2) + k’ n + k’’ for some constants k’ and k’’ MULT(X,Y): If |X| = |Y| = 1 then RETURN XY Break X into a;b and Y into c;d RETURN MULT(a,c) 2 n + (MULT(a,d) + MULT(b,c)) 2 n/2 + MULT(b,d)

J. Elder COSC 3101N Let’s be concrete T(1) = 1 T(n) = 4 T(n/2) + n How do we unravel T(n) so that we can determine its growth rate?

J. Elder COSC 3101N Technique 1: (Substitution) Recurrence Relation: T(1) = 1 & T(n) = 4T(n/2) + n Guess: G(n) = 2n 2 – n Verify: Left Hand SideRight Hand Side T(1) = 2(1) 2 – 1 T(n) = 2n 2 – n 1 4T(n/2) + n = 4 [2( n / 2 ) 2 – ( n / 2 )] + n = 2n 2 – n

J. Elder COSC 3101N Technique 2: Recursion Tree T(n) = n + 4 T(n/2) T(1) = 1 n T(n/2) = n = T(n) T(1) 1 =

J. Elder COSC 3101N n T(n/2) T(n) =

J. Elder COSC 3101N n T(n/2) T(n) = n/2 T(n/4)

J. Elder COSC 3101N n T(n) = n/2 T(n/4) n/2 T(n/4) n/2 T(n/4) n/2 T(n/4)

J. Elder COSC 3101N n T(n) = n/ n/4

J. Elder COSC 3101N Level i is the sum of 4 i copies of n/2 i n/2 + n/2 + n/2 + n/2 n n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/ i

J. Elder COSC 3101N =1  n = 4  n/2 = 16  n/4 = 4 i  n/2 i Total: θ( n log4 ) = θ( n 2 ) = 4 logn  n/2 logn =n log4  1

J. Elder COSC 3101N Divide and Conquer MULT: θ (n 2 ) time Grade School Multiplication: θ (n 2 ) time All that work for nothing!

J. Elder COSC 3101N MULT revisited MULT calls itself 4 times. Can you see a way to reduce the number of calls? MULT(X,Y): If |X| = |Y| = 1 then RETURN XY Break X into a;b and Y into c;d RETURN MULT(a,c) 2 n + (MULT(a,d) + MULT(b,c)) 2 n/2 + MULT(b,d)

J. Elder COSC 3101N Gauss’ Idea: Input: a,b,c,d Output: ac, ad+bc, bd A 1 = ac A 3 = bd m 3 = (a+b)(c+d) = ac + ad + bc + bd A 2 = m 3 – A 1 - A 3 = ad + bc

J. Elder COSC 3101N Gaussified MULT (Karatsuba 1962) T(n) = 3 T(n/2) + n Actually: T(n) = 2 T(n/2) + T(n/2 + 1) + kn MULT(X,Y): If |X| = |Y| = 1 then RETURN XY Break X into a;b and Y into c;d e = MULT(a,c) and f =MULT(b,d) RETURN e2 n + (MULT(a+b, c+d) – e - f) 2 n/2 + f

J. Elder COSC 3101N n T(n) = n/2 T(n/4) n/2 T(n/4) n/2 T(n/4) n/2 T(n/4)

J. Elder COSC 3101N n T(n/2) T(n) =

J. Elder COSC 3101N n T(n/2) T(n) = n/2 T(n/4)

J. Elder COSC 3101N n T(n) = n/2 T(n/4) n/2 T(n/4) n/2 T(n/4)

J. Elder COSC 3101N Level i is the sum of 3 i copies of n/2 i n/2 + n/2 + n/2 n n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/ i

J. Elder COSC 3101N =1  n = 3  n/2 = 9  n/4 = 3 i  n/2 i Total: θ( n log3 ) = θ( n ) = 3 logn  n/2 logn =n log3  1

J. Elder COSC 3101N Dramatic improvement for large n Not just a 25% savings! θ( n 2 ) vs θ( n )

J. Elder COSC 3101N Multiplication Algorithms Kindergartenn2 n Grade Schooln2n2 Karatsuban 1.58… Fastest Knownn logn loglogn

J. Elder COSC 3101N End