'Kronecker product of 3 matrices using Python

Suppose that we have 2 2X2 numpy arrays:

X=np.array([[0,1],[1,0]])

and

I=np.array([[1,0],[0,1]])

Consider the Kronecker product

XX=X^X

where I have let the symbol ^ be the symbol for Kronecker product. This can easily be computed via the numpy.kron() function in python:

import numpy as np
kronecker_product = np.kron(X, X)

Now, suppose that we want to compute

XX=I^X^X

numpy.kron() only takes two arrays as arguments and expects them to be the same dimension. How can I perform this operation using numpy.kron() or other technique in python?



Solution 1:[1]

As with anything like this, try:

XX = np.kron(I, np.kron(X, X))

Output:

>>> XX
array([[0, 0, 0, 1, 0, 0, 0, 0],
       [0, 0, 1, 0, 0, 0, 0, 0],
       [0, 1, 0, 0, 0, 0, 0, 0],
       [1, 0, 0, 0, 0, 0, 0, 0],
       [0, 0, 0, 0, 0, 0, 0, 1],
       [0, 0, 0, 0, 0, 0, 1, 0],
       [0, 0, 0, 0, 0, 1, 0, 0],
       [0, 0, 0, 0, 1, 0, 0, 0]])

You can nest calls to kron any number of times. For example, for XX = A^B^C^D^E, use

XX = np.kron(A, np.kron(B, np.kron(C, np.kron(D, E))))

If you don't like the verbosity there, you could create an alias for np.kron:

k = np.kron
XX = k(A, k(B, k(C, k(D, E))))

Or, better yet, use reduce from the Python built-in module functools to do it in an even more readable fashion:

import functools as ft

lst = [A, B, C, D, E]
XX = ft.reduce(np.kron, lst)

Note: I tested all of this and it works perfectly.

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Community