Grade School Revisited: How To Multiply Two Numbers

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

CS Divide and Conquer/Recurrence Relations1 Divide and Conquer.
Lecture 3: Parallel Algorithm Design
A simple example finding the maximum of a set S of n numbers.
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science Victor Adamchik Danny Sleator CS Spring 2010 Lecture.
CS Section 600 CS Section 002 Dr. Angela Guercio Spring 2010.
Data Structures, Spring 2004 © L. Joskowicz 1 Data Structures – LECTURE 3 Recurrence equations Formulating recurrence equations Solving recurrence equations.
Data Structures, Spring 2006 © L. Joskowicz 1 Data Structures – LECTURE 3 Recurrence equations Formulating recurrence equations Solving recurrence equations.
Introduction Credits: Steve Rudich, Jeff Edmond, Ping Xuan.
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.
Analysis of Algorithms
Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science S. Rudich V. Adamchik CS Spring 2006 Lecture 18March.
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.
Mathematics Review Exponents Logarithms Series Modular arithmetic Proofs.
Fundamentals of Algorithm Analysis Dr. Steve Goddard CSCE 310J: Data Structures &
Computer Algorithms Ch. 2
Great Theoretical Ideas in Computer Science.
Project 2 due … Project 2 due … Project 2 Project 2.
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]
Divide & Conquer  Themes  Reasoning about code (correctness and cost)  recursion, induction, and recurrence relations  Divide and Conquer  Examples.
COMPSCI 102 Introduction to Discrete Mathematics.
J. Elder COSC 3101N Thinking about Algorithms Abstractly Lecture 1. Introduction.
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:
4/3/2003CSE More Math CSE Algorithms Euclidean Algorithm Divide and Conquer.
Divide and Conquer Andreas Klappenecker [based on slides by Prof. Welch]
COMPSCI 102 Discrete Mathematics for Computer Science.
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.
1 How to Multiply Slides by Kevin Wayne. Copyright © 2005 Pearson-Addison Wesley. All rights reserved. integers, matrices, and polynomials.
Divide and Conquer Faculty Name: Ruhi Fatima Topics Covered Divide and Conquer Matrix multiplication Recurrence.
Induction II: Inductive Pictures Great Theoretical Ideas In Computer Science Anupam GuptaCS Fall 2005 Lecture 3Sept 6, 2005Carnegie Mellon University.
Grade School Revisited: How To Multiply Two Numbers CS Lecture 4 2 X 2 = 5.
Unary, Binary, and Beyond Great Theoretical Ideas In Computer Science Steven RudichCS Spring 2003 Lecture 2Jan 16, 2003Carnegie Mellon University.
Advanced Algorithms Analysis and Design By Dr. Nazir Ahmad Zafar Dr Nazir A. Zafar Advanced Algorithms Analysis and Design.
On Time Versus Input Size Great Theoretical Ideas In Computer Science S. Rudich V. Adamchik CS Spring 2006 Lecture 17March 21, 2006Carnegie Mellon.
Lecture 3: Parallel Algorithm Design
Introduction to Recurrence Relations
Divide-and-Conquer 6/30/2018 9:16 AM
CS 3343: Analysis of Algorithms
Great Theoretical Ideas in Computer Science
Randomized Algorithms
Great Theoretical Ideas in Computer Science
Great Theoretical Ideas in Computer Science
Lecture 3: Divide-and-conquer
How To Multiply Two Numbers
Analysis of Algorithms
By Jeff Edmonds York University
Counting I: Bijection and Choice Trees
Induction II: Inductive Pictures
Randomized Algorithms
Data Structures Review Session
Divide-and-Conquer 7 2  9 4   2   4   7
Grade School Revisited: How To Multiply Two Numbers
Introduction to Discrete Mathematics
Divide-and-Conquer 7 2  9 4   2   4   7
CSCI 256 Data Structures and Algorithm Analysis Lecture 12
Induction II: Inductive Pictures
At the end of this session, learner will be able to:
Algorithms Recurrences.
Divide-and-Conquer 7 2  9 4   2   4   7
Introduction to Discrete Mathematics
Presentation transcript:

Grade School Revisited: How To Multiply Two Numbers Great Theoretical Ideas In Computer Science S.Rudich V.Adamchik CS 15-251 Spring 2006 Lecture 18 March 23, 2006 Carnegie Mellon University Grade School Revisited: How To Multiply Two Numbers 2 X 2 = 5

The best way is often far from obvious!

(a+bi)(c+di) Gauss

Gauss’ Complex Puzzle Can you do better than $4.02? Remember how to multiply two complex numbers a + bi and c + di? (a+bi)(c+di) = [ac –bd] + [ad + bc] i Input: a,b,c,d Output: ac-bd, ad+bc If multiplying two real numbers costs $1 and adding them costs a penny, what is the cheapest way to obtain the output from the input? Can you do better than $4.02?

Gauss’ $3.05 Method c X2 = c + d $ X3 = X1 X2 = ac + ad + bc + bd (a+bi)(c+di) = [ac –bd] + [ad + bc] i Input: a,b,c,d Output: ac-bd, ad+bc c $ cc X1 = a + b X2 = c + d X3 = X1 X2 = ac + ad + bc + bd X4 = ac X5 = bd X6 = X4 – X5 = ac - bd X7 = X3 – X4 – X5 = bc + ad

The Gauss optimization saves one multiplication out of four. It requires 25% less work.

Time complexity of grade school addition * * * * * * + T(n) = The amount of time grade school addition uses to add two n-bit numbers We saw that T(n) was linear. T(n) = Θ(n)

Time complexity of grade school multiplication * * * * * * * * * * * * * * * * * * * * * * * * n2 T(n) = The amount of time grade school multiplication uses to add two n-bit numbers We saw that T(n) was quadratic. T(n) = Θ(n2)

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

Grade school addition is linear time. Is there a sub-linear time method for addition?

Any addition algorithm takes Ω(n) time Claim: Any algorithm for addition must read all of the input bits Proof: Suppose there is a mystery algorithm A that does not examine each bit Give A a pair of numbers. There must be some unexamined bit position i in one of the numbers

Any addition algorithm takes Ω(n) time * * * * * * * * * A did not read this bit at position i * * * * * * * * * * * * * * * * * * * If A is not correct on the inputs, we found a bug If A is correct, flip the bit at position i and give A the new pair of numbers. A gives the same answer as before, which is now wrong.

So any algorithm for addition must use time at least linear in the size of the numbers. Grade school addition can’t be improved upon by more than a constant factor.

Is there a clever algorithm to multiply two numbers in linear time? Grade School Addition: Θ(n) time Furthermore, it is optimal Grade School Multiplication: Θ(n2) time Is there a clever algorithm to multiply two numbers in linear time?

Despite years of research, no one knows Despite years of research, no one knows! If you resolve this question, Carnegie Mellon will give you a PhD!

Can we even break the quadratic time barrier? In other words, can we do something very different than grade school multiplication?

Grade School Multiplication: The Kissing Intuition Intuition: Let’s say that each time an algorithm has to multiply a digit from one number with a digit from the other number, we call that a “kiss”. It seems as if any correct algorithm must kiss at least n2 times.

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

Multiplication of 2 n-bit numbers n bits X = Y = a X b Y c d n/2 bits n/2 bits X = a 2n/2 + b Y = c 2n/2 + d X × Y = ac 2n + (ad + bc) 2n/2 + bd

Multiplication of 2 n-bit numbers X = Y = a b c d n/2 bits n/2 bits X × Y = ac 2n + (ad + bc) 2n/2 + bd MULT(X,Y): If |X| = |Y| = 1 then return XY break X into a;b and Y into c;d return MULT(a,c) 2n + (MULT(a,d) + MULT(b,c)) 2n/2 + MULT(b,d)

Same thing for numbers in decimal! n digits X = Y = a b c d n/2 digits n/2 digits X = a 10n/2 + b Y = c 10n/2 + d X × Y = ac 10n + (ad + bc) 10n/2 + bd

Multiplying (Divide & Conquer style) 12345678 * 21394276 *4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 1*2 1*1 2*2 2*1 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 1*2 1*1 2*2 2*1 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Hence: 12*21 = 2*102 + (1 + 4)101 + 2 = 252 2 1 4 2 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 252 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 1*2 1*1 2*2 2*1 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Hence: 12*21 = 2*102 + (1 + 4)101 + 2 = 252 2 1 4 2 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 252 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 1*2 1*1 2*2 2*1 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Hence: 12*21 = 2*102 + (1 + 4)101 + 2 = 252 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 252 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 1*3 1*9 2*3 2*9 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 242 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 3 9 6 18 *102 + *101 + *101 + *1 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 242 468 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 3 9 6 18 *102 + *101 + *101 + *1 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 252 468 714 1326 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx 252 468 714 1326 *104 + *102 + *102 + *1 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 1234*2139 1234*4276 5678*2139 5678*4276 12*21 12*39 34*21 34*39 xxxxxxxxxxxxxxxxxxxxxxxxx = 2639526 252 468 714 1326 *104 + *102 + *102 + *1 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 2639526 1234*4276 5678*2139 5678*4276 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 2639526 5276584 12145242 24279128 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 2639526 5276584 12145242 24279128 *108 + *104 + *104 + *1 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 12345678 * 21394276 2639526 5276584 12145242 24279128 *108 + *104 + *104 + *1 = 264126842539128 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Multiplying (Divide & Conquer style) 264126842539128 X = Y = X × Y = ac 10n + (ad + bc) 10n/2 + bd a b c d

Divide, Conquer, and Glue MULT(X,Y)

Divide, Conquer, and Glue MULT(X,Y): if |X| = |Y| = 1 then return XY, else…

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y):

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): Mult(b,d) Mult(a,c) Mult(a,d) Mult(b,c)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): Mult(b,d) Mult(a,d) Mult(b,c) Mult(a,c)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac ac Mult(b,d) Mult(a,d) Mult(b,c)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac, ac Mult(b,d) Mult(b,c) Mult(a,d)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac, ad, ac ad Mult(b,d) Mult(b,c)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac, ad, ac ad Mult(b,d) Mult(b,c)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac, ad, bc, ac bc ad Mult(b,d)

Divide, Conquer, and Glue X=a;b Y=c;d MULT(X,Y): ac, ad, bc, ac bc ad Mult(b,d)

Divide, Conquer, and Glue XY = ac2n + (ad+bc)2n/2 + bd X=a;b Y=c;d MULT(X,Y): ac, ad, bc, bd bd ac bc ad

Time required by MULT T(n) = time taken by MULT on two n-bit numbers What is T(n)? What is its growth rate? Big Question: Is it Θ(n2)?

divide + gluing time: k’n + k’’ T(n) = ? T(n) = 4 T(n/2) + (k’n + k’’) divide and glue Conquering time X=a;b Y=c;d XY = ac2n + (ad+bc)2n/2 + bd divide + gluing time: k’n + k’’ bd ac bc ad T(n/2) T(n/2) T(n/2) T(n/2)

Recurrence Relation T(1) = k for some constant k T(n) = 4 T(n/2) + k’n + k’’ for 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) 2n + (MULT(a,d) + MULT(b,c)) 2n/2 + MULT(b,d)

Let’s be concrete and keep it simple T(1) = k for some constant k T(n) = 4 T(n/2) + k’n + k’’ for constants k’ and k’’ 1 MULT(X,Y): If |X| = |Y| = 1 then return XY break X into a;b and Y into c;d return MULT(a,c) 2n + (MULT(a,d) + MULT(b,c)) 2n/2 + MULT(b,d)

Let’s be concrete and keep it simple T(n) = 4 T(n/2) + n (Notice that T(n) is inductively defined only for positive powers of 2.) What is the growth rate of T(n)?

Technique 1: Guess and Verify Guess: G(n) = 2n2 – n Verify: G(1) = 1 and G(n) = 4 G(n/2) + n 4 [2(n/2)2 – n/2] + n = 2n2 – 2n + n = 2n2 – n = G(n)

Technique 1: Guess and Verify Guess: G(n) = 2n2 – n Verify: G(1) = 1 and G(n) = 4 G(n/2) + n Similarly:T(1) = 1 and T(n) = 4 T(n/2) + n So T(n) = G(n) = Θ(n2)

Technique 2: Guess Form and Calculate Coefficients Guess: T(n) = an2 + bn + c for some a,b,c Calculate: T(1) = 1  a + b + c = 1 T(n) = 4 T(n/2) + n  an2 + bn + c = 4 [a(n/2)2 + b(n/2) + c] + n = an2 + 2bn + 4c + n  (b+1)n + 3c = 0 Therefore: b=-1 c=0 a=2

Technique 3: Labeled Tree Representation Definition: Labeled Tree A tree node-labeled by S is a tree T = <V,E> with an associated function Label: V to S From Lecture #2

Technique 3: Labeled Tree Representation T(n) = n + 4 T(n/2) n T(n) = T(n/2) T(n/2) T(n/2) T(n/2) T(1) = 1 T(1) = 1

Node labels: time not spent conquering T(n) = n + 4 T(n/2) n T(n) = T(n/2) T(n/2) T(n/2) T(n/2) T(1) = 1 T(1) = 1

divide + gluing time: k’n + k’’ T(n) = 4 T(n/2) + n divide and glue Conquering time X=a;b Y=c;d XY = ac2n + (ad+bc)2n/2 + bd divide + gluing time: k’n + k’’ bd ac bc ad T(n/2) T(n/2) T(n/2) T(n/2)

T(n) = n T(n/2) T(n/2) T(n/2) T(n/2)

T(n) = n n/2 T(n/4) T(n/2) T(n/2) T(n/2)

T(n) = n n/2 T(n/4) n/2 T(n/4) n/2 T(n/4) n/2 T(n/4)

T(n) = n n/2 n/2 n/2 n/2 n/4 n/4 n/4 n/4 n/4 n/4 n/4 n/4 n/4 n/4 n/4 11111111111111111111111111111111 . . . . . . 111111111111111111111111111111111

Level i is the sum of 4i copies of n/2i n/2 + n/2 + n/2 + n/2 Level i is the sum of 4i copies of n/2i . . . . . . . . . . . . . . . . . . . . . . . . . . 1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1 1 2 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/4 i

= 1n = 2n = 4n = 2in = (n)n n(1+2+4+8+ . . . +n) = n(2n-1) = 2n2-n

All that work for nothing! Divide and Conquer MULT: Θ(n2) time Grade School Multiplication: Θ(n2) time All that work for nothing!

Divide and Conquer MULT: Θ(n2) time Grade School Multiplication: Θ(n2) time In retrospect, it is obvious that the kissing number for Divide and Conquer MULT is n2, since the leaves are in correspondence with the kisses.

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

Gauss’ optimization X2 = c + d X3 = X1 X2 = ac + ad + bc + bd X4 = ac (a+bi)(c+di) = [ac –bd] + [ad + bc] i Input: a,b,c,d Output: ac-bd, ad+bc X1 = a + b X2 = c + d X3 = X1 X2 = ac + ad + bc + bd X4 = ac X5 = bd X6 = X4 – X5 = ac-bd X7 = X3 – X4 – X5 = bc + ad

Karatsuba, Anatolii Alexeevich (1937-) Sometime in the late 1950’s Karatsuba had formulated the first algorithm to break the kissing barrier!

Gaussified MULT (Karatsuba 1962) 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 e 2n + (MULT(a+c,b+d) – e - f) 2n/2 + f T(n) = 3 T(n/2) + n Actually: T(n) = 2 T(n/2) + T(n/2 + 1) + kn

T(n) = n T(n/2) T(n/2) T(n/2)

T(n) = n n/2 T(n/4) T(n/2) T(n/2)

T(n) = n n/2 T(n/4) n/2 T(n/4) n/2 T(n/4)

Level i is the sum of 3i copies of n/2i n/2 + n/2 + n/2 Level i is the sum of 3i copies of n/2i . . . . . . . . . . . . . . . . . . . . . . . . . . 1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1 1 2 n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 + n/4 i

n(1+3/2+(3/2)2+ . . . + (3/2)log2 n) = 3n1.58… – 2n = (3/2)in = (3/2)log n n n(1+3/2+(3/2)2+ . . . + (3/2)log2 n) = 3n1.58… – 2n

1 + X1 + X2 + X3 + … + Xn-1 + Xn = Xn+1 - 1 X - 1 The Geometric Series

Substituting into our formula…. 1 + X1 + X2 + X3 + … + Xk-1 + Xk = Xk+1 - 1 X - 1 We have: X = 3/2 k = log2 n (3/2) × (3/2)log2 n - 1 = 3 × (3log2 n/2log2 n) - 2 ½ = 3 × (3log2 n/n) - 2 = 3 n(log2 3) - 2 n

= 1n = 3/2n = 9/4n = (3/2)in = (3/2)log n n

Dramatic improvement for large n T(n) = 3nlog2 3 – 2n = Θ(nlog2 3) = Θ(n1.58…) A huge savings over Θ(n2) when n gets large.

We applied the Gauss optimization RECURSIVELY! Strange! The Gauss optimization seems to only be worth a 25% speedup. It simply replaces every 4 multiplications with 3. Where did the power come from? We applied the Gauss optimization RECURSIVELY!

REFERENCES Karatsuba, A., and Ofman, Y. Multiplication of multidigit numbers on automata. Sov. Phys. Dokl. 7 (1962), 595--596.