Matrix multiplication is a binary operation that produces a matrix from two matrices. Multiplying matrices is ubiquitous in mathematics, physics and computer science. You can perform matrix multiplication in Python using nested loops, list comprehension or the dot()
method from numpy.
This tutorial will go through how to multiply two matrices in Python with the help of code examples.
Table of contents
Matrix Multiplication Explained
A matrix is a rectangular arrangement of numbers into rows and columns. We refer to each number as a matrix element or entry in a matrix.
For example, the matrix below has two rows and three columns. The element in the second row in the first column of the matrix is 4.
To perform matrix multiplication, the number of columns in the first matrix must equal the number of rows in the second matrix. The resultant matrix will have the number of rows of the first and the number of columns of the second matrix. Below is an example of matrix multiplication.
Let’s look at an example of matrix multiplication between a 2×3 and a 3×2 matrix. The result will be a 2×2 matrix, and the green highlight shows how we perform a row by column multiplication.
Matrix Multiplication in Python Without NumPy
Matrix Multiplication in Python Using Nested Loop
Creating a Matrix in Python Without NumPy
In Python, we can create a matrix as a nested list, which is a list within a list. Each element in a nested list is a row of the matrix, for example:
X = [[10, 3, 5], [7, 9, 2], [11, 6, 9]]
represents a 3×3 matrix. Putting each row on a separate line in your code will improve readability.
Creating a Matrix in Python With NumPy
We can create a matrix using NumPy by passing a nested list to the array()
method, for example:
import numpy as np X = np.array([[10, 3, 5], [7, 9, 2], [11, 6, 9]]) print(X)
[[10 3 5] [ 7 9 2] [11 6 9]]
Indexing a Matrix in Python
We can select the first row in X
using X[0]
and select the element in the first row of the first column using X[0][0]
. Let’s look at an example of multiplying two matrices using a nested loop.
# Program to multiply two matrices using nested loops # 3 x 3 matrix X = [[10, 3, 5], [7, 9, 2], [11, 6, 9]] # 3 x 4 matrix Y = [[8, 5, 1, 10], [7, 6, 3, 1], [2, 4, 9, 1]] # result is a 3 x 4 matrix result = [[0, 0, 0, 0], [0,0,0,0], [0,0,0,0]] # Iterate over rows in X for i in range(len(X)): # Iterate through columns in Y for j in range(len(Y[0])): # Iterate through the rows of Y for k in range(len(Y)): result[i][j] += X[i][k] * Y[k][j] for r in result: print(r)
In the above program, we use nested for loops to iterate over each row and column and calculate the sum of the products for each row by column multiplication. Let’s run the code to get the result:
[111, 88, 64, 108] [123, 97, 52, 81] [148, 127, 110, 125]
Matrix Multiplication in Python Using Nested List Comprehension
Nested list comprehension performs a list comprehension within a list comprehension, resulting in a nested list. The syntax for nested list comprehension is:
new_list = [[expression for item in list] for item in list]
We can use nested list comprehension to multiply two matrices, similar to the nested loop method. Let’s look at an example:
# Program to multiply two matrices using list comprehension # 3 x 3 matrix X = [[10, 3, 5], [7, 9, 2], [11, 6, 9]] # 3 x 4 matrix Y = [[8, 5, 1, 10], [7, 6, 3, 1], [2, 4, 9, 1]] # result is a 3 x 4 matrix result = [[sum(a*b for a,b in zip(X_row, Y_col)) for Y_col in zip(*Y)] for X_row in X] for r in result: print(r)
In the above program, we are iterating over the columns in matrix Y
and the rows in matrix X
to calculate the sum of the products of each row by column multiplication. We use zip()
and the unpacking operator to get the columns of matrix Y
. To do the sum of products for every row in the nested list; we need the for X_row
in X
as the second part of the nested list comprehension. Let’s run the code to get the result:
[111, 88, 64, 108] [123, 97, 52, 81] [148, 127, 110, 125]
Both nested loop approaches are computationally expensive and do not scale well to large matrices. For larger matrix operations, it is better to use numerical libraries like NumPy. The following examples will discuss using the NumPy methods dot()
and matmul()
.
Matrix Multiplication in Python with NumPy
Matrix Multiplication in Python Using numpy.dot()
We can use NumPy’s dot()
function to multiply two matrices. Let’s look at an example:
import numpy as np # Program to multiply two matrices using np.dot() # 3 x 3 matrix X = [[10, 3, 5], [7, 9, 2], [11, 6, 9]] # 3 x 4 matrix Y = [[8, 5, 1, 10], [7, 6, 3, 1], [2, 4, 9, 1]] # Result is a 3 x 4 matrix result = np.dot(X,Y) print(result)
We replace the nested loop or nested list comprehension with an np.dot()
call in the above code. This approach is much faster and more concise. Let’s run the code to get the result:
[[111 88 64 108] [123 97 52 81] [148 127 110 125]]
We can also convert the nested lists to NumPy arrays and then call the dot()
method as shown below:
import numpy as np # Program to multiply two matrices using np.dot() # 3 x 3 matrix X = np.array([[10, 3, 5], [7, 9, 2], [11, 6, 9]]) # 3 x 4 matrix Y = np.array([[8, 5, 1, 10], [7, 6, 3, 1], [2, 4, 9, 1]]) # Result is a 3 x 4 matrix result = X.dot(Y) print(result)
[[111 88 64 108] [123 97 52 81] [148 127 110 125]]
Matrix Multiplication in Python Using numpy.matmul()
We can use NumPy’s matmul()
function to multiply two matrices. Let’s look at an example:
import numpy as np # Program to multiply two matrices using np.matmul() # 3 x 3 matrix X = np.array([[10, 3, 5], [7, 9, 2], [11, 6, 9]]) # 3 x 4 matrix Y = np.array([[8, 5, 1, 10], [7, 6, 3, 1], [2, 4, 9, 1]]) # Result is a 3 x 4 matrix result = np.matmul(X,Y) print(result)
We replace the nested loop or nested list comprehension with an np.matmul()
call in the above code. Let’s run the code to get the result:
[[111 88 64 108] [123 97 52 81] [148 127 110 125]]
Summary
Congratulations on reading to the end of this tutorial! You have gone through the fundamentals of matrix multiplication and how to do it in Python with nested loops, nested list comprehension and the NumPy methods dot()
and matmul()
. The most efficient way to do matrix multiplication is to use NumPy’s built-in methods; remember to import the library before using the methods.
For further reading on matrix manipulation in Python, go to the article: How to Find the Transpose of a Matrix in Python.
For further reading on multiplying matrices in other programming languages, go to the article:
How to do Matrix Multiplication in R
For further reading on ValueErrors NumPy arrays, go to the articles:
- How to Solve Python ValueError: operands could not be broadcast together with shapes
- How to Solve Python ValueError: matmul: Input Operand Mismatch in Matrix Multiplication
Have fun and happy researching!
Suf is a senior advisor in data science with deep expertise in Natural Language Processing, Complex Networks, and Anomaly Detection. Formerly a postdoctoral research fellow, he applied advanced physics techniques to tackle real-world, data-heavy industry challenges. Before that, he was a particle physicist at the ATLAS Experiment of the Large Hadron Collider. Now, he’s focused on bringing more fun and curiosity to the world of science and research online.