Documentation

Mathlib.LinearAlgebra.TensorProduct.Matrix

Connections between TensorProduct and Matrix #

This file contains results about the matrices corresponding to maps between tensor product types, where the correspondence is induced by Basis.tensorProduct

Notably, TensorProduct.toMatrix_map shows that taking the tensor product of linear maps is equivalent to taking the Kronecker product of their matrix representations.

theorem TensorProduct.toMatrix_map {R : Type u_1} {M : Type u_2} {N : Type u_3} {M' : Type u_5} {N' : Type u_6} {ι : Type u_7} {κ : Type u_8} {ι' : Type u_10} {κ' : Type u_11} [DecidableEq ι] [DecidableEq κ] [Fintype ι] [Fintype κ] [Finite ι'] [Finite κ'] [CommRing R] [AddCommGroup M] [AddCommGroup N] [AddCommGroup M'] [AddCommGroup N'] [Module R M] [Module R N] [Module R M'] [Module R N'] (bM : Basis ι R M) (bN : Basis κ R N) (bM' : Basis ι' R M') (bN' : Basis κ' R N') (f : M →ₗ[R] M') (g : N →ₗ[R] N') :
(LinearMap.toMatrix (bM.tensorProduct bN) (bM'.tensorProduct bN')) (map f g) = Matrix.kroneckerMap (fun (x1 x2 : R) => x1 * x2) ((LinearMap.toMatrix bM bM') f) ((LinearMap.toMatrix bN bN') g)

The linear map built from TensorProduct.map corresponds to the matrix built from Matrix.kronecker.

theorem Matrix.toLin_kronecker {R : Type u_1} {M : Type u_2} {N : Type u_3} {M' : Type u_5} {N' : Type u_6} {ι : Type u_7} {κ : Type u_8} {ι' : Type u_10} {κ' : Type u_11} [DecidableEq ι] [DecidableEq κ] [Fintype ι] [Fintype κ] [Finite ι'] [Finite κ'] [CommRing R] [AddCommGroup M] [AddCommGroup N] [AddCommGroup M'] [AddCommGroup N'] [Module R M] [Module R N] [Module R M'] [Module R N'] (bM : Basis ι R M) (bN : Basis κ R N) (bM' : Basis ι' R M') (bN' : Basis κ' R N') (A : Matrix ι' ι R) (B : Matrix κ' κ R) :
(toLin (bM.tensorProduct bN) (bM'.tensorProduct bN')) (kroneckerMap (fun (x1 x2 : R) => x1 * x2) A B) = TensorProduct.map ((toLin bM bM') A) ((toLin bN bN') B)

The matrix built from Matrix.kronecker corresponds to the linear map built from TensorProduct.map.

theorem TensorProduct.toMatrix_comm {R : Type u_1} {M : Type u_2} {N : Type u_3} {ι : Type u_7} {κ : Type u_8} [DecidableEq ι] [DecidableEq κ] [Fintype ι] [Fintype κ] [CommRing R] [AddCommGroup M] [AddCommGroup N] [Module R M] [Module R N] (bM : Basis ι R M) (bN : Basis κ R N) :
(LinearMap.toMatrix (bM.tensorProduct bN) (bN.tensorProduct bM)) (TensorProduct.comm R M N) = Matrix.submatrix 1 Prod.swap id

TensorProduct.comm corresponds to a permutation of the identity matrix.

theorem TensorProduct.toMatrix_assoc {R : Type u_1} {M : Type u_2} {N : Type u_3} {P : Type u_4} {ι : Type u_7} {κ : Type u_8} {τ : Type u_9} [DecidableEq ι] [DecidableEq κ] [DecidableEq τ] [Fintype ι] [Fintype κ] [Fintype τ] [CommRing R] [AddCommGroup M] [AddCommGroup N] [AddCommGroup P] [Module R M] [Module R N] [Module R P] (bM : Basis ι R M) (bN : Basis κ R N) (bP : Basis τ R P) :
(LinearMap.toMatrix ((bM.tensorProduct bN).tensorProduct bP) (bM.tensorProduct (bN.tensorProduct bP))) (TensorProduct.assoc R M N P) = Matrix.submatrix 1 id (Equiv.prodAssoc ι κ τ)

TensorProduct.assoc corresponds to a permutation of the identity matrix.