let n be Nat; :: thesis: for R being Ring
for M1, M2 being Matrix of n,R st M1 * M2 = 0. (R,n,n) & M1 is invertible holds
M1 commutes_with M2

let R be Ring; :: thesis: for M1, M2 being Matrix of n,R st M1 * M2 = 0. (R,n,n) & M1 is invertible holds
M1 commutes_with M2

let M1, M2 be Matrix of n,R; :: thesis: ( M1 * M2 = 0. (R,n,n) & M1 is invertible implies M1 commutes_with M2 )
assume that
A2: M1 * M2 = 0. (R,n,n) and
A3: M1 is invertible ; :: thesis: M1 commutes_with M2
A4: M1 ~ is_reverse_of M1 by A3, Def4;
A5: len M2 = n by MATRIX_0:24;
A6: ( len M1 = n & width M1 = n ) by MATRIX_0:24;
A7: len (M1 ~) = n by MATRIX_0:24;
A8: width (M1 ~) = n by MATRIX_0:24;
M2 = (1. (R,n)) * M2 by MATRIX_3:18
.= ((M1 ~) * M1) * M2 by A4
.= (M1 ~) * (0. (R,n,n)) by A2, A6, A5, A8, MATRIX_3:33
.= 0. (R,n,n) by A7, A8, Th2 ;
hence M1 commutes_with M2 by Th3; :: thesis: verum