-
-
Save mikezink/8397411c07b1adb72da6c572489071e1 to your computer and use it in GitHub Desktop.
strassen_matrix_mult.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import numpy as np | |
matrix1 = np.array([[12, 7], | |
[4, 5]]) | |
matrix2 = np.array([[5, 8], | |
[6, 7]]) | |
def split(matrix): | |
""" | |
Splits a given matrix into quarters. | |
Input: nxn matrix | |
Output: tuple containing 4 n/2 x n/2 matrices corresponding to a, b, c, d | |
""" | |
row, col = matrix.shape | |
row2, col2 = row // 2, col // 2 | |
return matrix[:row2, :col2], matrix[:row2, col2:], matrix[row2:, :col2], matrix[row2:, col2:] | |
def strassen(x, y): | |
""" | |
Computes matrix product by divide and conquer approach, recursively. | |
Input: nxn matrices x and y | |
Output: nxn matrix, product of x and y | |
""" | |
# Base case when size of matrices is 1x1 | |
if len(x) == 1: | |
return x * y | |
# Splitting the matrices into quadrants. This will be done recursively | |
# until the base case is reached. | |
a, b, c, d = split(x) | |
e, f, g, h = split(y) | |
# Computing the 7 products, recursively (p1, p2...p7) | |
p1 = strassen(a, f - h) | |
p2 = strassen(a + b, h) | |
p3 = strassen(c + d, e) | |
p4 = strassen(d, g - e) | |
p5 = strassen(a + d, e + h) | |
p6 = strassen(b - d, g + h) | |
p7 = strassen(a - c, e + f) | |
# Computing the values of the 4 quadrants of the final matrix c | |
c11 = p5 + p4 - p2 + p6 | |
c12 = p1 + p2 | |
c21 = p3 + p4 | |
c22 = p1 + p5 - p3 - p7 | |
# Combining the 4 quadrants into a single matrix by stacking horizontally and vertically. | |
c = np.vstack((np.hstack((c11, c12)), np.hstack((c21, c22)))) | |
return c | |
print(strassen(matrix1,matrix2)) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment