FinMatrix.Matrix.MatrixModule
Require Export Matrix.
Require Export ElementType.
Require Export MatrixDet.
Require Export MatrixInv.
Require Export MatrixOrth.
import element
default scope
Open Scope nat_scope.
Open Scope A_scope.
Open Scope vec_scope.
Open Scope A_scope.
Open Scope vec_scope.
Two vectors are equal, iff, element-wise equal
Lemma veq_iff_vnth : forall {n} (a b : vec n), a = b <-> (forall i, a.[i] = b.[i]).
Proof. intros. apply veq_iff_vnth. Qed.
Proof. intros. apply veq_iff_vnth. Qed.
Two vectors are not equal, iff, exist one element-wise not equal
Lemma vneq_iff_exist_vnth_neq : forall {n} (a b : vec n), a <> b <-> exists i, a.[i] <> b.[i].
Proof. intros. apply vneq_iff_exist_vnth_neq. Qed.
Proof. intros. apply vneq_iff_exist_vnth_neq. Qed.
Any two 0-D vectors are equal
No two 0-D vectors are unequal
The equality of 1-D, 2-D, ... vectors
Section veq.
Lemma v1eq_iff : forall (a b : vec 1), a = b <-> a.1 = b.1.
Proof. apply v1eq_iff. Qed.
Lemma v1neq_iff : forall (a b : vec 1), a <> b <-> a.1 <> b.1.
Proof. apply v1neq_iff. Qed.
Lemma v2eq_iff : forall (a b : vec 2), a = b <-> a.1 = b.1 /\ a.2 = b.2.
Proof. apply v2eq_iff. Qed.
Lemma v2neq_iff : forall (a b : vec 2), a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2).
Proof. apply v2neq_iff. Qed.
Lemma v3eq_iff : forall (a b : vec 3),
a = b <-> a.1 = b.1 /\ a.2 = b.2 /\ a.3 = b.3.
Proof. apply v3eq_iff. Qed.
Lemma v3neq_iff : forall (a b : vec 3),
a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2 \/ a.3 <> b.3).
Proof. apply v3neq_iff. Qed.
Lemma v4eq_iff : forall (a b : vec 4),
a = b <-> a.1 = b.1 /\ a.2 = b.2 /\ a.3 = b.3 /\ a.4 = b.4.
Proof. apply v4eq_iff. Qed.
Lemma v4neq_iff : forall (a b : vec 4),
a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2 \/ a.3 <> b.3 \/ a.4 <> b.4).
Proof. apply v4neq_iff. Qed.
End veq.
Lemma v1eq_iff : forall (a b : vec 1), a = b <-> a.1 = b.1.
Proof. apply v1eq_iff. Qed.
Lemma v1neq_iff : forall (a b : vec 1), a <> b <-> a.1 <> b.1.
Proof. apply v1neq_iff. Qed.
Lemma v2eq_iff : forall (a b : vec 2), a = b <-> a.1 = b.1 /\ a.2 = b.2.
Proof. apply v2eq_iff. Qed.
Lemma v2neq_iff : forall (a b : vec 2), a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2).
Proof. apply v2neq_iff. Qed.
Lemma v3eq_iff : forall (a b : vec 3),
a = b <-> a.1 = b.1 /\ a.2 = b.2 /\ a.3 = b.3.
Proof. apply v3eq_iff. Qed.
Lemma v3neq_iff : forall (a b : vec 3),
a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2 \/ a.3 <> b.3).
Proof. apply v3neq_iff. Qed.
Lemma v4eq_iff : forall (a b : vec 4),
a = b <-> a.1 = b.1 /\ a.2 = b.2 /\ a.3 = b.3 /\ a.4 = b.4.
Proof. apply v4eq_iff. Qed.
Lemma v4neq_iff : forall (a b : vec 4),
a <> b <-> (a.1 <> b.1 \/ a.2 <> b.2 \/ a.3 <> b.3 \/ a.4 <> b.4).
Proof. apply v4neq_iff. Qed.
End veq.
Definition v2f {n} (a : vec n) : nat -> A := v2f 0 a.
Definition f2v {n} (f : nat -> A) : vec n := f2v f.
Definition f2v {n} (f : nat -> A) : vec n := f2v f.
(f2v a).i = a i
Lemma vnth_f2v : forall {n} f i, (@f2v n f).[i] = f i.
Proof. intros. apply vnth_f2v. Qed.
Lemma f2v_inj : forall {n} (f g : nat -> A),
@f2v n f = @f2v n g -> (forall i, i < n -> f i = g i).
Proof. intros. apply (@f2v_inj _ n); auto. Qed.
Proof. intros. apply vnth_f2v. Qed.
Lemma f2v_inj : forall {n} (f g : nat -> A),
@f2v n f = @f2v n g -> (forall i, i < n -> f i = g i).
Proof. intros. apply (@f2v_inj _ n); auto. Qed.
(v2f a) i = a.i
Lemma nth_v2f : forall {n} (a : vec n) i (H:i<n), (v2f a) i = a.[nat2fin i H].
Proof. intros. apply nth_v2f. Qed.
Lemma v2f_inj : forall {n} (a b : vec n),
(forall i, i < n -> (v2f a) i = (v2f b) i) -> a = b.
Proof. intros. apply (v2f_inj 0); auto. Qed.
Proof. intros. apply nth_v2f. Qed.
Lemma v2f_inj : forall {n} (a b : vec n),
(forall i, i < n -> (v2f a) i = (v2f b) i) -> a = b.
Proof. intros. apply (v2f_inj 0); auto. Qed.
f2v (v2f a) = a
v2f (f2v a) = a
Lemma v2f_f2v : forall {n} (a : nat -> A) i, i < n -> v2f (@f2v n a) i = a i.
Proof. intros. apply v2f_f2v; auto. Qed.
Proof. intros. apply v2f_f2v; auto. Qed.
Definition v2l {n} (a : vec n) : list A := v2l a.
Definition l2v {n} (l : list A) : vec n := l2v 0 l.
Definition l2v {n} (l : list A) : vec n := l2v 0 l.
(l2v l).i = nth i l
Lemma vnth_l2v : forall {n} (l : list A) (i : 'I_n), (@l2v n l).[i] = nth i l 0.
Proof. intros. apply vnth_l2v. Qed.
Proof. intros. apply vnth_l2v. Qed.
nth i (v2l v) = v.i
Lemma nth_v2l : forall {n} (a : vec n) (i : nat) (H: i < n),
i < n -> nth i (v2l a) 0 = a (nat2fin i H).
Proof. intros. apply nth_v2l; auto. Qed.
Lemma v2l_length : forall {n} (a : vec n), length (v2l a) = n.
Proof. intros. apply v2l_length. Qed.
Lemma v2l_l2v : forall {n} (l : list A), length l = n -> (v2l (@l2v n l) = l).
Proof. intros. apply v2l_l2v; auto. Qed.
Lemma l2v_v2l : forall {n} (a : vec n), @l2v n (v2l a) = a.
Proof. intros. apply l2v_v2l. Qed.
Lemma v2l_inj : forall {n} (a b : vec n), v2l a = v2l b -> a = b.
Proof. intros. apply v2l_inj; auto. Qed.
i < n -> nth i (v2l a) 0 = a (nat2fin i H).
Proof. intros. apply nth_v2l; auto. Qed.
Lemma v2l_length : forall {n} (a : vec n), length (v2l a) = n.
Proof. intros. apply v2l_length. Qed.
Lemma v2l_l2v : forall {n} (l : list A), length l = n -> (v2l (@l2v n l) = l).
Proof. intros. apply v2l_l2v; auto. Qed.
Lemma l2v_v2l : forall {n} (a : vec n), @l2v n (v2l a) = a.
Proof. intros. apply l2v_v2l. Qed.
Lemma v2l_inj : forall {n} (a b : vec n), v2l a = v2l b -> a = b.
Proof. intros. apply v2l_inj; auto. Qed.
Definition mkvec1 (a1 : A) : vec 1 := mkvec1 (Azero:=0) a1.
Definition mkvec2 (a1 a2 : A) : vec 2 := mkvec2 (Azero:=0) a1 a2.
Definition mkvec3 (a1 a2 a3 : A) : vec 3 := mkvec3 (Azero:=0) a1 a2 a3.
Definition mkvec4 (a1 a2 a3 a4 : A) : vec 4 := mkvec4 (Azero:=0) a1 a2 a3 a4.
Definition mkvec2 (a1 a2 : A) : vec 2 := mkvec2 (Azero:=0) a1 a2.
Definition mkvec3 (a1 a2 a3 : A) : vec 3 := mkvec3 (Azero:=0) a1 a2 a3.
Definition mkvec4 (a1 a2 a3 a4 : A) : vec 4 := mkvec4 (Azero:=0) a1 a2 a3 a4.
Definition vmap {n} (f : A -> A) (a : vec n) : vec n := vmap f a.
Definition vmap2 {n} (f : A -> A -> A) (a b : vec n) : vec n := vmap2 f a b.
(vmap f a).i = f (a.i)
Lemma vnth_vmap : forall {n} (a : vec n) f i, (vmap f a).[i] = f (a.[i]).
Proof. intros. apply vnth_vmap. Qed.
Proof. intros. apply vnth_vmap. Qed.
(vmap2 f a b).i = f (a.i) (b.i)
Lemma vnth_vmap2 : forall {n} (a b : vec n) f i, (vmap2 f a b).[i] = f a.[i] b.[i].
Proof. intros. apply vnth_vmap2. Qed.
Proof. intros. apply vnth_vmap2. Qed.
vmap2 f a b = vmap id (fun i => f u.i v.i)
Lemma vmap2_eq_vmap : forall {n} (a b : vec n) f,
vmap2 f a b = vmap (fun a => a) (fun i => f a.[i] b.[i]).
Proof. intros. apply vmap2_eq_vmap. Qed.
vmap2 f a b = vmap (fun a => a) (fun i => f a.[i] b.[i]).
Proof. intros. apply vmap2_eq_vmap. Qed.
(repeat a).i = a
Make a zero vector
vzero.i = 0
(vset a i x).i = x
Lemma vnth_vset_eq : forall {n} (a : vec n) (i : 'I_n) (x : A), (vset a i x).[i] = x.
Proof. intros. apply vnth_vset_eq. Qed.
Proof. intros. apply vnth_vset_eq. Qed.
(vset a i x).j = a.j
Lemma vnth_vset_neq : forall {n} (a : vec n) (i j : 'I_n) (x : A),
i <> j -> (vset a i x).[j] = a.[j].
Proof. intros. apply vnth_vset_neq; auto. Qed.
i <> j -> (vset a i x).[j] = a.[j].
Proof. intros. apply vnth_vset_neq; auto. Qed.
Definition vswap {n} (a : vec n) (i j : 'I_n) : vec n := vswap a i j.
Lemma vnth_vswap_i : forall {n} (a : vec n) (i j : 'I_n), (vswap a i j).[i] = a.[j].
Proof. intros. apply vnth_vswap_i. Qed.
Lemma vnth_vswap_j : forall {n} (a : vec n) (i j : 'I_n), (vswap a i j).[j] = a.[i].
Proof. intros. apply vnth_vswap_j. Qed.
Lemma vnth_vswap_other : forall {n} (a : vec n) (i j k : 'I_n),
i <> k -> j <> k -> (vswap a i j).[k] = a.[k].
Proof. intros. apply vnth_vswap_other; auto. Qed.
Lemma vswap_vswap : forall {n} (a : vec n) (i j : 'I_n), vswap (vswap a i j) j i = a.
Proof. intros. apply vswap_vswap. Qed.
Lemma vnth_vswap_i : forall {n} (a : vec n) (i j : 'I_n), (vswap a i j).[i] = a.[j].
Proof. intros. apply vnth_vswap_i. Qed.
Lemma vnth_vswap_j : forall {n} (a : vec n) (i j : 'I_n), (vswap a i j).[j] = a.[i].
Proof. intros. apply vnth_vswap_j. Qed.
Lemma vnth_vswap_other : forall {n} (a : vec n) (i j k : 'I_n),
i <> k -> j <> k -> (vswap a i j).[k] = a.[k].
Proof. intros. apply vnth_vswap_other; auto. Qed.
Lemma vswap_vswap : forall {n} (a : vec n) (i j : 'I_n), vswap (vswap a i j) j i = a.
Proof. intros. apply vswap_vswap. Qed.
j < i -> (v2f (vinsert a i x)) j = (v2f a) i
Lemma vinsert_spec_lt : forall {n} (a : vec n) (i : 'I_(S n)) (x : A) (j : nat),
j < i -> v2f (vinsert a i x) j = v2f a j.
Proof. intros. apply vinsert_spec_lt; auto. Qed.
j < i -> v2f (vinsert a i x) j = v2f a j.
Proof. intros. apply vinsert_spec_lt; auto. Qed.
j = i -> (v2f (vinsert a i x)) j = x
Lemma vinsert_spec_eq : forall {n} (a : vec n) (i : 'I_(S n)) (x : A),
v2f (vinsert a i x) i = x.
Proof. intros. apply vinsert_spec_eq; auto. Qed.
v2f (vinsert a i x) i = x.
Proof. intros. apply vinsert_spec_eq; auto. Qed.
i < j -> j <= n -> (v2f (vinsert a i x)) j = (v2f a) (S i)
Lemma vinsert_spec_gt : forall {n} (a : vec n) (i : 'I_(S n)) (x : A) (j : nat),
i < j -> 0 < j -> j < S n -> v2f (vinsert a i x) j = v2f a (pred j).
Proof. intros. apply vinsert_spec_gt; auto. Qed.
i < j -> 0 < j -> j < S n -> v2f (vinsert a i x) j = v2f a (pred j).
Proof. intros. apply vinsert_spec_gt; auto. Qed.
Lemma vnth_vinsert_lt :
forall {n} (a : vec n) (i j : 'I_(S n)) x (H : j < i),
(vinsert a i x).[j] = a.[fPredRange j (nat_lt_ltS_lt _ _ _ H (fin2nat_lt _))].
Proof. intros. apply (@vnth_vinsert_lt _ 0); auto. Qed.
forall {n} (a : vec n) (i j : 'I_(S n)) x (H : j < i),
(vinsert a i x).[j] = a.[fPredRange j (nat_lt_ltS_lt _ _ _ H (fin2nat_lt _))].
Proof. intros. apply (@vnth_vinsert_lt _ 0); auto. Qed.
(vinsert a i x).i = a
Lemma vnth_vinsert_eq : forall {n} (a : vec n) (i : 'I_(S n)) x,
(vinsert a i x).[i] = x.
Proof. intros. apply (@vnth_vinsert_eq _ 0). Qed.
(vinsert a i x).[i] = x.
Proof. intros. apply (@vnth_vinsert_eq _ 0). Qed.
0 < j -> (vinsert a i x).j = a.(pred j)
Lemma vnth_vinsert_gt :
forall {n} (a : vec n) (i j : 'I_(S n)) x (H : 0 < j),
i < j -> (vinsert a i x).[j] = a.[fPredRangeP j H].
Proof. intros. apply (@vnth_vinsert_gt _ 0); auto. Qed.
forall {n} (a : vec n) (i j : 'I_(S n)) x (H : 0 < j),
i < j -> (vinsert a i x).[j] = a.[fPredRangeP j H].
Proof. intros. apply (@vnth_vinsert_gt _ 0); auto. Qed.
Invert 0 into vzero get vzero
Lemma vinsert_vzero_eq0 : forall {n} i, @vinsert n vzero i 0 = vzero.
Proof. intros. apply vinsert_vzero_eq0. Qed.
Proof. intros. apply vinsert_vzero_eq0. Qed.
If insert x into vector a get vzero, then x is 0
Lemma vinsert_eq0_imply_x0 : forall {n} (a : vec n) i x,
vinsert a i x = vzero -> x = 0.
Proof. intros. apply (vinsert_eq0_imply_x0 a i x H). Qed.
vinsert a i x = vzero -> x = 0.
Proof. intros. apply (vinsert_eq0_imply_x0 a i x H). Qed.
If insert x into vector a get vzero, then a is vzero
Lemma vinsert_eq0_imply_v0 : forall {n} (a : vec n) i x,
vinsert a i x = vzero -> a = vzero.
Proof. intros. apply (vinsert_eq0_imply_v0 a i x H). Qed.
vinsert a i x = vzero -> a = vzero.
Proof. intros. apply (vinsert_eq0_imply_v0 a i x H). Qed.
Insert x into vector a get vzero, iff a is vzero and x is 0
Lemma vinsert_eq0_iff : forall {n} (a : vec n) i x,
vinsert a i x = vzero <-> (a = vzero /\ x = 0).
Proof. intros. apply vinsert_eq0_iff. Qed.
vinsert a i x = vzero <-> (a = vzero /\ x = 0).
Proof. intros. apply vinsert_eq0_iff. Qed.
Insert x into vector a is not vzero, iff a is not vzero or x is 0
Lemma vinsert_neq0_iff : forall {n} (a : vec n) i x,
vinsert a i x <> vzero <-> (a <> vzero \/ x <> 0).
Proof. intros. apply vinsert_neq0_iff. Qed.
vinsert a i x <> vzero <-> (a <> vzero \/ x <> 0).
Proof. intros. apply vinsert_neq0_iff. Qed.
j < i -> (v2f (vremove a i)) j = (v2f a) j
Lemma vremove_spec_lt : forall {n} (a : vec (S n)) (i : 'I_(S n)) (j : nat),
j < i -> v2f (vremove a i) j = v2f a j.
Proof. intros. apply vremove_spec_lt; auto. Qed.
j < i -> v2f (vremove a i) j = v2f a j.
Proof. intros. apply vremove_spec_lt; auto. Qed.
i <= j -> j < n -> (v2f (vremove a i)) j = (v2f a) (S j)
Lemma vremove_spec_ge : forall {n} (a : vec (S n)) (i : 'I_(S n)) (j : nat),
i <= j -> j < n -> v2f (vremove a i) j = v2f a (S j).
Proof. intros. apply vremove_spec_ge; auto. Qed.
i <= j -> j < n -> v2f (vremove a i) j = v2f a (S j).
Proof. intros. apply vremove_spec_ge; auto. Qed.
Lemma vnth_vremove_lt : forall {n} (a : vec (S n)) (i : 'I_(S n)) (j : 'I_n),
j < i -> (vremove a i).[j] = v2f a j.
Proof. intros. apply vnth_vremove_lt; auto. Qed.
j < i -> (vremove a i).[j] = v2f a j.
Proof. intros. apply vnth_vremove_lt; auto. Qed.
i <= j -> j < n -> (vremove a i).j = a.(S j)
Lemma vnth_vremove_ge : forall {n} (a : vec (S n)) (i : 'I_(S n)) (j : 'I_n),
i <= j -> j < n -> (vremove a i).[j] = v2f a (S j).
Proof. intros. apply vnth_vremove_ge; auto. Qed.
i <= j -> j < n -> (vremove a i).[j] = v2f a (S j).
Proof. intros. apply vnth_vremove_ge; auto. Qed.
vremove (vinsert a i x) i = a
Lemma vremove_vinsert : forall {n} (a : vec n) (i : 'I_(S n)) (x : A),
vremove (vinsert a i x) i = a.
Proof. intros. apply (@vremove_vinsert _ 0). Qed.
vremove (vinsert a i x) i = a.
Proof. intros. apply (@vremove_vinsert _ 0). Qed.
vinsert (vremove a i) (a.i) = a
Lemma vinsert_vremove : forall {n} (a : vec (S n)) (i : 'I_(S n)),
vinsert (vremove a i) i (a.[i]) = a.
Proof. intros. apply (@vinsert_vremove _ 0). Qed.
vinsert (vremove a i) i (a.[i]) = a.
Proof. intros. apply (@vinsert_vremove _ 0). Qed.
vmap f (vremove a i) = vremove (vmap f v) i
Lemma vmap_vremove : forall {n} (a : vec (S n)) f i,
vmap f (vremove a i) = vremove (vmap f a) i.
Proof. intros. apply (@vmap_vremove _ _ 0 0). Qed.
vmap f (vremove a i) = vremove (vmap f a) i.
Proof. intros. apply (@vmap_vremove _ _ 0 0). Qed.
vmap2 f (vremove a i) (vremove b i) = vremove (vmap2 a b) i
Lemma vmap2_vremove_vremove : forall {n} (a b : vec (S n)) f i,
vmap2 f (vremove a i) (vremove b i) = vremove (vmap2 f a b) i.
Proof. intros. apply (@vmap2_vremove_vremove _ _ _ 0 0 0). Qed.
vmap2 f (vremove a i) (vremove b i) = vremove (vmap2 f a b) i.
Proof. intros. apply (@vmap2_vremove_vremove _ _ _ 0 0 0). Qed.
Get tail element
vhead a = (v2f a) 0
Lemma vhead_spec : forall {n} (a : vec (S n)), vhead a = (v2f a) 0.
Proof. intros. apply vhead_spec. Qed.
Proof. intros. apply vhead_spec. Qed.
vhead a = a.0
Lemma vhead_eq : forall {n} (a : vec (S n)), vhead a = a.[fin0].
Proof. intros. apply vhead_eq. Qed.
Proof. intros. apply vhead_eq. Qed.
vtail a = a.(n - 1)
Lemma vtail_spec : forall {n} (a : vec (S n)), vtail a = (v2f a) n.
Proof. intros. apply vtail_spec. Qed.
Proof. intros. apply vtail_spec. Qed.
vtail a = a
Get tail elements
i < m -> (vheadN a).i = (v2f a).i
Lemma vheadN_spec : forall {m n} (a : vec (m + n)) i,
i < m -> v2f (vheadN a) i = (v2f a) i.
Proof. intros. apply vheadN_spec; auto. Qed.
i < m -> v2f (vheadN a) i = (v2f a) i.
Proof. intros. apply vheadN_spec; auto. Qed.
(vheadN a).i = a.i
Lemma vnth_vheadN : forall {m n} (a : vec (m + n)) i,
(vheadN a).[i] = a.[fin2AddRangeR i].
Proof. intros. apply vnth_vheadN. Qed.
(vheadN a).[i] = a.[fin2AddRangeR i].
Proof. intros. apply vnth_vheadN. Qed.
i < n -> (vtailN a).i = (v2f a).(m + i)
Lemma vtailN_spec : forall {m n} (a : vec (m + n)) i,
i < n -> v2f (vtailN a) i = (v2f a) (m + i).
Proof. intros. apply vtailN_spec; auto. Qed.
i < n -> v2f (vtailN a) i = (v2f a) (m + i).
Proof. intros. apply vtailN_spec; auto. Qed.
(vtailN a).i = a.(n + i)
Lemma vnth_vtailN : forall {m n} (a : vec (m + n)) i,
(vtailN a).[i] = a.[fin2AddRangeAddL i].
Proof. intros. apply vnth_vtailN. Qed.
(vtailN a).[i] = a.[fin2AddRangeAddL i].
Proof. intros. apply vnth_vtailN. Qed.
Remove tail element
i < n -> (vremoveH a).i = v.(S i)
Lemma vremoveH_spec : forall {n} (a : vec (S n)) (i : nat),
i < n -> v2f (vremoveH a) i = v2f a (S i).
Proof. intros. apply vremoveH_spec; auto. Qed.
i < n -> v2f (vremoveH a) i = v2f a (S i).
Proof. intros. apply vremoveH_spec; auto. Qed.
(vremoveH a).i = a.(S i)
Lemma vnth_vremoveH : forall {n} (a : vec (S n)) (i : 'I_n),
(vremoveH a).[i] = a.[fSuccRangeS i].
Proof. intros. apply vnth_vremoveH; auto. Qed.
(vremoveH a).[i] = a.[fSuccRangeS i].
Proof. intros. apply vnth_vremoveH; auto. Qed.
a <> 0 -> vhead a = 0 -> vremoveH a <> 0
Lemma vremoveH_neq0_if : forall {n} (a : vec (S n)),
a <> vzero -> vhead a = 0 -> vremoveH a <> vzero.
Proof. intros. apply vremoveH_neq0_if; auto. Qed.
a <> vzero -> vhead a = 0 -> vremoveH a <> vzero.
Proof. intros. apply vremoveH_neq0_if; auto. Qed.
vremoveH also hold, if hold for all elements
Lemma vremoveH_hold : forall {n} (a : vec (S n)) (P : A -> Prop),
(forall i, P (a.[i])) -> (forall i, P ((vremoveH a).[i])).
Proof. intros. apply vremoveH_hold; auto. Qed.
(forall i, P (a.[i])) -> (forall i, P ((vremoveH a).[i])).
Proof. intros. apply vremoveH_hold; auto. Qed.
i < n -> (vremoveT a).i = a.i
Lemma vremoveT_spec : forall {n} (a : vec (S n)) (i : nat),
i < n -> v2f (vremoveT a) i = v2f a i.
Proof. intros. apply vremoveT_spec; auto. Qed.
i < n -> v2f (vremoveT a) i = v2f a i.
Proof. intros. apply vremoveT_spec; auto. Qed.
(vremoveT a).i = a.i
Lemma vnth_vremoveT : forall {n} (a : vec (S n)) (i : 'I_n),
(vremoveT a).[i] = a.[fSuccRange i].
Proof. intros. apply vnth_vremoveT; auto. Qed.
(vremoveT a).[i] = a.[fSuccRange i].
Proof. intros. apply vnth_vremoveT; auto. Qed.
v <> 0 -> vtail v = 0 -> vremoveT v <> 0
Lemma vremoveT_neq0_if : forall {n} (a : vec (S n)),
a <> vzero -> vtail a = 0 -> vremoveT a <> vzero.
Proof. intros. apply vremoveT_neq0_if; auto. Qed.
a <> vzero -> vtail a = 0 -> vremoveT a <> vzero.
Proof. intros. apply vremoveT_neq0_if; auto. Qed.
vremoveT also hold, if hold for all elements
Lemma vremoveT_hold : forall {n} (a : vec (S n)) (P : A -> Prop),
(forall i, P (a.[i])) -> (forall i, P ((vremoveT a).[i])).
Proof. intros. apply vremoveT_hold; auto. Qed.
(forall i, P (a.[i])) -> (forall i, P ((vremoveT a).[i])).
Proof. intros. apply vremoveT_hold; auto. Qed.
Remove some tail elements
i < n -> (vremoveHN a).i = a.(m + i)
Lemma vremoveHN_spec : forall {m n} (a : vec (m + n)) (i : nat),
i < n -> v2f (vremoveHN a) i = v2f a (m + i).
Proof. intros. apply vremoveHN_spec; auto. Qed.
i < n -> v2f (vremoveHN a) i = v2f a (m + i).
Proof. intros. apply vremoveHN_spec; auto. Qed.
(vremoveHN a).i = a.(m + i)
Lemma vnth_vremoveHN : forall {m n} (a : vec (m + n)) (i : 'I_n),
(vremoveHN a).[i] = a.[fin2AddRangeAddL i].
Proof. intros. apply vnth_vremoveHN; auto. Qed.
(vremoveHN a).[i] = a.[fin2AddRangeAddL i].
Proof. intros. apply vnth_vremoveHN; auto. Qed.
a <> 0 -> vheadN v = 0 -> vremoveHN a <> 0
Lemma vremoveHN_neq0_if : forall {m n} (a : vec (m + n)),
a <> vzero -> vheadN a = vzero -> vremoveHN a <> vzero.
Proof. intros. apply vremoveHN_neq0_if; auto. Qed.
a <> vzero -> vheadN a = vzero -> vremoveHN a <> vzero.
Proof. intros. apply vremoveHN_neq0_if; auto. Qed.
i < n -> (vremoveTN a).i = a.i
Lemma vremoveTN_spec : forall {m n} (a : vec (m + n)) (i : nat),
i < m -> v2f (vremoveTN a) i = v2f a i.
Proof. intros. apply vremoveTN_spec; auto. Qed.
i < m -> v2f (vremoveTN a) i = v2f a i.
Proof. intros. apply vremoveTN_spec; auto. Qed.
(vremoveTN a).i = a.i
Lemma vnth_vremoveTN : forall {m n} (a : vec (m + n)) (i : 'I_m),
(vremoveTN a).[i] = a.[fin2AddRangeR i].
Proof. intros. apply vnth_vremoveTN; auto. Qed.
(vremoveTN a).[i] = a.[fin2AddRangeR i].
Proof. intros. apply vnth_vremoveTN; auto. Qed.
a <> 0 -> vtailN v = 0 -> vremoveTN a <> 0
Lemma vremoveTN_neq0_if : forall {m n} (a : vec (m + n)),
a <> vzero -> vtailN a = vzero -> vremoveTN a <> vzero.
Proof. intros. apply vremoveTN_neq0_if; auto. Qed.
a <> vzero -> vtailN a = vzero -> vremoveTN a <> vzero.
Proof. intros. apply vremoveTN_neq0_if; auto. Qed.
cons at tail: a; x
i = 0 -> (v2f x; a) i = a
Lemma vconsH_spec_0 : forall {n} x (a : vec n) (i : nat),
i = O -> v2f (vconsH x a) i = x.
Proof. intros. apply vconsH_spec_0; auto. Qed.
i = O -> v2f (vconsH x a) i = x.
Proof. intros. apply vconsH_spec_0; auto. Qed.
0 < i -> i < n -> x; a.i = a.(pred i)
Lemma vconsH_spec_gt0 : forall {n} x (a : vec n) (i : nat),
0 < i -> i < n -> v2f (vconsH x a) i = v2f a (pred i).
Proof. intros. apply vconsH_spec_gt0; auto. Qed.
0 < i -> i < n -> v2f (vconsH x a) i = v2f a (pred i).
Proof. intros. apply vconsH_spec_gt0; auto. Qed.
i = 0 -> x; a.i = a
Lemma vnth_vconsH_0 : forall {n} x (a : vec n) i,
i = fin0 -> (vconsH x a).[i] = x.
Proof. intros. apply vnth_vconsH_0; auto. Qed.
i = fin0 -> (vconsH x a).[i] = x.
Proof. intros. apply vnth_vconsH_0; auto. Qed.
0 < i -> x; a.i = a.(pred i)
Lemma vnth_vconsH_gt0 : forall {n} x (a : vec n) (i : 'I_(S n)) (H: 0 < i),
(vconsH x a).[i] = a.[fPredRangeP i H].
Proof. intros. apply vnth_vconsH_gt0; auto. Qed.
(vconsH x a).[i] = a.[fPredRangeP i H].
Proof. intros. apply vnth_vconsH_gt0; auto. Qed.
x; a = 0 <-> x = 0 /\ v = 0
Lemma vconsH_eq0_iff : forall {n} x (a : vec n),
vconsH x a = vzero <-> x = 0 /\ a = vzero.
Proof. intros. apply vconsH_eq0_iff; auto. Qed.
vconsH x a = vzero <-> x = 0 /\ a = vzero.
Proof. intros. apply vconsH_eq0_iff; auto. Qed.
x; a <> 0 <-> x <> 0 \/ a <> 0
Lemma vconsH_neq0_iff : forall {n} x (a : vec n),
vconsH x a <> vzero <-> x <> 0 \/ a <> vzero.
Proof. intros. apply vconsH_neq0_iff; auto. Qed.
vconsH x a <> vzero <-> x <> 0 \/ a <> vzero.
Proof. intros. apply vconsH_neq0_iff; auto. Qed.
vconsH (vhead a) (vremoveH a) = a
Lemma vconsH_vhead_vremoveH : forall {n} (a : vec (S n)),
vconsH (vhead a) (vremoveH a) = a.
Proof. intros. apply vconsH_vhead_vremoveH; auto. Qed.
vconsH (vhead a) (vremoveH a) = a.
Proof. intros. apply vconsH_vhead_vremoveH; auto. Qed.
vremoveH (vconsH a x) = a
Lemma vremoveH_vconsH : forall {n} x (a : vec n), vremoveH (vconsH x a) = a.
Proof. intros. apply vremoveH_vconsH; auto. Qed.
Proof. intros. apply vremoveH_vconsH; auto. Qed.
vhead (vconsH a x) = x
Lemma vhead_vconsH : forall {n} (a : vec n) x, vhead (vconsH x a) = x.
Proof. intros. apply vhead_vconsH; auto. Qed.
Proof. intros. apply vhead_vconsH; auto. Qed.
0; vzero = vzero
Lemma vconsH_0_vzero : forall {n}, @vconsH n 0 vzero = vzero.
Proof. intros. apply vconsH_0_vzero; auto. Qed.
Proof. intros. apply vconsH_0_vzero; auto. Qed.
i = n -> (v2f a; x) i = a
Lemma vconsT_spec_n : forall {n} x (a : vec n) (i : nat),
i = n -> v2f (vconsT a x) i = x.
Proof. intros. apply vconsT_spec_n; auto. Qed.
i = n -> v2f (vconsT a x) i = x.
Proof. intros. apply vconsT_spec_n; auto. Qed.
i < n -> (v2f a; x) i = a.(pred i)
Lemma vconsT_spec_lt : forall {n} x (a : vec n) (i : nat),
i < n -> v2f (vconsT a x) i = v2f a i.
Proof. intros. apply vconsT_spec_lt; auto. Qed.
i < n -> v2f (vconsT a x) i = v2f a i.
Proof. intros. apply vconsT_spec_lt; auto. Qed.
i = n -> a; x.i = a
Lemma vnth_vconsT_n : forall {n} x (a : vec n) i,
fin2nat i = n -> (vconsT a x).[i] = x.
Proof. intros. apply vnth_vconsT_n; auto. Qed.
fin2nat i = n -> (vconsT a x).[i] = x.
Proof. intros. apply vnth_vconsT_n; auto. Qed.
i < n -> a; x.i = a.(pred i)
Lemma vnth_vconsT_lt : forall {n} x (a : vec n) (i : 'I_(S n)) (H: i < n),
(vconsT a x).[i] = a (fPredRange i H).
Proof. intros. apply vnth_vconsT_lt; auto. Qed.
(vconsT a x).[i] = a (fPredRange i H).
Proof. intros. apply vnth_vconsT_lt; auto. Qed.
a; x = 0 <-> a = 0 /\ x = 0
Lemma vconsT_eq0_iff : forall {n} (a : vec n) x,
vconsT a x = vzero <-> a = vzero /\ x = 0.
Proof. intros. apply vconsT_eq0_iff; auto. Qed.
vconsT a x = vzero <-> a = vzero /\ x = 0.
Proof. intros. apply vconsT_eq0_iff; auto. Qed.
a; x <> 0 <-> a <> 0 \/ x <> 0
Lemma vconsT_neq0_iff : forall {n} (a : vec n) x,
vconsT a x <> vzero <-> a <> vzero \/ x <> 0.
Proof. intros. apply vconsT_neq0_iff; auto. Qed.
vconsT a x <> vzero <-> a <> vzero \/ x <> 0.
Proof. intros. apply vconsT_neq0_iff; auto. Qed.
vconsT (vremoveT a) (vtail a) = a
Lemma vconsT_vremoveT_vtail : forall {n} (a : vec (S n)),
vconsT (vremoveT a) (vtail a) = a.
Proof. intros. apply vconsT_vremoveT_vtail; auto. Qed.
vconsT (vremoveT a) (vtail a) = a.
Proof. intros. apply vconsT_vremoveT_vtail; auto. Qed.
vremoveT (vconsT a x) = a
Lemma vremoveT_vconsT : forall {n} (a : vec n) x, vremoveT (vconsT a x) = a.
Proof. intros. apply vremoveT_vconsT; auto. Qed.
Proof. intros. apply vremoveT_vconsT; auto. Qed.
vtail (vconsT a x) = x
Lemma vtail_vconsT : forall {n} (a : vec n) x, vtail (vconsT a x) = x.
Proof. intros. apply vtail_vconsT; auto. Qed.
Proof. intros. apply vtail_vconsT; auto. Qed.
vzero; 0 = vzero
Lemma vconsT_vzero_eq0 : forall {n}, @vconsT n vzero Azero = vzero.
Proof. intros. apply vconsT_vzero_eq0; auto. Qed.
Proof. intros. apply vconsT_vzero_eq0; auto. Qed.
Definition vapp {n m} (a : vec n) (b : vec m) : vec (n + m) := vapp a b.
Infix "++" := vapp : vec_scope.
Infix "++" := vapp : vec_scope.
Lemma vapp_spec_l : forall {n m} (a : vec n) (b : vec m) (i : nat),
i < n -> v2f (a ++ b) i = v2f a i.
Proof. intros. apply vapp_spec_l; auto. Qed.
i < n -> v2f (a ++ b) i = v2f a i.
Proof. intros. apply vapp_spec_l; auto. Qed.
Lemma vapp_spec_r : forall {n m} (a : vec n) (b : vec m) (i : nat),
n <= i -> i < n + m -> v2f (a ++ b) i = v2f b (i - n).
Proof. intros. apply vapp_spec_r; auto. Qed.
n <= i -> i < n + m -> v2f (a ++ b) i = v2f b (i - n).
Proof. intros. apply vapp_spec_r; auto. Qed.
Lemma vnth_vapp_l : forall {n m} (a : vec n) (b : vec m) (i : 'I_(n + m)) (H: i < n),
(a ++ b).[i] = a.[fin2AddRangeR' i H].
Proof. intros. apply vnth_vapp_l. Qed.
(a ++ b).[i] = a.[fin2AddRangeR' i H].
Proof. intros. apply vnth_vapp_l. Qed.
Lemma vnth_vapp_r : forall {n m} (a : vec n) (b : vec m) (i : 'I_(n + m)) (H : n <= i),
(a ++ b).[i] = b.[fin2AddRangeAddL' i H].
Proof. intros. apply vnth_vapp_r. Qed.
(a ++ b).[i] = b.[fin2AddRangeAddL' i H].
Proof. intros. apply vnth_vapp_r. Qed.
a ++ b = 0 <-> a = 0 /\ b = 0
Lemma vapp_eq0_iff : forall {n m} (a : vec n) (b : vec m),
a ++ b = vzero <-> a = vzero /\ b = vzero.
Proof. intros. apply vapp_eq0_iff; auto. Qed.
a ++ b = vzero <-> a = vzero /\ b = vzero.
Proof. intros. apply vapp_eq0_iff; auto. Qed.
vapp (vheadN a) (vtailN a) = a
Lemma vapp_vheadN_vtailN : forall {n m} (a : vec (n + m)),
vheadN a ++ vtailN a = a.
Proof. intros. apply vapp_vheadN_vtailN; auto. Qed.
vheadN a ++ vtailN a = a.
Proof. intros. apply vapp_vheadN_vtailN; auto. Qed.
A proposition which at least one element of the vector holds
Definition vmem {n} (a : vec n) (x : A) : Prop := vmem a x.
Lemma vmem_vnth : forall {n} (a : vec n) (i : 'I_n), vmem a (a.[i]).
Proof. intros. apply vmem_vnth. Qed.
Lemma vmem_vnth : forall {n} (a : vec n) (i : 'I_n), vmem a (a.[i]).
Proof. intros. apply vmem_vnth. Qed.
{x ∈ a} + {x ∉ a}
Lemma vmem_dec : forall {n} (a : vec n) (x : A), {vmem a x} + {~vmem a x}.
Proof. intros. apply vmem_dec; auto. Qed.
Proof. intros. apply vmem_dec; auto. Qed.
Definition vmems {r s} (a : vec r) (b : vec s) : Prop := vmems a b.
Lemma vmems_refl : forall {n} (a : vec n), vmems a a.
Proof. intros. apply vmems_refl. Qed.
Lemma vmems_trans : forall {r s t} (a : vec r) (b : vec s) (c : vec t),
vmems a b -> vmems b c -> vmems a c.
Proof. intros. apply vmems_trans with b; auto. Qed.
Lemma vmems_refl : forall {n} (a : vec n), vmems a a.
Proof. intros. apply vmems_refl. Qed.
Lemma vmems_trans : forall {r s t} (a : vec r) (b : vec s) (c : vec t),
vmems a b -> vmems b c -> vmems a c.
Proof. intros. apply vmems_trans with b; auto. Qed.
{a ⊆ b} + {~(a ⊆ b)}
Lemma vmems_dec : forall {r s} (a : vec r) (b : vec s), {vmems a b} + {~vmems a b}.
Proof. intros. apply vmems_dec. Qed.
Proof. intros. apply vmems_dec. Qed.
Two vectors are equivalent (i.e., contain each other)
Definition vequiv {r s} (a : vec r) (b : vec s) : Prop := vequiv a b.
Lemma vequiv_refl : forall {n} (a : vec n), vequiv a a.
Proof. intros. apply vequiv_refl. Qed.
Lemma vequiv_syms : forall {r s} (a : vec r) (b : vec s), vequiv a b -> vequiv b a.
Proof. intros. apply vequiv_syms; auto. Qed.
Lemma vequiv_trans : forall {r s t} (a : vec r) (b : vec s) (c : vec t),
vequiv a b -> vequiv b c -> vequiv a c.
Proof. intros. apply vequiv_trans with b; auto. Qed.
Lemma vequiv_refl : forall {n} (a : vec n), vequiv a a.
Proof. intros. apply vequiv_refl. Qed.
Lemma vequiv_syms : forall {r s} (a : vec r) (b : vec s), vequiv a b -> vequiv b a.
Proof. intros. apply vequiv_syms; auto. Qed.
Lemma vequiv_trans : forall {r s t} (a : vec r) (b : vec s) (c : vec t),
vequiv a b -> vequiv b c -> vequiv a c.
Proof. intros. apply vequiv_trans with b; auto. Qed.
{a ∼ b} + {~(a ∼ b)}
Lemma vequiv_dec : forall {r s} (a : vec r) (b : vec s), {vequiv a b} + {~ vequiv a b}.
Proof. intros. apply vequiv_dec; auto. Qed.
Proof. intros. apply vequiv_dec; auto. Qed.
((x + a.1) + a.2) + ...
... + (v.(n-1) + (v.n + x))
Convert `vfoldl` to `seqfoldl`
Lemma vfoldl_eq_seqfoldl :
forall {B} {n} (a : vec n) (x : B) (f : B -> A -> B) (s : nat -> A),
(forall i, a.[i] = s i) -> vfoldl a x f = seqfoldl s n x f.
Proof. intros. apply vfoldl_eq_seqfoldl; auto. Qed.
forall {B} {n} (a : vec n) (x : B) (f : B -> A -> B) (s : nat -> A),
(forall i, a.[i] = s i) -> vfoldl a x f = seqfoldl s n x f.
Proof. intros. apply vfoldl_eq_seqfoldl; auto. Qed.
Automation for vector equality proofs
square matrix type
row vector type
column vector type
Lemma meq_iff_mnth : forall {r c : nat} (M N : mat r c),
M = N <-> (forall i j, M.[i].[j] = N.[i].[j]).
Proof. intros. apply meq_iff_mnth. Qed.
M = N <-> (forall i j, M.[i].[j] = N.[i].[j]).
Proof. intros. apply meq_iff_mnth. Qed.
Two matrices are not equal, iff, exist one element-wise not equal
Lemma mneq_iff_exist_mnth_neq : forall {r c} (M N : mat r c),
M <> N <-> (exists i j, M.[i].[j] <> N.[i].[j]).
Proof. intros. apply mneq_iff_exist_mnth_neq. Qed.
M <> N <-> (exists i j, M.[i].[j] <> N.[i].[j]).
Proof. intros. apply mneq_iff_exist_mnth_neq. Qed.
Definition cv2v {n} (M : cvec n) : vec n := cv2v M.
Definition v2cv {n} (a : vec n) : cvec n := v2cv a.
Lemma cv2v_spec : forall {n} (M : cvec n) i, M.[i].[fin0] = (cv2v M).[i].
Proof. intros. apply (cv2v_spec M). Qed.
Lemma v2cv_spec : forall {n} (a : vec n) i, a.[i] = (v2cv a).[i].[fin0].
Proof. intros. apply v2cv_spec. Qed.
Lemma cv2v_v2cv : forall {n} (a : vec n), cv2v (v2cv a) = a.
Proof. intros. apply cv2v_v2cv. Qed.
Lemma v2cv_cv2v : forall {n} (M : cvec n), v2cv (cv2v M) = M.
Proof. intros. apply v2cv_cv2v. Qed.
Lemma cv2v_inj : forall {n} (M N : cvec n), cv2v M = cv2v N -> M = N.
Proof. intros. apply cv2v_inj; auto. Qed.
Lemma v2cv_inj : forall {n} (a b : vec n), v2cv a = v2cv b -> a = b.
Proof. intros. apply v2cv_inj; auto. Qed.
Lemma vnth_v2cv : forall {n} (a : vec n) i j, (v2cv a).[i].[j] = a.[i].
Proof. intros. apply vnth_v2cv. Qed.
Definition rv2v {n} (M : rvec n) : vec n := rv2v M.
Definition v2rv {n} (a : vec n) : rvec n := v2rv a.
Lemma rv2v_spec : forall {n} (M : rvec n) i, M.[fin0].[i] = (rv2v M).[i].
Proof. intros. apply rv2v_spec. Qed.
Lemma v2rv_spec : forall {n} (a : vec n) i, a.[i] = (v2rv a).[fin0].[i].
Proof. intros. apply v2rv_spec. Qed.
Lemma rv2v_v2rv : forall {n} (a : vec n), rv2v (v2rv a) = a.
Proof. intros. apply cv2v_v2cv. Qed.
Lemma v2rv_rv2v : forall {n} (M : rvec n), v2rv (rv2v M) = M.
Proof. intros. apply v2rv_rv2v. Qed.
Lemma vnth_v2rv : forall {n} (a : vec n) i, (v2rv a).[i] = a.
Proof. intros. apply vnth_v2rv. Qed.
Definition f2m {r c} (f : nat -> nat -> A) : mat r c := f2m f.
Definition m2f {r c} (M : mat r c) : nat -> nat -> A := m2f 0 M.
Lemma f2m_inj : forall {r c} (f g : nat -> nat -> A),
@f2m r c f = @f2m r c g -> (forall i j, i < r -> j < c -> f i j = g i j).
Proof. intros. apply (@f2m_inj _ r c); auto. Qed.
Lemma mnth_f2m : forall {r c} (f : nat -> nat -> A) i j,
(@f2m r c f) i j = f i j.
Proof. intros. apply mnth_f2m. Qed.
(@f2m r c f) i j = f i j.
Proof. intros. apply mnth_f2m. Qed.
(f2m f).i = f2v (f i)
Lemma vnth_f2m : forall {r c} (f : nat -> nat -> A) i,
(@f2m r c f).[i] = f2v (f i).
Proof. intros. apply vnth_f2m. Qed.
(@f2m r c f).[i] = f2v (f i).
Proof. intros. apply vnth_f2m. Qed.
Lemma nth_m2f : forall {r c} (M : mat r c) (i j : nat) (Hi : i < r)(Hj : j < c),
(m2f M) i j = M.[nat2fin i Hi].[nat2fin j Hj].
Proof. intros. apply nth_m2f. Qed.
(m2f M) i j = M.[nat2fin i Hi].[nat2fin j Hj].
Proof. intros. apply nth_m2f. Qed.
Lemma nth_m2f_nat2finS : forall {r c} (M : mat (S r) (S c)) i j,
i < S r -> j < S c -> (m2f M) i j = M.[#i].[#j].
Proof. intros. apply nth_m2f_nat2finS; auto. Qed.
Lemma m2f_inj : forall {r c} (M1 M2 : mat r c),
(forall i j, i < r -> j < c -> (m2f M1) i j = (m2f M2) i j) -> M1 = M2.
Proof. intros. apply m2f_inj in H; auto. Qed.
Lemma f2m_m2f : forall {r c} (M : mat r c), f2m (m2f M) = M.
Proof. intros. apply f2m_m2f. Qed.
Lemma m2f_f2m : forall {r c} (f : nat -> nat -> A),
forall i j, i < r -> j < c -> m2f (@f2m r c f) i j = f i j.
Proof. intros. apply m2f_f2m; auto. Qed.
i < S r -> j < S c -> (m2f M) i j = M.[#i].[#j].
Proof. intros. apply nth_m2f_nat2finS; auto. Qed.
Lemma m2f_inj : forall {r c} (M1 M2 : mat r c),
(forall i j, i < r -> j < c -> (m2f M1) i j = (m2f M2) i j) -> M1 = M2.
Proof. intros. apply m2f_inj in H; auto. Qed.
Lemma f2m_m2f : forall {r c} (M : mat r c), f2m (m2f M) = M.
Proof. intros. apply f2m_m2f. Qed.
Lemma m2f_f2m : forall {r c} (f : nat -> nat -> A),
forall i j, i < r -> j < c -> m2f (@f2m r c f) i j = f i j.
Proof. intros. apply m2f_f2m; auto. Qed.
Definition l2m {r c} (dl : dlist A) : mat r c := l2m 0 dl.
Definition m2l {r c} (M : mat r c) : dlist A := m2l M.
Lemma l2m_inj : forall {r c} (d1 d2 : dlist A),
length d1 = r -> width d1 c -> length d2 = r -> width d2 c ->
@l2m r c d1 = l2m d2 -> d1 = d2.
Proof. intros. apply l2m_inj in H3; auto. Qed.
Lemma l2m_surj : forall {r c} (M : mat r c), (exists d, l2m d = M).
Proof. intros. apply l2m_surj. Qed.
Lemma m2l_length : forall {r c} (M : mat r c), length (m2l M) = r.
Proof. intros. apply m2l_length. Qed.
Lemma m2l_width : forall {r c} (M : mat r c), width (m2l M) c.
Proof. intros. apply m2l_width. Qed.
Lemma m2l_inj : forall {r c} (m1 m2 : mat r c), m2l m1 = m2l m2 -> m1 = m2.
Proof. intros. apply m2l_inj; auto. Qed.
Lemma m2l_surj : forall {r c} (d : dlist A),
length d = r -> width d c -> (exists M : mat r c, m2l M = d).
Proof. intros. apply (m2l_surj 0); auto. Qed.
Lemma l2m_m2l : forall {r c} (M : mat r c), @l2m r c (m2l M) = M.
Proof. intros. apply l2m_m2l. Qed.
Lemma m2l_l2m : forall {r c} (dl : dlist A),
length dl = r -> width dl c -> m2l (@l2m r c dl) = dl.
Proof. intros. apply m2l_l2m; auto. Qed.
`list of row vectors` to mat
Definition rvl2m {r c} (l : list (vec c)) : mat r c := rvl2m 0 l.
Lemma m2rvl_rvl2m : forall {r c} (l : list (vec c)),
length l = r -> @m2rvl r c (rvl2m l) = l.
Proof. apply m2rvl_rvl2m. Qed.
Lemma rvl2m_m2rvl : forall {r c} (M : mat r c), rvl2m (m2rvl M) = M.
Proof. apply rvl2m_m2rvl. Qed.
Lemma m2rvl_rvl2m : forall {r c} (l : list (vec c)),
length l = r -> @m2rvl r c (rvl2m l) = l.
Proof. apply m2rvl_rvl2m. Qed.
Lemma rvl2m_m2rvl : forall {r c} (M : mat r c), rvl2m (m2rvl M) = M.
Proof. apply rvl2m_m2rvl. Qed.
mat to `list of column vectors`
`list of column vectors` to mat
Definition cvl2m {r c} (l : list (vec r)) : mat r c := cvl2m 0 l.
Lemma m2cvl_cvl2m : forall {r c} (l : list (vec r)),
length l = c -> @m2cvl r c (cvl2m l) = l.
Proof. apply m2cvl_cvl2m. Qed.
Lemma cvl2m_m2cvl : forall {r c} (M : mat r c), cvl2m (m2cvl M) = M.
Proof. apply cvl2m_m2cvl. Qed.
Lemma m2cvl_cvl2m : forall {r c} (l : list (vec r)),
length l = c -> @m2cvl r c (cvl2m l) = l.
Proof. apply m2cvl_cvl2m. Qed.
Lemma cvl2m_m2cvl : forall {r c} (M : mat r c), cvl2m (m2cvl M) = M.
Proof. apply cvl2m_m2cvl. Qed.
Definition mkmat_0_c c : mat 0 c := mkmat_0_c c (Azero:=0).
Definition mkmat_r_0 r : mat r 0 := mkmat_r_0 r (Azero:=0).
Definition mkmat_1_1 a11 : mat 1 1 := mkmat_1_1 a11 (Azero:=0).
Definition mkmat_1_c c (a : vec c) : mat 1 c := mkmat_1_c c a.
Definition mkmat_r_1 r (a : vec r) : mat r 1 := mkmat_r_1 r a.
Definition mkmat_1_2 a11 a12 : mat 1 2 := mkmat_1_2 a11 a12 (Azero:=0).
Definition mkmat_2_1 a11 a21 : mat 2 1 := mkmat_2_1 a11 a21 (Azero:=0).
Definition mkmat_2_2 a11 a12 a21 a22 : mat 2 2 :=
mkmat_2_2 a11 a12 a21 a22 (Azero:=0).
Definition mkmat_1_3 a11 a12 a13 : mat 1 3 :=
mkmat_1_3 a11 a12 a13 (Azero:=0).
Definition mkmat_3_1 a11 a21 a31 : mat 3 1 :=
mkmat_3_1 a11 a21 a31 (Azero:=0).
Definition mkmat_3_3 a11 a12 a13 a21 a22 a23 a31 a32 a33 : mat 3 3 :=
mkmat_3_3 a11 a12 a13 a21 a22 a23 a31 a32 a33 (Azero:=0).
Definition mkmat_1_4 a11 a12 a13 a14 : mat 1 4 :=
mkmat_1_4 a11 a12 a13 a14 (Azero:=0).
Definition mkmat_4_1 a11 a21 a31 a41 : mat 4 1 :=
mkmat_4_1 a11 a21 a31 a41 (Azero:=0).
Definition mkmat_4_4 a11 a12 a13 a14 a21 a22 a23 a24
a31 a32 a33 a34 a41 a42 a43 a44 : mat 4 4 :=
mkmat_4_4
a11 a12 a13 a14 a21 a22 a23 a24
a31 a32 a33 a34 a41 a42 a43 a44 (Azero:=0).
Definition mrow {r c} (M : mat r c) (i : 'I_r) : vec c := mrow M i.
Definition mcol {r c} (M : mat r c) (j : 'I_c) : vec r := mcol M j.
Notation "M &1" := (mcol M #0) : mat_scope.
Notation "M &2" := (mcol M #1) : mat_scope.
Notation "M &3" := (mcol M #2) : mat_scope.
Notation "M &4" := (mcol M #3) : mat_scope.
(mrow M i).j = M.i.j
Lemma vnth_mrow : forall {r c} (M : mat r c) (i : 'I_r) (j : 'I_c),
(mrow M i).[j] = M.[i].[j].
Proof. intros. apply vnth_mrow. Qed.
(mrow M i).[j] = M.[i].[j].
Proof. intros. apply vnth_mrow. Qed.
(mcol M j).i = M.i.j
Lemma vnth_mcol : forall {r c} (M : mat r c) (i : 'I_r) (j : 'I_c),
(mcol M j).[i] = M.[i].[j].
Proof. intros. apply vnth_mcol. Qed.
Lemma mcol_mtrans_eq_mrow : forall {r c} (M : mat r c) (i : 'I_r),
mcol (M\T) i = mrow M i.
Proof. intros. apply mcol_mtrans_eq_mrow. Qed.
Lemma mrow_mtrans_eq_mcol : forall {r c} (M : mat r c) (j : 'I_c),
mrow (M\T) j = mcol M j.
Proof. intros. apply mrow_mtrans_eq_mcol. Qed.
(mcol M j).[i] = M.[i].[j].
Proof. intros. apply vnth_mcol. Qed.
Lemma mcol_mtrans_eq_mrow : forall {r c} (M : mat r c) (i : 'I_r),
mcol (M\T) i = mrow M i.
Proof. intros. apply mcol_mtrans_eq_mrow. Qed.
Lemma mrow_mtrans_eq_mcol : forall {r c} (M : mat r c) (j : 'I_c),
mrow (M\T) j = mcol M j.
Proof. intros. apply mrow_mtrans_eq_mcol. Qed.
Append matrix by column
Get tail column
(mheadc M).i = M.i.0
Lemma vnth_mheadc : forall {r c} (M : mat r (S c)) i, (mheadc M).[i] = M.[i].[fin0].
Proof. intros. apply vnth_mheadc; auto. Qed.
Proof. intros. apply vnth_mheadc; auto. Qed.
(mtailc M).i = M.i.(n-1)
Lemma vnth_mtailc : forall {r c} (M : mat r (S c)) i, (mtailc M).[i] = M.[i].[#c].
Proof. intros. apply vnth_mtailc; auto. Qed.
Proof. intros. apply vnth_mtailc; auto. Qed.
Remove tail column
(mremovecH M).i.j = M.i.(S j)
Lemma mnth_mremovecH : forall {r c} (M : mat r (S c)) i j,
(mremovecH M).[i].[j] = M.[i].[fSuccRangeS j].
Proof. intros. apply mnth_mremovecH; auto. Qed.
(mremovecH M).[i].[j] = M.[i].[fSuccRangeS j].
Proof. intros. apply mnth_mremovecH; auto. Qed.
(mremovecT M).i.j = M.i.j
Lemma mnth_mremovecT : forall {r c} (M : mat r (S c)) i j,
(mremovecT M).[i].[j] = M.[i].[fSuccRange j].
Proof. intros. apply mnth_mremovecT; auto. Qed.
(mremovecT M).[i].[j] = M.[i].[fSuccRange j].
Proof. intros. apply mnth_mremovecT; auto. Qed.
Construct a matrix with a matrix and a row vector
Construct a matrix with a column vector and a matrix
Construct a matrix with a matrix and a column vector
Definition mconscT {r c} (M : mat r c) (a : vec r) : mat r (S c) := mconscT M a.
Lemma mnth_mconsrH_0 : forall {r c} (a : vec c) (M : mat r c) j,
(mconsrH a M).[fin0].[j] = a.[j].
Proof. intros. apply mnth_mconsrH_0; auto. Qed.
Lemma mnth_mconsrH_gt0 :
forall {r c} (a : vec c) (M : mat r c) (i : 'I_(S r)) (j : 'I_c) (H : 0 < i),
(mconsrH a M).[i].[j] = M.[fPredRangeP i H].[j].
Proof. intros. apply mnth_mconsrH_gt0; auto. Qed.
Lemma mconsrH_spec : forall {r c} (a : vec c) (M : mat r c),
let fa := v2f a in
let fM := m2f M in
let faM := m2f (mconsrH a M) in
(forall j, j < c -> faM O j = fa j) /\
(forall i j, 0 < i < r -> j < c -> faM i j = fM (i - 1) j).
Proof. intros. apply mconsrH_spec. Qed.
Lemma mnth_mconsrT_n : forall {r c} (M : mat r c) (a : vec c) i j,
i = #r -> (mconsrT M a).[i].[j] = a.[j].
Proof. intros. apply mnth_mconsrT_n; auto. Qed.
Lemma mnth_mconsrT_lt :
forall {r c} (M : mat r c) (a : vec c) i j (E : fin2nat i < r),
(mconsrT M a).[i].[j] = M.[fPredRange i E].[j].
Proof. intros. apply mnth_mconsrT_lt; auto. Qed.
Lemma vnth_mconscH : forall {r c} (M : mat (S r) c) (a : vec (S r)) (i : 'I_(S r)),
(mconscH a M).[i] = vconsH (a.[i]) (M.[i]).
Proof. intros; apply vnth_mconscH; auto. Qed.
Lemma mnth_mconscH_0 : forall {r c} (a : vec r) (M : mat r c) i,
(mconscH a M).[i].[fin0] = a.[i].
Proof. intros. apply mnth_mconscH_0; auto. Qed.
Lemma mnth_mconscH_gt0 :
forall {r c} (M : mat r c) (a : vec r) i j (E : 0 < fin2nat j),
(mconscH a M).[i].[j] = M.[i].[fPredRangeP j E].
Proof. intros. apply mnth_mconscH_gt0; auto. Qed.
Lemma mnth_mconsrH_0 : forall {r c} (a : vec c) (M : mat r c) j,
(mconsrH a M).[fin0].[j] = a.[j].
Proof. intros. apply mnth_mconsrH_0; auto. Qed.
Lemma mnth_mconsrH_gt0 :
forall {r c} (a : vec c) (M : mat r c) (i : 'I_(S r)) (j : 'I_c) (H : 0 < i),
(mconsrH a M).[i].[j] = M.[fPredRangeP i H].[j].
Proof. intros. apply mnth_mconsrH_gt0; auto. Qed.
Lemma mconsrH_spec : forall {r c} (a : vec c) (M : mat r c),
let fa := v2f a in
let fM := m2f M in
let faM := m2f (mconsrH a M) in
(forall j, j < c -> faM O j = fa j) /\
(forall i j, 0 < i < r -> j < c -> faM i j = fM (i - 1) j).
Proof. intros. apply mconsrH_spec. Qed.
Lemma mnth_mconsrT_n : forall {r c} (M : mat r c) (a : vec c) i j,
i = #r -> (mconsrT M a).[i].[j] = a.[j].
Proof. intros. apply mnth_mconsrT_n; auto. Qed.
Lemma mnth_mconsrT_lt :
forall {r c} (M : mat r c) (a : vec c) i j (E : fin2nat i < r),
(mconsrT M a).[i].[j] = M.[fPredRange i E].[j].
Proof. intros. apply mnth_mconsrT_lt; auto. Qed.
Lemma vnth_mconscH : forall {r c} (M : mat (S r) c) (a : vec (S r)) (i : 'I_(S r)),
(mconscH a M).[i] = vconsH (a.[i]) (M.[i]).
Proof. intros; apply vnth_mconscH; auto. Qed.
Lemma mnth_mconscH_0 : forall {r c} (a : vec r) (M : mat r c) i,
(mconscH a M).[i].[fin0] = a.[i].
Proof. intros. apply mnth_mconscH_0; auto. Qed.
Lemma mnth_mconscH_gt0 :
forall {r c} (M : mat r c) (a : vec r) i j (E : 0 < fin2nat j),
(mconscH a M).[i].[j] = M.[i].[fPredRangeP j E].
Proof. intros. apply mnth_mconscH_gt0; auto. Qed.
mconscH (mheadc M) (mremovecH M) = M
Lemma mconscH_mheadc_mremovecH : forall {r c} (M : mat r (S c)),
mconscH (mheadc M) (mremovecH M) = M.
Proof. intros. apply mconscH_mheadc_mremovecH; auto. Qed.
mconscH (mheadc M) (mremovecH M) = M.
Proof. intros. apply mconscH_mheadc_mremovecH; auto. Qed.
mconscH (vconsT a x) (vconsT M b) = vconsT (mconscH a M) (vconsH x b)
Lemma mconscH_vconsT_vconsT_eq_vconsT_mconscH_vconsH :
forall {r c} (a : vec r) (x : A) (M : mat r c) (b : vec c),
mconscH (vconsT a x) (Vector.vconsT M b) =
Vector.vconsT (mconscH a M) (vconsH x b).
Proof. intros. apply mconscH_vconsT_vconsT_eq_vconsT_mconscH_vconsH. Qed.
Lemma mnth_mconscT_n : forall {r c} (M : mat r c) (a : vec r) i j,
j = nat2finS c -> (mconscT M a).[i].[j] = a.[i].
Proof. intros. apply mnth_mconscT_n; auto. fin. Qed.
Lemma mnth_mconscT_lt :
forall {r c} (M : mat r c) (a : vec r) i j (H : fin2nat j < c),
(mconscT M a).[i].[j] = M.[i].[fPredRange j H].
Proof. intros. apply mnth_mconscT_lt; auto. Qed.
Lemma vnth_mconscT : forall {r c} (M : mat r c) (a : vec r) i,
(mconscT M a).[i] = vconsT M.[i] a.[i].
Proof. intros. apply vnth_mconscT; auto. Qed.
forall {r c} (a : vec r) (x : A) (M : mat r c) (b : vec c),
mconscH (vconsT a x) (Vector.vconsT M b) =
Vector.vconsT (mconscH a M) (vconsH x b).
Proof. intros. apply mconscH_vconsT_vconsT_eq_vconsT_mconscH_vconsH. Qed.
Lemma mnth_mconscT_n : forall {r c} (M : mat r c) (a : vec r) i j,
j = nat2finS c -> (mconscT M a).[i].[j] = a.[i].
Proof. intros. apply mnth_mconscT_n; auto. fin. Qed.
Lemma mnth_mconscT_lt :
forall {r c} (M : mat r c) (a : vec r) i j (H : fin2nat j < c),
(mconscT M a).[i].[j] = M.[i].[fPredRange j H].
Proof. intros. apply mnth_mconscT_lt; auto. Qed.
Lemma vnth_mconscT : forall {r c} (M : mat r c) (a : vec r) i,
(mconscT M a).[i] = vconsT M.[i] a.[i].
Proof. intros. apply vnth_mconscT; auto. Qed.
mconscT (mremovecT M) (mtailc M) = M
Lemma mconscT_mremovecT_mtailc : forall {r c} (M : mat r (S c)),
mconscT (mremovecT M) (mtailc M) = M.
Proof. intros. apply mconscT_mremovecT_mtailc; auto. Qed.
mconscT (mremovecT M) (mtailc M) = M.
Proof. intros. apply mconscT_mremovecT_mtailc; auto. Qed.
Definition mmap {r c} (f : A -> A) (M : mat r c) : mat r c := mmap f M.
Definition mmap2 {r c} (f : A -> A -> A) (M N : mat r c) : mat r c := mmap2 f M N.
Lemma mmap2_comm :
forall {r c} (f : A -> A -> A) (M N : mat r c) {Comm : Commutative f},
mmap2 f M N = mmap2 f N M.
Proof. intros. apply mmap2_comm; auto. Qed.
Lemma mmap2_assoc :
forall {r c} (f : A -> A -> A) (M N O : mat r c) {Assoc : Associative f},
mmap2 f (mmap2 f M N) O = mmap2 f M (mmap2 f N O).
Proof. intros. apply mmap2_assoc; auto. Qed.
set column
Definition msetc {r c} (M : mat r c) (a : vec r) (j0 : 'I_c) : mat r c :=
msetc M a j0.
Lemma mnth_msetr_same : forall {r c} (M : mat r c) (a : vec c) (i0 : 'I_r) i j,
i = i0 -> (msetr M a i0).[i].[j] = a.[j].
Proof. intros. apply mnth_msetr_same; auto. Qed.
Lemma mnth_msetr_diff : forall {r c} (M : mat r c) (a : vec c) (i0 : 'I_r) i j,
i <> i0 -> (msetr M a i0).[i].[j] = M.[i].[j].
Proof. intros. apply mnth_msetr_diff; auto. Qed.
Lemma mnth_msetc_same : forall {r c} (M : mat r c) (a : vec r) (j0 : 'I_c) i j,
j = j0 -> (msetc M a j0).[i].[j] = a.[i].
Proof. intros. apply mnth_msetc_same; auto. Qed.
Lemma mnth_msetc_diff : forall {r c} (M : mat r c) (a : vec r) (j0 : 'I_c) i j,
j <> j0 -> (msetc M a j0).[i].[j] = M.[i].[j].
Proof. intros. apply mnth_msetc_diff; auto. Qed.
msetc M a j0.
Lemma mnth_msetr_same : forall {r c} (M : mat r c) (a : vec c) (i0 : 'I_r) i j,
i = i0 -> (msetr M a i0).[i].[j] = a.[j].
Proof. intros. apply mnth_msetr_same; auto. Qed.
Lemma mnth_msetr_diff : forall {r c} (M : mat r c) (a : vec c) (i0 : 'I_r) i j,
i <> i0 -> (msetr M a i0).[i].[j] = M.[i].[j].
Proof. intros. apply mnth_msetr_diff; auto. Qed.
Lemma mnth_msetc_same : forall {r c} (M : mat r c) (a : vec r) (j0 : 'I_c) i j,
j = j0 -> (msetc M a j0).[i].[j] = a.[i].
Proof. intros. apply mnth_msetc_same; auto. Qed.
Lemma mnth_msetc_diff : forall {r c} (M : mat r c) (a : vec r) (j0 : 'I_c) i j,
j <> j0 -> (msetc M a j0).[i].[j] = M.[i].[j].
Proof. intros. apply mnth_msetc_diff; auto. Qed.
Definition mtrans {r c} (M : mat r c): mat c r := mtrans M.
Notation "M \T" := (mtrans M) : mat_scope.
Transpose twice keep unchanged.
Lemma mtrans_mtrans : forall {r c} (M : mat r c), M \T \T = M.
Proof. intros. apply mtrans_mtrans. Qed.
Proof. intros. apply mtrans_mtrans. Qed.
Construct a diagonal matrix
Transpose of a diagonal matrix keep unchanged
Lemma mtrans_diag : forall {n} (M : smat n), mdiag M -> M\T = M.
Proof. intros. apply mtrans_diag in H; auto. Qed.
Proof. intros. apply mtrans_diag in H; auto. Qed.
mdiagMk is correct
Lemma mdiagMk_spec : forall {n} (a : vec n), mdiag (mdiagMk a).
Proof. intros. apply mdiagMk_spec. Qed.
Proof. intros. apply mdiagMk_spec. Qed.
Lemma mnth_mdiagMk_same : forall {n} (a : vec n) i, (mdiagMk a).[i].[i] = a.[i].
Proof. intros. apply mnth_mdiagMk_same. Qed.
Proof. intros. apply mnth_mdiagMk_same. Qed.
Lemma mnth_mdiagMk_diff : forall {n} (a : vec n) i j, i <> j -> (mdiagMk a).[i].[j] = 0.
Proof. intros. apply mnth_mdiagMk_diff; auto. Qed.
Proof. intros. apply mnth_mdiagMk_diff; auto. Qed.
mat0\T = mat0
Lemma mtrans_mat0 : forall {r c : nat}, (@mat0 r c)\T = mat0.
Proof. intros. apply mtrans_mat0. Qed.
Proof. intros. apply mtrans_mat0. Qed.
row mat0 i = vzero
col mat0 i = vzero
Lemma mcol_mat0 : forall {r c} j, (fun k => (@mat0 r c).[k].[j]) = vzero.
Proof. intros. apply mcol_mat0 with (j:=j). Qed.
Proof. intros. apply mcol_mat0 with (j:=j). Qed.
Automation for matrix equality proofs
Module MonoidMatrixTheory (E : MonoidElementType).
Include (BasicMatrixTheory E).
Open Scope vec_scope.
Include (BasicMatrixTheory E).
Open Scope vec_scope.
(∀ i, a.i = b.i) -> Σa = Σb
Lemma vsum_eq : forall {n} (a b : vec n), (forall i, a.[i] = b.[i]) -> vsum a = vsum b.
Proof. intros. apply vsum_eq; intros; auto. Qed.
Proof. intros. apply vsum_eq; intros; auto. Qed.
(∀ i, a.i = 0) -> Σa = 0
Lemma vsum_eq0 : forall {n} (a : vec n), (forall i, a.[i] = 0) -> vsum a = 0.
Proof. intros. apply vsum_eq0; auto. Qed.
Proof. intros. apply vsum_eq0; auto. Qed.
`vsum` of (S n) elements, equal to addition of Sum and tail
Lemma vsumS_tail : forall {n} (a : vec (S n)),
vsum a = (vsum (fun i => a.[fSuccRange i]) + a.[nat2finS n])%A.
Proof. intros. apply vsumS_tail; auto. Qed.
vsum a = (vsum (fun i => a.[fSuccRange i]) + a.[nat2finS n])%A.
Proof. intros. apply vsumS_tail; auto. Qed.
`vsum` of (S n) elements, equal to addition of head and Sum
Lemma vsumS_head : forall {n} (a : vec (S n)),
vsum a = (a.[nat2finS 0] + vsum (fun i => a.[fSuccRangeS i]))%A.
Proof. intros. apply vsumS_head; auto. Qed.
vsum a = (a.[nat2finS 0] + vsum (fun i => a.[fSuccRangeS i]))%A.
Proof. intros. apply vsumS_head; auto. Qed.
Lemma vsum_add : forall {n} (a b : vec n),
(vsum a + vsum b)%A = vsum (fun i => a.[i] + b.[i])%A.
Proof. intros. apply vsum_add; auto. Qed.
(vsum a + vsum b)%A = vsum (fun i => a.[i] + b.[i])%A.
Proof. intros. apply vsum_add; auto. Qed.
`vsum` which only one item is nonzero, then got this item.
Lemma vsum_unique : forall {n} (a : vec n) (x : A) i,
a.[i] = x -> (forall j, i <> j -> a.[j] = 0) -> vsum a = x.
Proof. intros. apply vsum_unique with (i:=i); auto. Qed.
a.[i] = x -> (forall j, i <> j -> a.[j] = 0) -> vsum a = x.
Proof. intros. apply vsum_unique with (i:=i); auto. Qed.
`vsum` of the m+n elements equal to plus of two parts.
Σ0,(m+n) a = Σ0,m(fun i=>ai) + Σm,m+n (fun i=>am+i)
Lemma vsum_plusIdx : forall m n (a : vec (m + n)),
vsum a = (vsum (fun i => a.[fin2AddRangeR i]) +
vsum (fun i => a.[fin2AddRangeAddL i]))%A.
Proof. intros. apply vsum_plusIdx; auto. Qed.
vsum a = (vsum (fun i => a.[fin2AddRangeR i]) +
vsum (fun i => a.[fin2AddRangeAddL i]))%A.
Proof. intros. apply vsum_plusIdx; auto. Qed.
The order of two nested summations can be exchanged.
∑i,0,r(∑j,0,c a.ij) =
a00 + a01 + ... + a0c +
a10 + a11 + ... + a1c +
...
ar0 + ar1 + ... + arc =
∑j,0,c(∑i,0,r a.ij)
Lemma vsum_vsum : forall r c (a : @Vector.vec (vec c) r),
vsum (fun i => vsum (fun j => a.[i].[j])) =
vsum (fun j => vsum (fun i => a.[i].[j])).
Proof. intros. apply vsum_vsum. Qed.
vsum (fun i => vsum (fun j => a.[i].[j])) =
vsum (fun j => vsum (fun i => a.[i].[j])).
Proof. intros. apply vsum_vsum. Qed.
(a + b) + c = a + (b + c)
Lemma vadd_assoc : forall {n} (a b c : vec n), (a + b) + c = a + (b + c).
Proof. intros. apply vadd_assoc. Qed.
Proof. intros. apply vadd_assoc. Qed.
a + b = b + a
0 + a = a
a + 0 = a
Lemma vadd_0_r : forall {n} (a : vec n), a + vzero = a.
Proof. intros. apply vadd_0_r. Qed.
#[export] Instance vadd_AMonoid : forall n, AMonoid (@vadd n) vzero.
Proof. apply vadd_AMonoid. Qed.
Open Scope mat_scope.
Proof. intros. apply vadd_0_r. Qed.
#[export] Instance vadd_AMonoid : forall n, AMonoid (@vadd n) vzero.
Proof. apply vadd_AMonoid. Qed.
Open Scope mat_scope.
Definition madd {r c} (M N : mat r c) : mat r c := madd M N (Aadd:=Aadd).
Infix "+" := madd : mat_scope.
Lemma mnth_madd : forall {r c} (M N : mat r c) i j,
(M + N).[i].[j] = (M.[i].[j] + N.[i].[j])%A.
Proof. intros. unfold madd. apply mnth_madd. Qed.
(M + N).[i].[j] = (M.[i].[j] + N.[i].[j])%A.
Proof. intros. unfold madd. apply mnth_madd. Qed.
cv2v (M + N) = cv2v M + cv2v N
Lemma cv2v_madd : forall {n} (M N : cvec n), cv2v (M + N) = (cv2v M + cv2v N)%V.
Proof. intros. apply cv2v_madd. Qed.
Proof. intros. apply cv2v_madd. Qed.
M + N = N + M
Lemma madd_comm : forall {r c} (M N : mat r c), M + N = (N + M).
Proof. intros. apply madd_comm. Qed.
Proof. intros. apply madd_comm. Qed.
(M + N) + O = M + (N + O)
Lemma madd_assoc : forall {r c} (M N O : mat r c), (M + N) + O = M + (N + O).
Proof. intros. apply madd_assoc. Qed.
Proof. intros. apply madd_assoc. Qed.
(M + N) + O = (M + O) + N
Lemma madd_perm : forall {r c} (M N O : mat r c), (M + N) + O = (M + O) + N.
Proof. intros. apply madd_perm. Qed.
Proof. intros. apply madd_perm. Qed.
mat0 + M = M
M + mat0 = M
(M + N) \T = M \T + N \T
Lemma mtrans_madd : forall {r c} (M N : mat r c), (M + N) \T = M \T + N \T.
Proof. intros. apply mtrans_madd. Qed.
End MonoidMatrixTheory.
Proof. intros. apply mtrans_madd. Qed.
End MonoidMatrixTheory.
Module RingMatrixTheory (E : RingElementType).
Include (MonoidMatrixTheory E).
Open Scope vec_scope.
Include (MonoidMatrixTheory E).
Open Scope vec_scope.
(veye i).i = 1
(veye i).j = 0
Lemma vnth_veye_neq : forall {n} i j, i <> j -> (@veye n i).[j] = 0.
Proof. intros. apply vnth_veye_neq; auto. Qed.
Proof. intros. apply vnth_veye_neq; auto. Qed.
veyes.ii = 1
veyes.ij = 0
Lemma vnth_veyes_neq : forall {n} i j, i <> j -> (veyes n).[i].[j] = 0.
Proof. intros. apply vnth_veyes_neq; auto. Qed.
Proof. intros. apply vnth_veyes_neq; auto. Qed.
Definition vopp {n} (a : vec n) : vec n := vopp (Aopp:=Aopp) a.
Notation "- a" := (vopp a) : vec_scope.
- a + a = 0
Lemma vadd_vopp_l : forall {n} (a : vec n), (- a) + a = vzero.
Proof. intros. apply vadd_vopp_l. Qed.
Proof. intros. apply vadd_vopp_l. Qed.
a + - a = 0
Lemma vadd_vopp_r : forall {n} (a : vec n), a + (- a) = vzero.
Proof. intros. apply vadd_vopp_r. Qed.
#[export] Instance vadd_AGroup : forall n, AGroup (@vadd n) vzero vopp.
Proof. intros. apply vadd_AGroup. Qed.
Proof. intros. apply vadd_vopp_r. Qed.
#[export] Instance vadd_AGroup : forall n, AGroup (@vadd n) vzero vopp.
Proof. intros. apply vadd_AGroup. Qed.
- (- a) = a
a = - b <-> - a = b
Lemma vopp_exchange : forall {n} (a b : vec n), a = - b <-> - a = b.
Proof. intros. apply vopp_exchange. Qed.
Proof. intros. apply vopp_exchange. Qed.
- (vzero) = vzero
- (a + b) = (- a) + (- b)
Lemma vopp_vadd : forall {n} (a b : vec n), - (a + b) = (- a) + (- b).
Proof. intros. apply vopp_vadd. Qed.
Proof. intros. apply vopp_vadd. Qed.
Notation "a - b" := ((a + -b)%V) : vec_scope.
Lemma vsub_self : forall (n : nat) (a : vec n), a - a = (@vzero n).
Proof. intros. apply vsub_self. Qed.
Lemma vsub_0_l : forall (n : nat) (a : vec n), (@vzero n) - a = - a.
Proof. intros. apply vsub_0_l. Qed.
Lemma vsub_comm : forall (n : nat) (a b : vec n), a - b = - (b - a).
Proof. intros. apply vsub_comm. Qed.
Lemma vsub_assoc : forall (n : nat) (a b c : vec n), (a - b) - c = a - (b + c).
Proof. intros. apply vsub_assoc. Qed.
Lemma vsub_assoc1 : forall (n : nat) (a b c : vec n), (a + b) - c = a + (b - c).
Proof. intros. apply vsub_assoc1. Qed.
Lemma vsub_assoc2 : forall (n : nat) (a b c : vec n), (a - b) - c = (a - c) - b.
Proof. intros. apply vsub_assoc2. Qed.
Definition vcmul {n} (x : A) (a : vec n) : vec n := vcmul (Amul:=Amul) x a.
Infix "\.*" := vcmul : vec_scope.
Lemma vnth_vcmul : forall {n} (a : vec n) x i, (x \.* a).[i] = x * (a.[i]).
Proof. intros. cbv. auto. Qed.
Proof. intros. cbv. auto. Qed.
x .* (y .* a) = (x * y) .* a
Lemma vcmul_assoc : forall {n} (x y : A) (a : vec n),
x \.* (y \.* a) = (x * y)%A \.* a.
Proof. intros. apply vcmul_assoc. Qed.
x \.* (y \.* a) = (x * y)%A \.* a.
Proof. intros. apply vcmul_assoc. Qed.
x .* (y .* a) = y .* (x .* a)
Lemma vcmul_perm : forall {n} (x y : A) (a : vec n),
x \.* (y \.* a) = y \.* (x \.* a).
Proof. intros. apply vcmul_perm. Qed.
x \.* (y \.* a) = y \.* (x \.* a).
Proof. intros. apply vcmul_perm. Qed.
(x + y) .* a = (x .* a) + (y .* a)
Lemma vcmul_add : forall {n} (x y : A) (a : vec n),
(x + y)%A \.* a = (x \.* a) + (y \.* a).
Proof. intros. apply vcmul_add. Qed.
(x + y)%A \.* a = (x \.* a) + (y \.* a).
Proof. intros. apply vcmul_add. Qed.
x .* (a + b) = (x .* a) + (x .* b)
Lemma vcmul_vadd : forall {n} x (a b : vec n),
x \.* (a + b) = (x \.* a) + (x \.* b).
Proof. intros. apply vcmul_vadd. Qed.
x \.* (a + b) = (x \.* a) + (x \.* b).
Proof. intros. apply vcmul_vadd. Qed.
1 .* a = a
0 .* a = 0
x .* 0 = 0
(-x) .* a = - (x .* a)
Lemma vcmul_opp : forall {n} x (a : vec n), (- x)%A \.* a = - (x \.* a).
Proof. intros. apply vcmul_opp. Qed.
Proof. intros. apply vcmul_opp. Qed.
x .* (- a) = - (x .* a)
Lemma vcmul_vopp : forall {n} x (a : vec n), x \.* (- a) = - (x \.* a).
Proof. intros. apply vcmul_vopp. Qed.
Proof. intros. apply vcmul_vopp. Qed.
(-x) .* (- a) = x .* a
Lemma vcmul_opp_vopp : forall {n} x (a : vec n), (- x)%A \.* (- a) = x \.* a.
Proof. intros. apply vcmul_opp_vopp. Qed.
Proof. intros. apply vcmul_opp_vopp. Qed.
x .* (a - b) = (x .* a) - (x .* b)
Lemma vcmul_vsub : forall {n} x (a b : vec n),
x \.* (a - b) = (x \.* a) - (x \.* b).
Proof. intros. apply vcmul_vsub. Qed.
x \.* (a - b) = (x \.* a) - (x \.* b).
Proof. intros. apply vcmul_vsub. Qed.
a <> 0 -> b <> 0 -> x .* a = b -> x <> 0
Lemma vcmul_eq_imply_x_neq0 : forall {n} (a b : vec n) x,
a <> vzero -> b <> vzero -> x \.* a = b -> x <> 0.
Proof. intros. apply vcmul_eq_imply_x_neq0 in H1; auto. Qed.
a <> vzero -> b <> vzero -> x \.* a = b -> x <> 0.
Proof. intros. apply vcmul_eq_imply_x_neq0 in H1; auto. Qed.
Definition vdot {n : nat} (a b : vec n) : A := @vdot _ Aadd 0 Amul _ a b.
Notation "< a , b >" := (vdot a b) : vec_scope.
<a, b> = <b, a>
<vzero, a> = 0
<a, vzero> = 0
<a + b, c> = <a, c> + <b, c>
Lemma vdot_vadd_l : forall {n} (a b c : vec n), <a + b, c> = (<a, c> + <b, c>)%A.
Proof. intros. apply vdot_vadd_l. Qed.
Proof. intros. apply vdot_vadd_l. Qed.
<a, b + c> = <a, b> + <a, c>
Lemma vdot_vadd_r : forall {n} (a b c : vec n), <a, b + c> = (<a, b> + <a, c>)%A.
Proof. intros. apply vdot_vadd_r. Qed.
Proof. intros. apply vdot_vadd_r. Qed.
<- a, b> = - <a, b>
Lemma vdot_vopp_l : forall {n} (a b : vec n), < - a, b> = (- <a, b>)%A.
Proof. intros. apply vdot_vopp_l. Qed.
Proof. intros. apply vdot_vopp_l. Qed.
<a, - b> = - <a, b>
Lemma vdot_vopp_r : forall {n} (a b : vec n), <a, - b> = (- <a, b>)%A.
Proof. intros. apply vdot_vopp_r. Qed.
Proof. intros. apply vdot_vopp_r. Qed.
<a - b, c> = <a, c> - <b, c>
Lemma vdot_vsub_l : forall {n} (a b c : vec n), <a - b, c> = (<a, c> - <b, c>)%A.
Proof. intros. apply vdot_vsub_l. Qed.
Proof. intros. apply vdot_vsub_l. Qed.
<a, a - c> = <a, b> - <a, c>
Lemma vdot_vsub_r : forall {n} (a b c : vec n), <a, b - c> = (<a, b> - <a, c>)%A.
Proof. intros. apply vdot_vsub_r. Qed.
Proof. intros. apply vdot_vsub_r. Qed.
<x .* a, b> = x * <a, b>
Lemma vdot_vcmul_l : forall {n} (a b : vec n) (x : A), <x \.* a, b> = x * <a, b>.
Proof. intros. apply vdot_vcmul_l. Qed.
Proof. intros. apply vdot_vcmul_l. Qed.
<a, x .* b> = x * <a, b>
Lemma vdot_vcmul_r : forall {n} (a b : vec n) (x : A), <a, x \.* b> = x * <a, b>.
Proof. intros. apply vdot_vcmul_r. Qed.
Proof. intros. apply vdot_vcmul_r. Qed.
<a, veye i> = a i
Lemma vdot_veye_r : forall {n} (a : vec n) i, <a, veye i> = a i.
Proof. intros. apply vdot_veye_r. Qed.
Proof. intros. apply vdot_veye_r. Qed.
<veye i, a> = a i
Lemma vdot_veye_l : forall {n} (a : vec n) i, <veye i, a> = a i.
Proof. intros. apply vdot_veye_l. Qed.
Proof. intros. apply vdot_veye_l. Qed.
<a, b> <> 0 -> a <> 0
Lemma vdot_neq0_imply_neq0_l : forall {n} (a b : vec n), <a, b> <> 0 -> a <> vzero.
Proof. intros. apply vdot_neq0_imply_neq0_l in H; auto. Qed.
Proof. intros. apply vdot_neq0_imply_neq0_l in H; auto. Qed.
<a, b> <> 0 -> b <> 0
Lemma vdot_neq0_imply_neq0_r : forall {n} (a b : vec n), <a, b> <> 0 -> b <> vzero.
Proof. intros. apply vdot_neq0_imply_neq0_r in H; auto. Qed.
Proof. intros. apply vdot_neq0_imply_neq0_r in H; auto. Qed.
(∀ c, <a, c> = <b, c>) -> a = b
Lemma vdot_cancel_r : forall {n} (a b : vec n),
(forall c : vec n, <a, c> = <b, c>) -> a = b.
Proof. intros. apply vdot_cancel_r in H; auto. Qed.
(forall c : vec n, <a, c> = <b, c>) -> a = b.
Proof. intros. apply vdot_cancel_r in H; auto. Qed.
(∀ c, <c, a> = <c, b>) -> a = b
Lemma vdot_cancel_l : forall {n} (a b : vec n),
(forall c : vec n, <c, a> = <c, b>) -> a = b.
Proof. intros. apply vdot_cancel_l in H; auto. Qed.
(forall c : vec n, <c, a> = <c, b>) -> a = b.
Proof. intros. apply vdot_cancel_l in H; auto. Qed.
Lemma vsum_opp : forall {n} (a : vec n),
(- vsum a)%A = vsum (fun i => - a.[i])%A.
Proof. intros. apply vsum_opp; auto. Qed.
(- vsum a)%A = vsum (fun i => - a.[i])%A.
Proof. intros. apply vsum_opp; auto. Qed.
x * Σa = Σ(fun i -> x * a.i)
Lemma vsum_cmul_l : forall {n} (a : vec n) x,
x * vsum a = vsum (fun i => x * a.[i]).
Proof. intros. apply vsum_cmul_l. Qed.
x * vsum a = vsum (fun i => x * a.[i]).
Proof. intros. apply vsum_cmul_l. Qed.
Σa * x = Σ(fun i -> a.i * x)
Lemma vsum_cmul_r : forall {n} (a : vec n) x,
vsum a * x = vsum (fun i => a.[i] * x).
Proof. intros. apply vsum_cmul_r. Qed.
vsum a * x = vsum (fun i => a.[i] * x).
Proof. intros. apply vsum_cmul_r. Qed.
Unit vector
vunit a <-> vunit (vopp a).
Lemma vopp_vunit : forall {n} (a : vec n), vunit (vopp a) <-> vunit a.
Proof. intros. apply vopp_vunit. Qed.
Proof. intros. apply vopp_vunit. Qed.
a _| b -> b _| a
Lemma vorth_comm : forall {n} (a b : vec n), a _|_ b -> b _|_ a.
Proof. intros. apply vorth_comm; auto. Qed.
Open Scope mat_scope.
Proof. intros. apply vorth_comm; auto. Qed.
Open Scope mat_scope.
mat1 is diagonal matrix
mat1 \T = mat1
Lemma mnth_mat1_same : forall {n} i, (@mat1 n).[i].[i] = 1.
Proof. intros. apply mnth_mat1_same; auto. Qed.
Proof. intros. apply mnth_mat1_same; auto. Qed.
Lemma mnth_mat1_diff : forall {n} i j, i <> j -> (@mat1 n).[i].[j] = 0.
Proof. intros. apply mnth_mat1_diff; auto. Qed.
Proof. intros. apply mnth_mat1_diff; auto. Qed.
Definition mtrace {n : nat} (M : smat n) : A := @mtrace _ Aadd 0 _ M.
Notation "'tr' M" := (mtrace M) : mat_scope.
Notation "'tr' M" := (mtrace M) : mat_scope.
tr(M \T) = tr(M)
Lemma mtrace_mtrans : forall {n} (M : smat n), tr (M \T) = tr(M).
Proof. intros. apply mtrace_mtrans. Qed.
Proof. intros. apply mtrace_mtrans. Qed.
tr(M + N) = tr(M) + tr(N)
Lemma mtrace_madd : forall {n} (M N : smat n), tr (M + N) = (tr M + tr N)%A.
Proof. intros. apply mtrace_madd. Qed.
Proof. intros. apply mtrace_madd. Qed.
#[export] Instance madd_AMonoid : forall r c, AMonoid (@madd r c) mat0.
Proof. apply madd_AMonoid. Qed.
Proof. apply madd_AMonoid. Qed.
Definition mopp {r c} (M : mat r c) : mat r c := mopp M (Aopp:=Aopp).
Notation "- a" := (mopp a) : mat_scope.
- (M + N) = (- M) + (- N)
Lemma mopp_madd : forall {r c : nat} (M N : mat r c), - (M + N) = (- M) + (- N).
Proof. intros. apply mopp_madd. Qed.
Proof. intros. apply mopp_madd. Qed.
(- M) + M = mat0
Lemma madd_mopp_l : forall r c (M : mat r c), (- M) + M = mat0.
Proof. intros. apply madd_opp_l. Qed.
Proof. intros. apply madd_opp_l. Qed.
M + (-M) = mat0
Lemma madd_mopp_r : forall r c (M : mat r c), M + (- M) = mat0.
Proof. intros. apply madd_opp_r. Qed.
Proof. intros. apply madd_opp_r. Qed.
- (- M) = M
- mat0 = mat0
(- M) \T = - (M \T)
Lemma mtrans_mopp : forall {r c} (M : mat r c), (- M) \T = - (M \T).
Proof. intros. apply mtrans_mopp. Qed.
Proof. intros. apply mtrans_mopp. Qed.
tr(- M) = - (tr(M))
Lemma mtrace_mopp : forall {n} (M : smat n), tr (- M) = (- tr M)%A.
Proof. intros. apply mtrace_mopp. Qed.
Proof. intros. apply mtrace_mopp. Qed.
M - N = M + (- N)
M - N = - (N - M)
Lemma msub_comm : forall {r c} (M N : mat r c), M - N = - (N - M).
Proof. intros. apply msub_comm. Qed.
Proof. intros. apply msub_comm. Qed.
(M - N) - O = M - (N + O)
Lemma msub_assoc : forall {r c} (M N O : mat r c), (M - N) - O = M - (N + O).
Proof. intros. apply msub_assoc. Qed.
Proof. intros. apply msub_assoc. Qed.
(M + N) - O = M + (N - O)
Lemma msub_assoc1 : forall {r c} (M N O : mat r c), (M + N) - O = M + (N - O).
Proof. intros. apply msub_assoc1. Qed.
Proof. intros. apply msub_assoc1. Qed.
(M - N) - O = M - (O - N)
Lemma msub_assoc2 : forall {r c} (M N O : mat r c), (M - N) - O = (M - O) - N.
Proof. intros. apply msub_assoc2. Qed.
Proof. intros. apply msub_assoc2. Qed.
mat0 - M = - M
M - mat0 = M
M - M = mat0
(M - N) \T = M \T - N \T
Lemma mtrans_msub : forall {r c} (M N : mat r c), (M - N) \T = M \T - N \T.
Proof. intros. apply mtrans_msub. Qed.
Proof. intros. apply mtrans_msub. Qed.
tr(M - N) = tr(M) - tr(N)
Lemma mtrace_msub : forall {n} (M N : smat n), tr (M - N) = (tr M - tr N)%A.
Proof. intros. apply mtrace_msub. Qed.
Proof. intros. apply mtrace_msub. Qed.
#[export] Instance madd_AGroup : forall r c, AGroup (@madd r c) mat0 mopp.
Proof. apply madd_AGroup. Qed.
Proof. apply madd_AGroup. Qed.
Definition mcmul {r c} (x : A) (M : mat r c) : mat r c := mcmul x M (Amul:=Amul).
Infix "\.*" := mcmul : mat_scope.
Infix "\.*" := mcmul : mat_scope.
Lemma mnth_mcmul : forall {r c} (M : mat r c) x i j,
(x \.* M).[i].[j] = x * (M.[i].[j]).
Proof. intros. unfold mcmul. apply mnth_mcmul. Qed.
(x \.* M).[i].[j] = x * (M.[i].[j]).
Proof. intros. unfold mcmul. apply mnth_mcmul. Qed.
cv2v (x .* M) = x .* (cv2v M)
Lemma cv2v_mcmul : forall {n} (x : A) (M : cvec n),
cv2v (x \.* M) = (x \.* (cv2v M))%V.
Proof. intros. apply cv2v_mcmul. Qed.
cv2v (x \.* M) = (x \.* (cv2v M))%V.
Proof. intros. apply cv2v_mcmul. Qed.
0 .* M = mat0
x .* mat0 = mat0
1 .* M = M
Lemma mcmul_1_r : forall {n} x, x \.* mat1 = mdiagMk (vrepeat n x).
Proof. intros. apply mcmul_1_r. Qed.
Proof. intros. apply mcmul_1_r. Qed.
x .* (y .* M) = (x * y) .* M
Lemma mcmul_assoc : forall {r c} (x y : A) (M : mat r c),
x \.* (y \.* M) = (x * y) \.* M.
Proof. intros. apply mcmul_assoc. Qed.
x \.* (y \.* M) = (x * y) \.* M.
Proof. intros. apply mcmul_assoc. Qed.
x .* (y .* M) = y .* (x .* M)
Lemma mcmul_perm : forall {r c} (x y : A) (M : mat r c),
x \.* (y \.* M) = y \.* (x \.* M).
Proof. intros. apply mcmul_perm. Qed.
x \.* (y \.* M) = y \.* (x \.* M).
Proof. intros. apply mcmul_perm. Qed.
(x + y) .* M = (x .* M) + (y .* M)
Lemma mcmul_add_distr : forall {r c} (x y : A) (M : mat r c),
(x + y)%A \.* M = (x \.* M) + (y \.* M).
Proof. intros. apply mcmul_add_distr. Qed.
(x + y)%A \.* M = (x \.* M) + (y \.* M).
Proof. intros. apply mcmul_add_distr. Qed.
x \.* (M + N) = (x \.* M) + (x \.* N)
Lemma mcmul_madd_distr : forall {r c} (x : A) (M N : mat r c),
x \.* (M + N) = (x \.* M) + (x \.* N).
Proof. intros. apply mcmul_madd_distr. Qed.
x \.* (M + N) = (x \.* M) + (x \.* N).
Proof. intros. apply mcmul_madd_distr. Qed.
(-x) .* M = - (x .* M)
Lemma mcmul_opp : forall {r c} x (M : mat r c), (- x)%A \.* M = - (x \.* M).
Proof. intros. apply mcmul_opp. Qed.
Proof. intros. apply mcmul_opp. Qed.
x \.* (- M) = - (x \.* M)
Lemma mcmul_mopp : forall {r c} x (M : mat r c), x \.* (- M) = - (x \.* M).
Proof. intros. apply mcmul_mopp. Qed.
Proof. intros. apply mcmul_mopp. Qed.
x \.* (M - N) = (x \.* M) - (x \.* N)
Lemma mcmul_msub : forall {r c} x (M N : mat r c),
x \.* (M - N) = (x \.* M) - (x \.* N).
Proof. intros. apply mcmul_msub. Qed.
x \.* (M - N) = (x \.* M) - (x \.* N).
Proof. intros. apply mcmul_msub. Qed.
(x \.* M) \T = x \.* (M \T)
Lemma mtrans_mcmul : forall {r c} (x : A) (M : mat r c), (x \.* M) \T = x \.* (M \T).
Proof. intros. apply mtrans_mcmul. Qed.
Proof. intros. apply mtrans_mcmul. Qed.
tr (x \.* M) = a * tr (m)
Lemma mtrace_mcmul : forall {n} (x : A) (M : smat n), tr (x \.* M) = (x * tr M)%A.
Proof. intros. apply mtrace_mcmul. Qed.
Proof. intros. apply mtrace_mcmul. Qed.
M <> 0 -> N <> 0 -> x .* M = N -> x <> 0
Lemma mcmul_eq_imply_not_x0 : forall {r c} (M N : mat r c) x,
M <> mat0 -> N <> mat0 -> x \.* M = N -> x <> 0.
Proof. intros. apply mcmul_eq_imply_not_x0 in H1; auto. Qed.
M <> mat0 -> N <> mat0 -> x \.* M = N -> x <> 0.
Proof. intros. apply mcmul_eq_imply_not_x0 in H1; auto. Qed.
Definition mmul {r c s : nat} (M : mat r c) (N : mat c s) : mat r s :=
mmul M N (Amul:=Amul)(Azero:=0)(Aadd:=Aadd).
Infix "*" := mmul : mat_scope.
mmul M N (Amul:=Amul)(Azero:=0)(Aadd:=Aadd).
Infix "*" := mmul : mat_scope.
Lemma mnth_mmul : forall {r c t} (M : mat r c) (N : mat c t) i j,
(M * N).[i].[j] = <M.[i], (fun k => N.[k].[j])>.
Proof. intros. auto. Qed.
(M * N).[i].[j] = <M.[i], (fun k => N.[k].[j])>.
Proof. intros. auto. Qed.
(M * N)i = <row M i, col N j>
Lemma vnth_mmul : forall {r c t} (M : mat r c) (N : mat c t) i,
(M * N).[i] = Vector.vmap (fun a => <M.[i], a>) (N\T).
Proof. intros. auto. Qed.
(M * N).[i] = Vector.vmap (fun a => <M.[i], a>) (N\T).
Proof. intros. auto. Qed.
N is cvec -> M * N = fun i => (vdot N) (M.i)
Lemma mmul_cvec : forall {r c} (M : mat r c) (N : cvec c),
M * N = fun i j => <cv2v N, M.[i]>.
Proof. intros. apply mmul_cvec. Qed.
M * N = fun i j => <cv2v N, M.[i]>.
Proof. intros. apply mmul_cvec. Qed.
M is rvec -> M * N = fun i j => (vdot M) (mcol N j)
Lemma mmul_rvec : forall {r c} (M : rvec r) (N : mat r c),
M * N = fun i j => <rv2v M, mcol N j>.
Proof. intros. apply mmul_rvec. Qed.
M * N = fun i j => <rv2v M, mcol N j>.
Proof. intros. apply mmul_rvec. Qed.
Lemma vdot_row_col : forall {r c s} (M : mat r c) (N : mat c s) i j,
<mrow M i, mcol N j> = (M * N).[i].[j].
Proof. intros. apply vdot_row_col. Qed.
<mrow M i, mcol N j> = (M * N).[i].[j].
Proof. intros. apply vdot_row_col. Qed.
Lemma vdot_col_col : forall {n} (M N : smat n) i j,
<mcol M i, mcol N j> = (M\T * N).[i].[j].
Proof. intros. apply vdot_col_col. Qed.
<mcol M i, mcol N j> = (M\T * N).[i].[j].
Proof. intros. apply vdot_col_col. Qed.
Lemma vdot_row_row : forall {n} (M N : smat n) i j,
<mrow M i, mrow N j> = (M * N\T).[i].[j].
Proof. intros. apply vdot_row_row. Qed.
<mrow M i, mrow N j> = (M * N\T).[i].[j].
Proof. intros. apply vdot_row_row. Qed.
<a, b> = (a\T * b).11
Lemma vdot_eq_mmul : forall {n} (a b : vec n), <a, b> = (v2rv a * v2cv b).11.
Proof. intros. apply vdot_eq_mmul. Qed.
Proof. intros. apply vdot_eq_mmul. Qed.
(M * N) * O = M * (N * O)
Lemma mmul_assoc : forall {r c s t : nat} (M : mat r c) (N : mat c s) (O : mat s t),
(M * N) * O = M * (N * O).
Proof. intros. apply mmul_assoc. Qed.
(M * N) * O = M * (N * O).
Proof. intros. apply mmul_assoc. Qed.
M * (N + O) = M * N + M * O
Lemma mmul_madd_distr_l : forall {r c s : nat} (M : mat r c) (N O : mat c s),
M * (N + O) = M * N + M * O.
Proof. intros. apply mmul_madd_distr_l. Qed.
M * (N + O) = M * N + M * O.
Proof. intros. apply mmul_madd_distr_l. Qed.
(M + N) * O = M * O + N * O
Lemma mmul_madd_distr_r : forall {r c s : nat} (M N : mat r c) (O : mat c s),
(M + N) * O = M * O + N * O.
Proof. intros. apply mmul_madd_distr_r. Qed.
(M + N) * O = M * O + N * O.
Proof. intros. apply mmul_madd_distr_r. Qed.
M * (N - O) = M * N - M * O
Lemma mmul_msub_distr_l : forall {r c s : nat} (M : mat r c) (N O : mat c s),
M * (N - O) = M * N - M * O.
Proof. intros. apply mmul_msub_distr_l. Qed.
M * (N - O) = M * N - M * O.
Proof. intros. apply mmul_msub_distr_l. Qed.
(M - N) * O = M * O - N * O
Lemma mmul_msub_distr_r : forall {r c s : nat} (M N : mat r c) (O : mat c s),
(M - N) * O = M * O - N * O.
Proof. intros. apply mmul_msub_distr_r. Qed.
(M - N) * O = M * O - N * O.
Proof. intros. apply mmul_msub_distr_r. Qed.
- (M * N) = (- M) * N
Lemma mmul_mopp_l : forall {r c s : nat} (M : mat r c) (N : mat c s),
- (M * N) = (- M) * N.
Proof. intros. apply mmul_mopp_l. Qed.
- (M * N) = (- M) * N.
Proof. intros. apply mmul_mopp_l. Qed.
- (M * N) = M * (- N)
Lemma mmul_mopp_r : forall {r c s : nat} (M : mat r c) (N : mat c s),
- (M * N) = M * (- N).
Proof. intros. apply mmul_mopp_r. Qed.
- (M * N) = M * (- N).
Proof. intros. apply mmul_mopp_r. Qed.
mat0 * M = mat0
Lemma mmul_0_l : forall {r c s} (M : mat c s), (@mat0 r c) * M = mat0.
Proof. intros. apply mmul_0_l. Qed.
Proof. intros. apply mmul_0_l. Qed.
M * mat0 = mat0
Lemma mmul_0_r : forall {r c s} (M : mat r c), M * (@mat0 c s) = mat0.
Proof. intros. apply mmul_0_r. Qed.
Proof. intros. apply mmul_0_r. Qed.
mat1 * M = M
Lemma mmul_1_l : forall {r c : nat} (M : mat r c), mat1 * M = M.
Proof. intros. apply mmul_1_l. Qed.
Proof. intros. apply mmul_1_l. Qed.
M * mat1 = M
Lemma mmul_1_r : forall {r c : nat} (M : mat r c), M * mat1 = M.
Proof. intros. apply mmul_1_r. Qed.
Proof. intros. apply mmul_1_r. Qed.
x \.* (M * N) = (x \.* M) * N.
Lemma mmul_mcmul_l : forall {r c s} (x : A) (M : mat r c) (N : mat c s),
(x \.* M) * N = x \.* (M * N).
Proof. intros. apply mmul_mcmul_l. Qed.
(x \.* M) * N = x \.* (M * N).
Proof. intros. apply mmul_mcmul_l. Qed.
x \.* (M * N) = M * (x \.* N)
Lemma mmul_mcmul_r : forall {r c s} (x : A) (M : mat r c) (N : mat c s),
M * (x \.* N) = x \.* (M * N).
Proof. intros. apply mmul_mcmul_r. Qed.
M * (x \.* N) = x \.* (M * N).
Proof. intros. apply mmul_mcmul_r. Qed.
(M * N) \T = N \T * M \T
Lemma mtrans_mmul : forall {r c s} (M : mat r c) (N : mat c s),
(M * N) \T = N \T * M \T.
Proof. intros. apply mtrans_mmul. Qed.
(M * N) \T = N \T * M \T.
Proof. intros. apply mtrans_mmul. Qed.
tr (M * N) = tr (N * M)
Lemma mtrace_mmul : forall {r c} (M : mat r c) (N : mat c r), tr (M * N) = tr (N * M).
Proof. intros. apply mtrace_mmul. Qed.
Proof. intros. apply mtrace_mmul. Qed.
Definition mmulv {r c : nat} (M : mat r c) (a : vec c) : vec r :=
@mmulv _ Aadd 0 Amul _ _ M a.
Infix "*v" := mmulv : mat_scope.
(M *v a)i = <row M i, a>
Lemma vnth_mmulv : forall {r c} (M : mat r c) (a : vec c) i,
(M *v a).[i] = <M.[i], a>.
Proof. intros. apply vnth_mmulv. Qed.
(M *v a).[i] = <M.[i], a>.
Proof. intros. apply vnth_mmulv. Qed.
(M * N) *v a = M *v (N *v a)
Lemma mmulv_assoc : forall {m n r} (M : mat m n) (N : mat n r) (a : vec r),
(M * N) *v a = M *v (N *v a).
Proof. intros. apply mmulv_assoc. Qed.
(M * N) *v a = M *v (N *v a).
Proof. intros. apply mmulv_assoc. Qed.
M *v (a + b) = M *v a + M *v b
Lemma mmulv_vadd : forall {r c} (M : mat r c) (a b : vec c),
M *v (a + b)%V = (M *v a + M *v b)%V.
Proof. intros. apply mmulv_vadd. Qed.
M *v (a + b)%V = (M *v a + M *v b)%V.
Proof. intros. apply mmulv_vadd. Qed.
(M + N) *v a = M *v a + N *v a
Lemma mmulv_madd : forall {r c} (M N : mat r c) (a : vec c),
(M + N) *v a = (M *v a + N *v a)%V.
Proof. intros. apply mmulv_madd. Qed.
(M + N) *v a = (M *v a + N *v a)%V.
Proof. intros. apply mmulv_madd. Qed.
(- M) *v a = - (M *v a)
Lemma mmulv_mopp : forall {r c} (M : mat r c) (a : vec c),
(- M) *v a = (- (M *v a))%V.
Proof. intros. apply mmulv_mopp. Qed.
(- M) *v a = (- (M *v a))%V.
Proof. intros. apply mmulv_mopp. Qed.
M *v (- a) = - (M *v a)
Lemma mmulv_vopp : forall {r c} (M : mat r c) (a : vec c),
M *v (- a)%V = (- (M *v a))%V.
Proof. intros. apply mmulv_vopp. Qed.
M *v (- a)%V = (- (M *v a))%V.
Proof. intros. apply mmulv_vopp. Qed.
M *v (a - b) = M *v a - M *v b
Lemma mmulv_vsub : forall {r c} (M : mat r c) (a b : vec c),
M *v (a - b)%V = (M *v a - M *v b)%V.
Proof. intros. apply mmulv_vsub. Qed.
M *v (a - b)%V = (M *v a - M *v b)%V.
Proof. intros. apply mmulv_vsub. Qed.
(M - N) *v a = M *v a - N *v a
Lemma mmulv_msub : forall {r c} (M N : mat r c) (a : vec c),
(M - N) *v a = (M *v a - N *v a)%V.
Proof. intros. apply mmulv_msub. Qed.
(M - N) *v a = (M *v a - N *v a)%V.
Proof. intros. apply mmulv_msub. Qed.
0 *v a = 0
Lemma mmulv_0_l : forall {r c} (a : vec c), (@mat0 r c) *v a = vzero.
Proof. intros. apply mmulv_0_l. Qed.
Proof. intros. apply mmulv_0_l. Qed.
M *v 0 = 0
Lemma mmulv_0_r : forall {r c} (M : mat r c), M *v vzero = vzero.
Proof. intros. apply mmulv_0_r. Qed.
Proof. intros. apply mmulv_0_r. Qed.
1 *v a = a
(x .* M) *v a = x .* (M *v a)
Lemma mmulv_mcmul : forall {r c} (x : A) (M : mat r c) (a : vec c),
(x \.* M) *v a = (x \.* (M *v a))%V.
Proof. intros. apply mmulv_mcmul. Qed.
(x \.* M) *v a = (x \.* (M *v a))%V.
Proof. intros. apply mmulv_mcmul. Qed.
M *v (x .* a) = x .* (M *v a)
Lemma mmulv_vcmul : forall {r c} (x : A) (M : mat r c) (a : vec c),
M *v (x \.* a)%V = (x \.* (M *v a))%V.
Proof. intros. apply mmulv_vcmul. Qed.
M *v (x \.* a)%V = (x \.* (M *v a))%V.
Proof. intros. apply mmulv_vcmul. Qed.
<a, b> = (a\T *v b).1
Lemma vdot_eq_mmulv : forall {n} (a b : vec n), <a, b> = (v2rv a *v b).1.
Proof. intros. apply vdot_eq_mmulv. Qed.
Proof. intros. apply vdot_eq_mmulv. Qed.
v2cv (M *v a) = M * v2cv a
Lemma v2cv_mmulv : forall {r c} (M : mat r c) (a : vec c),
v2cv (M *v a) = (M * v2cv a).
Proof. intros. apply v2cv_mmulv. Qed.
v2cv (M *v a) = (M * v2cv a).
Proof. intros. apply v2cv_mmulv. Qed.
v2rv (M *v a) = (v2rv a) * M\T
Lemma v2rv_mmulv : forall {r c} (M : mat r c) (a : vec c),
v2rv (M *v a) = (v2rv a * M\T).
Proof. intros. apply v2rv_mmulv. Qed.
v2rv (M *v a) = (v2rv a * M\T).
Proof. intros. apply v2rv_mmulv. Qed.
Definition mvmul {r c : nat} (a : vec r) (M : mat r c) : vec c :=
@mvmul _ Aadd 0 Amul _ _ a M.
Infix "v*" := mvmul : mat_scope.
(M v* a)i = <row M i, a>
Lemma vnth_mvmul : forall {r c} (a : vec r) (M : mat r c) i,
(a v* M).[i] = <a, M&[i]>.
Proof. intros. apply vnth_mvmul. Qed.
(a v* M).[i] = <a, M&[i]>.
Proof. intros. apply vnth_mvmul. Qed.
a v* (M * N) = (a v* M) v* N
Lemma mvmul_assoc : forall {r c s} (a : vec r) (M : mat r c) (N : mat c s),
a v* (M * N) = (a v* M) v* N.
Proof. intros. apply mvmul_assoc. Qed.
a v* (M * N) = (a v* M) v* N.
Proof. intros. apply mvmul_assoc. Qed.
(a + b) v* M = a v* M + b v* M
Lemma mvmul_vadd : forall {r c} (a b : vec r) (M : mat r c),
(a + b)%V v* M = (a v* M + b v* M)%V.
Proof. intros. apply mvmul_vadd. Qed.
(a + b)%V v* M = (a v* M + b v* M)%V.
Proof. intros. apply mvmul_vadd. Qed.
a v* (M + N) = a v* M + N v* a
Lemma mvmul_madd : forall {r c} (a : vec r) (M N : mat r c),
a v* (M + N) = (a v* M + a v* N)%V.
Proof. intros. apply mvmul_madd. Qed.
a v* (M + N) = (a v* M + a v* N)%V.
Proof. intros. apply mvmul_madd. Qed.
a v* (- M) = - (a v* M)
Lemma mvmul_mopp : forall {r c} (a : vec r) (M : mat r c),
a v* (- M) = (- (a v* M))%V.
Proof. intros. apply mvmul_mopp. Qed.
a v* (- M) = (- (a v* M))%V.
Proof. intros. apply mvmul_mopp. Qed.
(- a) v* M = - (a v* M)
Lemma mvmul_vopp : forall {r c} (a : vec r) (M : mat r c),
(- a)%V v* M = (- (a v* M))%V.
Proof. intros. apply mvmul_vopp. Qed.
(- a)%V v* M = (- (a v* M))%V.
Proof. intros. apply mvmul_vopp. Qed.
(a - b) v* M = a v* M - b v* M
Lemma mvmul_vsub : forall {r c} (a b : vec r) (M : mat r c),
(a - b)%V v* M = (a v* M - b v* M)%V.
Proof. intros. apply mvmul_vsub. Qed.
(a - b)%V v* M = (a v* M - b v* M)%V.
Proof. intros. apply mvmul_vsub. Qed.
a v* (M - N) = a v* M - a v* N
Lemma mvmul_msub : forall {r c} (a : vec r) (M N : mat r c),
a v* (M - N) = (a v* M - a v* N)%V.
Proof. intros. apply mvmul_msub. Qed.
a v* (M - N) = (a v* M - a v* N)%V.
Proof. intros. apply mvmul_msub. Qed.
0 v* M = 0
Lemma mvmul_0_l : forall {r c} (M : mat r c), vzero v* M = vzero.
Proof. intros. apply mvmul_0_l. Qed.
Proof. intros. apply mvmul_0_l. Qed.
a v* 0 = 0
Lemma mvmul_0_r : forall {r c} (a : vec r), a v* (@mat0 r c) = vzero.
Proof. intros. apply mvmul_0_r. Qed.
Proof. intros. apply mvmul_0_r. Qed.
a v* mat1 = a
a v* (x .* M) = x .* (a v* M)
Lemma mvmul_mcmul : forall {r c} (a : vec r) (x : A) (M : mat r c),
a v* (x \.* M) = (x \.* (a v* M))%V.
Proof. intros. apply mvmul_mcmul. Qed.
a v* (x \.* M) = (x \.* (a v* M))%V.
Proof. intros. apply mvmul_mcmul. Qed.
(x .* a) v* M = x .* (a v* M)
Lemma mvmul_vcmul : forall {r c} (a : vec r) (x : A) (M : mat r c),
(x \.* a)%V v* M = (x \.* (a v* M))%V.
Proof. intros. apply mvmul_vcmul. Qed.
(x \.* a)%V v* M = (x \.* (a v* M))%V.
Proof. intros. apply mvmul_vcmul. Qed.
<a, b> = (a v* v2cv b).1
Lemma vdot_eq_mvmul : forall {n} (a b : vec n), <a, b> = (a v* v2cv b).1.
Proof. intros. apply vdot_eq_mvmul. Qed.
Proof. intros. apply vdot_eq_mvmul. Qed.
v2cv (a v* M) = v2rv a * M
Lemma v2cv_mvmul : forall {r c} (a : vec r) (M : mat r c),
v2cv (a v* M) = M\T * v2cv a.
Proof. intros. apply v2cv_mvmul. Qed.
v2cv (a v* M) = M\T * v2cv a.
Proof. intros. apply v2cv_mvmul. Qed.
v2rv (a v* M) = (v2rv a) * M
Lemma v2rv_mvmul : forall {r c} (a : vec r) (M : mat r c),
v2rv (a v* M) = v2rv a * M.
Proof. intros. apply v2rv_mvmul. Qed.
v2rv (a v* M) = v2rv a * M.
Proof. intros. apply v2rv_mvmul. Qed.
Lemma mmul_mconsrT_mconscT_eq_mconscT :
forall {r c s} (M1 : mat r c) (v1 : vec c) (M2 : mat c s) (v2 : vec c),
mconsrT M1 v1 * mconscT M2 v2 =
mconscT (mconsrT (M1 * M2) (v1 v* M2)) (vconsT (M1 *v v2) (<v1,v2>)).
Proof. intros. apply mmul_mconsrT_mconscT_eq_mconscT. Qed.
Lemma mmul_mconsrT_mconscT_eq_mconsrT :
forall {r c s} (M1 : mat r c) (v1 : vec c) (M2 : mat c s) (v2 : vec c),
mconsrT M1 v1 * mconscT M2 v2 =
mconsrT (mconscT (M1 * M2) (M1 *v v2)) (vconsT (v1 v* M2) (<v1,v2>)).
Proof. intros. apply mmul_mconsrT_mconscT_eq_mconsrT. Qed.
forall {r c s} (M1 : mat r c) (v1 : vec c) (M2 : mat c s) (v2 : vec c),
mconsrT M1 v1 * mconscT M2 v2 =
mconscT (mconsrT (M1 * M2) (v1 v* M2)) (vconsT (M1 *v v2) (<v1,v2>)).
Proof. intros. apply mmul_mconsrT_mconscT_eq_mconscT. Qed.
Lemma mmul_mconsrT_mconscT_eq_mconsrT :
forall {r c s} (M1 : mat r c) (v1 : vec c) (M2 : mat c s) (v2 : vec c),
mconsrT M1 v1 * mconscT M2 v2 =
mconsrT (mconscT (M1 * M2) (M1 *v v2)) (vconsT (v1 v* M2) (<v1,v2>)).
Proof. intros. apply mmul_mconsrT_mconscT_eq_mconsrT. Qed.
Make suere skewP is equal to Matrix.skewP
Lemma skewP_eq : forall {n} (M : smat n), skewP M = @Matrix.skewP _ Aopp _ M.
Proof. intros. auto. Qed.
Proof. intros. auto. Qed.
Hardmard product
Definition mdet {n} (M : smat n) : A := @mdet _ Aadd 0 Aopp Amul 1 _ M.
Notation "| M |" := (mdet M) : mat_scope.
Notation "| M |" := (mdet M) : mat_scope.
|M \T| = |M|
|M * N| = |M| * |N|
Lemma mdet_mmul : forall {n} (M N : smat n), |M * N| = (|M| * |N|)%A.
Proof. intros. apply mdet_mmul. Qed.
Proof. intros. apply mdet_mmul. Qed.
|mat1| = 1
Determinant by cofactor expansion along the 0-th row
mdetEx is equal to mdet
Lemma mdetEx_eq_mdet : forall {n} (M : smat n), mdetEx M = mdet M.
Proof. intros. apply mdetEx_eq_mdet. Qed.
Proof. intros. apply mdetEx_eq_mdet. Qed.
Definition mdet1 (M : smat 1) := mdet1 M.
Definition mdet2 (M : smat 2) := @mdet2 _ Aadd Aopp Amul M.
Definition mdet3 (M : smat 3) := @mdet3 _ Aadd Aopp Amul M.
Definition mdet2 (M : smat 2) := @mdet2 _ Aadd Aopp Amul M.
Definition mdet3 (M : smat 3) := @mdet3 _ Aadd Aopp Amul M.
mdet1 M = |M|
|M| <> 0 <-> mdet_exp <> 0
Lemma mdet1_neq0_iff : forall (M : smat 1), |M| <> 0 <-> M.11 <> 0.
Proof. intros. apply mdet1_neq0_iff. Qed.
Proof. intros. apply mdet1_neq0_iff. Qed.
mdet2 M = |M|
|M| <> 0 <-> mdet_exp <> 0
Lemma mdet2_neq0_iff : forall (M : smat 2),
|M| <> 0 <-> (M.11*M.22 - M.12*M.21)%A <> 0.
Proof. intros. apply mdet2_neq0_iff. Qed.
|M| <> 0 <-> (M.11*M.22 - M.12*M.21)%A <> 0.
Proof. intros. apply mdet2_neq0_iff. Qed.
mdet3 M = |M|
|M| <> 0 <-> mdet_exp <> 0
Lemma mdet3_neq0_iff : forall (M : smat 3),
|M| <> 0 <->
(M.11 * M.22 * M.33 - M.11 * M.23 * M.32 -
M.12 * M.21 * M.33 + M.12 * M.23 * M.31 +
M.13 * M.21 * M.32 - M.13 * M.22 * M.31)%A <> 0.
Proof. intros. apply mdet3_neq0_iff. Qed.
|M| <> 0 <->
(M.11 * M.22 * M.33 - M.11 * M.23 * M.32 -
M.12 * M.21 * M.33 + M.12 * M.23 * M.31 +
M.13 * M.21 * M.32 - M.13 * M.22 * M.31)%A <> 0.
Proof. intros. apply mdet3_neq0_iff. Qed.
Adjoint matrix (Adjugate matrix, adj(A), A* )
Definition madj {n} (M : smat n) : smat n :=
@madj _ Aadd 0 Aopp Amul 1 _ M.
Notation "M \A" := (madj M) : mat_scope.
@madj _ Aadd 0 Aopp Amul 1 _ M.
Notation "M \A" := (madj M) : mat_scope.
The matrix `M` has a left inverse under matrix multiplication
The matrix `M` has a right inverse under matrix multiplication
The matrix `M` is singular (degenerate, not invertible)
matrix `M` is invertible, imply `M` is left invertible
Lemma minvtble_imply_minvtbleL : forall {n} (M : smat n),
minvtble M -> minvtbleL M.
Proof. intros. apply minvtble_imply_minvtbleL; auto. Qed.
minvtble M -> minvtbleL M.
Proof. intros. apply minvtble_imply_minvtbleL; auto. Qed.
matrix `M` is invertible, imply `M` is right invertible
Lemma minvtble_imply_minvtbleR : forall {n} (M : smat n),
minvtble M -> minvtbleR M.
Proof. intros. apply minvtble_imply_minvtbleR; auto. Qed.
End RingMatrixTheory.
minvtble M -> minvtbleR M.
Proof. intros. apply minvtble_imply_minvtbleR; auto. Qed.
End RingMatrixTheory.
Module OrderedRingMatrixTheory (E : OrderedRingElementType).
Include (RingMatrixTheory E).
Open Scope vec_scope.
Include (RingMatrixTheory E).
Open Scope vec_scope.
0 <= <a, a>
<a, b>² <= <a, b> * <a, a>
Lemma vdot_sqr_le : forall {n} (a b : vec n), (<a, b>²) <= (<a, a> * <b, b>)%A.
Proof. intros. apply vdot_sqr_le. Qed.
Proof. intros. apply vdot_sqr_le. Qed.
(a i)² <= <a, a>
Lemma vnth_sqr_le_vdot : forall {n} (a : vec n) (i : 'I_n), (a i) ² <= <a, a>.
Proof. intros. apply vnth_sqr_le_vdot. Qed.
Proof. intros. apply vnth_sqr_le_vdot. Qed.
(∀ i, 0 <= a.i) -> a.i <= ∑a
Lemma vsum_ge_any : forall {n} (a : vec n) i, (forall i, 0 <= a.[i]) -> a.[i] <= vsum a.
Proof. intros. apply vsum_ge_any; auto. Qed.
Proof. intros. apply vsum_ge_any; auto. Qed.
(∀ i, 0 <= a.i) -> 0 <= ∑a
Lemma vsum_ge0 : forall {n} (a : vec n), (forall i, 0 <= a.[i]) -> 0 <= vsum a.
Proof. intros. apply vsum_ge0; auto. Qed.
Proof. intros. apply vsum_ge0; auto. Qed.
(∀ i, 0 <= a.i) -> (∃ i, a.i <> 0) -> 0 < ∑a
Lemma vsum_gt0 : forall {n} (a : vec n),
(forall i, 0 <= a.[i]) -> (exists i, a.[i] <> 0) -> 0 < vsum a.
Proof. intros. apply vsum_gt0; auto. Qed.
End OrderedRingMatrixTheory.
(forall i, 0 <= a.[i]) -> (exists i, a.[i] <> 0) -> 0 < vsum a.
Proof. intros. apply vsum_gt0; auto. Qed.
End OrderedRingMatrixTheory.
Module FieldMatrixTheory (E : FieldElementType).
Include (RingMatrixTheory E).
Module AM := MinvAM E.
Module GE := MinvGE E.
Module Import OrthAM := MatrixOrth E.
Open Scope vec_scope.
Lemma veye_neq0 : forall {n} i, @veye n i <> vzero.
Proof. intros. apply veye_neq0. apply field_1_neq_0. Qed.
Proof. intros. apply veye_neq0. apply field_1_neq_0. Qed.
Lemma vcmul_eq0_imply_x0_or_v0 : forall {n} x (a : vec n),
x \.* a = vzero -> (x = 0) \/ (a = vzero).
Proof. intros. apply vcmul_eq0_imply_x0_or_v0; auto. Qed.
x \.* a = vzero -> (x = 0) \/ (a = vzero).
Proof. intros. apply vcmul_eq0_imply_x0_or_v0; auto. Qed.
x .* a = 0 -> a <> 0 -> x = 0
Lemma vcmul_eq0_imply_x0 : forall {n} (x : A) (a : vec n),
x \.* a = vzero -> a <> vzero -> x = 0.
Proof. intros. apply (vcmul_eq0_imply_x0 x a); auto. Qed.
x \.* a = vzero -> a <> vzero -> x = 0.
Proof. intros. apply (vcmul_eq0_imply_x0 x a); auto. Qed.
x .* a = 0 -> x <> 0 -> a = 0
Lemma vcmul_eq0_imply_v0 : forall {n} (x : A) (a : vec n),
x \.* a = vzero -> x <> 0 -> a = vzero.
Proof. intros. apply (vcmul_eq0_imply_v0 x a); auto. Qed.
x \.* a = vzero -> x <> 0 -> a = vzero.
Proof. intros. apply (vcmul_eq0_imply_v0 x a); auto. Qed.
x .* a = a -> x = 1 \/ a = 0
Lemma vcmul_same_imply_x1_or_v0 : forall {n} (x : A) (a : vec n),
x \.* a = a -> (x = 1 \/ a = vzero).
Proof. intros. apply vcmul_same_imply_x1_or_v0; auto. Qed.
x \.* a = a -> (x = 1 \/ a = vzero).
Proof. intros. apply vcmul_same_imply_x1_or_v0; auto. Qed.
x = 1 \/ a = 0 -> x .* a = a
Lemma vcmul_same_if_x1_or_v0 : forall {n} (x : A) (a : vec n),
(x = 1 \/ a = vzero) -> x \.* a = a.
Proof. intros. apply vcmul_same_if_x1_or_v0; auto. Qed.
(x = 1 \/ a = vzero) -> x \.* a = a.
Proof. intros. apply vcmul_same_if_x1_or_v0; auto. Qed.
x .* a = a -> a <> 0 -> x = 1
Lemma vcmul_same_imply_x1 : forall {n} (x : A) (a : vec n),
x \.* a = a -> a <> vzero -> x = 1.
Proof. intros. apply (vcmul_same_imply_x1 x a); auto. Qed.
x \.* a = a -> a <> vzero -> x = 1.
Proof. intros. apply (vcmul_same_imply_x1 x a); auto. Qed.
x .* a = a -> x <> 1 -> a = 0
Lemma vcmul_same_imply_v0 : forall {n} (x : A) (a : vec n),
x \.* a = a -> x <> 1 -> a = vzero.
Proof. intros. apply (vcmul_same_imply_v0 x a); auto. Qed.
x \.* a = a -> x <> 1 -> a = vzero.
Proof. intros. apply (vcmul_same_imply_v0 x a); auto. Qed.
x .* a = y .* a -> (x = y \/ a = 0)
Lemma vcmul_sameV_imply_eqX_or_v0 : forall {n} (x y : A) (a : vec n),
x \.* a = y \.* a -> (x = y \/ a = vzero).
Proof. intros. apply vcmul_sameV_imply_eqX_or_v0; auto. Qed.
x \.* a = y \.* a -> (x = y \/ a = vzero).
Proof. intros. apply vcmul_sameV_imply_eqX_or_v0; auto. Qed.
x .* a = y .* a -> a <> 0 -> x = y
Lemma vcmul_sameV_imply_eqX : forall {n} (x y : A) (a : vec n),
x \.* a = y \.* a -> a <> vzero -> x = y.
Proof. intros. apply vcmul_sameV_imply_eqX in H; auto. Qed.
x \.* a = y \.* a -> a <> vzero -> x = y.
Proof. intros. apply vcmul_sameV_imply_eqX in H; auto. Qed.
x .* a = y .* a -> x <> y -> a = 0
Lemma vcmul_sameV_imply_v0 : forall {n} (x y : A) (a : vec n),
x \.* a = y \.* a -> x <> y -> a = vzero.
Proof. intros. apply vcmul_sameV_imply_v0 in H; auto. Qed.
x \.* a = y \.* a -> x <> y -> a = vzero.
Proof. intros. apply vcmul_sameV_imply_v0 in H; auto. Qed.
(x .* a) _| b <-> a _| b
Lemma vorth_vcmul_l : forall {n} x (a b : vec n),
x <> 0 -> ((x \.* a) _|_ b <-> a _|_ b).
Proof. intros. apply vorth_vcmul_l; auto. Qed.
x <> 0 -> ((x \.* a) _|_ b <-> a _|_ b).
Proof. intros. apply vorth_vcmul_l; auto. Qed.
a _| (x .* b) <-> a _| b
Lemma vorth_vcmul_r : forall {n} x (a b : vec n),
x <> 0 -> (a _|_ (x \.* b) <-> a _|_ b).
Proof. intros. apply vorth_vcmul_r; auto. Qed.
x <> 0 -> (a _|_ (x \.* b) <-> a _|_ b).
Proof. intros. apply vorth_vcmul_r; auto. Qed.
a _| b -> vproj a b = vzero
Lemma vorth_imply_vproj_eq0 : forall {n} (a b : vec n), a _|_ b -> vproj a b = vzero.
Proof. intros. apply vorth_imply_vproj_eq0; auto. Qed.
Proof. intros. apply vorth_imply_vproj_eq0; auto. Qed.
vunit b -> vproj a b = <a, b> \.* b
Lemma vproj_vunit : forall {n} (a b : vec n), vunit b -> vproj a b = <a, b> \.* b.
Proof. intros. apply vproj_vunit; auto. Qed.
Proof. intros. apply vproj_vunit; auto. Qed.
Perpendicular component of a vector respect to another
vperp a b = a - vproj a b
Lemma vperp_eq_minus_vproj : forall {n} (a b : vec n), vperp a b = a - vproj a b.
Proof. intros; apply vperp_eq_minus_vproj. Qed.
Proof. intros; apply vperp_eq_minus_vproj. Qed.
vproj a b = a - vperp a b
Lemma vproj_eq_minus_vperp : forall {n} (a b : vec n), vproj a b = a - vperp a b.
Proof. intros; apply vproj_eq_minus_vperp. Qed.
Proof. intros; apply vproj_eq_minus_vperp. Qed.
(vproj a b) + (vperp a b) = a
Lemma vproj_plus_vperp : forall {n} (a b : vec n), vproj a b + vperp a b = a.
Proof. intros; apply vproj_plus_vperp. Qed.
Proof. intros; apply vproj_plus_vperp. Qed.
a _| b -> vperp a b = a
Lemma vorth_imply_vperp_eq_l : forall {n} (a b : vec n), a _|_ b -> vperp a b = a.
Proof. intros. apply vorth_imply_vperp_eq_l; auto. Qed.
Proof. intros. apply vorth_imply_vperp_eq_l; auto. Qed.
Lemma vunit_neq0 : forall {n} (a : vec n), vunit a -> a <> vzero.
Proof. intros. apply vunit_neq0; auto. Qed.
Open Scope mat_scope.
Proof. intros. apply vunit_neq0; auto. Qed.
Open Scope mat_scope.
Lemma mcmul_eq0_imply_x0_or_m0 : forall {r c} (M : mat r c) x,
x \.* M = mat0 -> x = 0 \/ (M = mat0).
Proof. intros. apply mcmul_eq0_imply_x0_or_m0; auto. Qed.
x \.* M = mat0 -> x = 0 \/ (M = mat0).
Proof. intros. apply mcmul_eq0_imply_x0_or_m0; auto. Qed.
(M <> 0 /\ x .* M = 0) -> M = 0
Lemma mcmul_mnonzero_eq0_imply_x0 : forall {r c} (M : mat r c) x,
M <> mat0 -> x \.* M = mat0 -> x = 0.
Proof. intros. apply mcmul_mnonzero_eq0_imply_x0 with (M:=M); auto. Qed.
M <> mat0 -> x \.* M = mat0 -> x = 0.
Proof. intros. apply mcmul_mnonzero_eq0_imply_x0 with (M:=M); auto. Qed.
x .* M = M -> x = 1 \/ M = 0
Lemma mcmul_same_imply_x1_or_m0 : forall {r c} x (M : mat r c),
x \.* M = M -> x = 1 \/ (M = mat0).
Proof. intros. apply mcmul_same_imply_x1_or_m0; auto. Qed.
x \.* M = M -> x = 1 \/ (M = mat0).
Proof. intros. apply mcmul_same_imply_x1_or_m0; auto. Qed.
Lemma mmul_eq1_imply_mdet_neq0_l : forall {n} (M N : smat n),
M * N = mat1 -> |M| <> 0.
Proof. intros. apply mmul_eq1_imply_mdet_neq0_l in H; auto. Qed.
M * N = mat1 -> |M| <> 0.
Proof. intros. apply mmul_eq1_imply_mdet_neq0_l in H; auto. Qed.
M * N = mat1 -> |N| <> 0
Lemma mmul_eq1_imply_mdet_neq0_r : forall {n} (M N : smat n),
M * N = mat1 -> |N| <> 0.
Proof. intros. apply mmul_eq1_imply_mdet_neq0_r in H; auto. Qed.
M * N = mat1 -> |N| <> 0.
Proof. intros. apply mmul_eq1_imply_mdet_neq0_r in H; auto. Qed.
Cramer rule
Definition cramerRule {n} (C : smat n) (b : vec n) : vec n :=
@cramerRule _ Aadd 0 Aopp Amul 1 Ainv n C b.
@cramerRule _ Aadd 0 Aopp Amul 1 Ainv n C b.
C *v (cramerRule C b) = b
Lemma cramerRule_spec : forall {n} (C : smat n) (b : vec n),
|C| <> 0 -> C *v (cramerRule C b) = b.
Proof. intros. apply cramerRule_spec; auto. Qed.
|C| <> 0 -> C *v (cramerRule C b) = b.
Proof. intros. apply cramerRule_spec; auto. Qed.
Cramer rule over list
Definition cramerRuleList (n : nat) (lC : dlist A) (lb : list A) : list A :=
@cramerRuleList _ Aadd 0 Aopp Amul 1 Ainv n lC lb.
@cramerRuleList _ Aadd 0 Aopp Amul 1 Ainv n lC lb.
{cramerRuleList lC lb} = cramerRule {lC} {lb}
Lemma cramerRuleList_spec : forall n (lC : dlist A) (lb : list A),
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (cramerRuleList n lC lb) = cramerRule C b.
Proof. intros. apply cramerRuleList_spec. Qed.
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (cramerRuleList n lC lb) = cramerRule C b.
Proof. intros. apply cramerRuleList_spec. Qed.
Lemma minvtbleL_iff_mdet_neq0 : forall {n} (M : smat n), minvtbleL M <-> |M| <> 0.
Proof. intros. apply minvtbleL_iff_mdet_neq0. Qed.
Proof. intros. apply minvtbleL_iff_mdet_neq0. Qed.
matrix `M` is right invertible, if and only if the determinant is not zero
Lemma minvtbleR_iff_mdet_neq0 : forall {n} (M : smat n), minvtbleR M <-> |M| <> 0.
Proof. intros. apply minvtbleR_iff_mdet_neq0. Qed.
Proof. intros. apply minvtbleR_iff_mdet_neq0. Qed.
A matrix `M` is invertible, if and only if the determinant is not zero
Lemma minvtble_iff_mdet_neq0 : forall {n} (M : smat n), minvtble M <-> |M| <> 0.
Proof. intros. apply minvtble_iff_mdet_neq0. Qed.
Proof. intros. apply minvtble_iff_mdet_neq0. Qed.
matrix `M` is left invertible, imply `M` is invertible
Lemma minvtbleL_imply_minvtble : forall {n} (M : smat n),
minvtbleL M -> minvtble M.
Proof. intros. apply minvtbleL_imply_minvtble; auto. Qed.
minvtbleL M -> minvtble M.
Proof. intros. apply minvtbleL_imply_minvtble; auto. Qed.
matrix `M` is right invertible, imply `M` is invertible
Lemma minvtbleR_imply_minvtble : forall {n} (M : smat n),
minvtbleR M -> minvtble M.
Proof. intros. apply minvtbleR_imply_minvtble; auto. Qed.
minvtbleR M -> minvtble M.
Proof. intros. apply minvtbleR_imply_minvtble; auto. Qed.
matrix `M` is invertible, if and only if `M` is left invertible
Lemma minvtble_iff_minvtbleL : forall {n} (M : smat n),
minvtble M <-> minvtbleL M.
Proof. intros. apply minvtble_iff_minvtbleL. Qed.
minvtble M <-> minvtbleL M.
Proof. intros. apply minvtble_iff_minvtbleL. Qed.
matrix `M` is invertible, if and only if `M` is right invertible
Lemma minvtble_iff_minvtbleR : forall {n} (M : smat n),
minvtble M <-> minvtbleR M.
Proof. intros. apply minvtble_iff_minvtbleR. Qed.
minvtble M <-> minvtbleR M.
Proof. intros. apply minvtble_iff_minvtbleR. Qed.
matrix `M` is left invertible, if and only if `M` is right invertible
Lemma minvtbleL_iff_minvtbleR : forall {n} (M : smat n),
minvtbleL M <-> minvtbleR M.
Proof. intros. apply minvtbleL_iff_minvtbleR. Qed.
minvtbleL M <-> minvtbleR M.
Proof. intros. apply minvtbleL_iff_minvtbleR. Qed.
`M * N = mat1` imply `M` is invertible
Lemma mmul_eq1_imply_minvtble_l : forall {n} (M N : smat n),
M * N = mat1 -> minvtble M.
Proof. intros. apply mmul_eq1_imply_minvtble_l in H; auto. Qed.
M * N = mat1 -> minvtble M.
Proof. intros. apply mmul_eq1_imply_minvtble_l in H; auto. Qed.
`M * N = mat1` imply `N` is invertible
Lemma mmul_eq1_imply_minvtble_r : forall {n} (M N : smat n),
M * N = mat1 -> minvtble N.
Proof. intros. apply mmul_eq1_imply_minvtble_r in H; auto. Qed.
M * N = mat1 -> minvtble N.
Proof. intros. apply mmul_eq1_imply_minvtble_r in H; auto. Qed.
Transpose preserve `invertible` property
Lemma mtrans_minvtble : forall n (M : smat n),
minvtble M -> minvtble (M\T).
Proof. intros. apply mtrans_minvtble; auto. Qed.
minvtble M -> minvtble (M\T).
Proof. intros. apply mtrans_minvtble; auto. Qed.
Multiplication preserve `invertible` property
Lemma mmul_minvtble: forall {n} (M N : smat n),
minvtble M -> minvtble N -> minvtble (M * N).
Proof. intros. apply mmul_minvtble; auto. Qed.
minvtble M -> minvtble N -> minvtble (M * N).
Proof. intros. apply mmul_minvtble; auto. Qed.
mat1 is invertible
Lemma mat1_minvtble : forall {n}, minvtble (@mat1 n).
Proof. intros. apply mat1_minvtble; auto. Qed.
Proof. intros. apply mat1_minvtble; auto. Qed.
Left cancellation law of matrix multiplication
Lemma mmul_cancel_l : forall {r c} (M : smat r) (N1 N2 : mat r c) ,
minvtble M -> M * N1 = M * N2 -> N1 = N2.
Proof. intros. apply mmul_cancel_l in H0; auto. Qed.
minvtble M -> M * N1 = M * N2 -> N1 = N2.
Proof. intros. apply mmul_cancel_l in H0; auto. Qed.
Right cancellation law of matrix multiplication
Lemma mmul_cancel_r : forall {r c} (M : smat c) (N1 N2 : mat r c) ,
minvtble M -> N1 * M = N2 * M -> N1 = N2.
Proof. intros. apply mmul_cancel_r in H0; auto. Qed.
minvtble M -> N1 * M = N2 * M -> N1 = N2.
Proof. intros. apply mmul_cancel_r in H0; auto. Qed.
Cancellation law of matrix multiply vector
Lemma mmulv_cancel : forall {n} (M : smat n) (a b : vec n),
minvtble M -> M *v a = M *v b -> a = b.
Proof. intros. apply mmulv_cancel in H0; auto. Qed.
minvtble M -> M *v a = M *v b -> a = b.
Proof. intros. apply mmulv_cancel in H0; auto. Qed.
Cancellation law of vector multipliy matrix
Lemma mvmul_cancel : forall {n} (M : smat n) (a b : vec n),
minvtble M -> a v* M = b v* M -> a = b.
Proof. intros. apply mvmul_cancel in H0; auto. Qed.
minvtble M -> a v* M = b v* M -> a = b.
Proof. intros. apply mvmul_cancel in H0; auto. Qed.
N1 * M = mat1 -> N2 * M = mat1 -> N1 = N2
Lemma mmul_eq1_uniq_l : forall {n} (M N1 N2 : smat n),
N1 * M = mat1 -> N2 * M = mat1 -> N1 = N2.
Proof. intros. apply mmul_eq1_uniq_l with (M:=M); auto. Qed.
N1 * M = mat1 -> N2 * M = mat1 -> N1 = N2.
Proof. intros. apply mmul_eq1_uniq_l with (M:=M); auto. Qed.
M * N1 = mat1 -> M * N2 = mat1 -> N1 = N2
Lemma mmul_eq1_uniq_r : forall {n} (M N1 N2 : smat n),
M * N1 = mat1 -> M * N2 = mat1 -> N1 = N2.
Proof. intros. apply mmul_eq1_uniq_r with (M:=M); auto. Qed.
M * N1 = mat1 -> M * N2 = mat1 -> N1 = N2.
Proof. intros. apply mmul_eq1_uniq_r with (M:=M); auto. Qed.
M * N = mat1 -> M = /|N| .* N\A
Lemma mmul_eq1_imply_det_cmul_adj_l : forall {n} (M N : smat n),
M * N = mat1 -> M = /|N| \.* N\A.
Proof. intros. apply mmul_eq1_imply_det_cmul_adj_l; auto. Qed.
M * N = mat1 -> M = /|N| \.* N\A.
Proof. intros. apply mmul_eq1_imply_det_cmul_adj_l; auto. Qed.
M * N = mat1 -> N = /|M| .* M\A
Lemma mmul_eq1_imply_det_cmul_adj_r : forall {n} (M N : smat n),
M * N = mat1 -> N = /|M| \.* M\A.
Proof. intros. apply mmul_eq1_imply_det_cmul_adj_r; auto. Qed.
M * N = mat1 -> N = /|M| \.* M\A.
Proof. intros. apply mmul_eq1_imply_det_cmul_adj_r; auto. Qed.
M1 * M2 = mat1 -> M2 * M1 = mat1
Lemma mmul_eq1_comm : forall {n} (M1 M2 : smat n),
M1 * M2 = mat1 -> M2 * M1 = mat1.
Proof. intros. apply mmul_eq1_comm; auto. Qed.
M1 * M2 = mat1 -> M2 * M1 = mat1.
Proof. intros. apply mmul_eq1_comm; auto. Qed.
行变换列表转换为矩阵
rowOps2mat (l1 ++ l2) = rowOps2mat l1 * rowOps2mat l2
Lemma rowOps2mat_app : forall {n} (l1 l2 : list (@RowOp A n)),
rowOps2mat (l1 ++ l2) = rowOps2mat l1 * rowOps2mat l2.
Proof. intros. apply rowOps2mat_app. Qed.
rowOps2mat (l1 ++ l2) = rowOps2mat l1 * rowOps2mat l2.
Proof. intros. apply rowOps2mat_app. Qed.
行变换列表转换为反作用的矩阵。即,rowOps2mat的逆矩阵
rowOps2matInv (l1 ++ l2) = rowOps2matInv l2 * rowOps2matInv l1
Lemma rowOps2matInv_app : forall {n} (l1 l2 : list (@RowOp A n)),
rowOps2matInv (l1 ++ l2) = rowOps2matInv l2 * rowOps2matInv l1.
Proof. intros. apply rowOps2matInv_app. Qed.
rowOps2matInv (l1 ++ l2) = rowOps2matInv l2 * rowOps2matInv l1.
Proof. intros. apply rowOps2matInv_app. Qed.
rowOps2matInv l * rowOps2mat l = mat1
Lemma mmul_rowOps2matInv_rowOps2mat_eq1 : forall {n} (l : list (@RowOp A n)),
Forall (@roValid _ 0 _) l -> rowOps2matInv l * rowOps2mat l = mat1.
Proof. intros. apply mmul_rowOps2matInv_rowOps2mat_eq1; auto. Qed.
Forall (@roValid _ 0 _) l -> rowOps2matInv l * rowOps2mat l = mat1.
Proof. intros. apply mmul_rowOps2matInv_rowOps2mat_eq1; auto. Qed.
rowOps2mat l * rowOps2matInv l = mat1
Lemma mmul_rowOps2mat_rowOps2matInv_eq1 : forall {n} (l : list (@RowOp A n)),
Forall (@roValid _ 0 _) l -> rowOps2mat l * rowOps2matInv l = mat1.
Proof. intros. apply mmul_rowOps2mat_rowOps2matInv_eq1; auto. Qed.
Forall (@roValid _ 0 _) l -> rowOps2mat l * rowOps2matInv l = mat1.
Proof. intros. apply mmul_rowOps2mat_rowOps2matInv_eq1; auto. Qed.
Check the invertibility of matrix `M`
minvtble M <-> minvtblebGE M = true
Lemma minvtble_iff_minvtblebGE_true : forall {n} (M : smat n),
minvtble M <-> minvtblebGE M = true.
Proof. intros. apply minvtble_iff_minvtbleb_true. Qed.
minvtble M <-> minvtblebGE M = true.
Proof. intros. apply minvtble_iff_minvtbleb_true. Qed.
msingular M <-> minvtblebGE M = false
Lemma msingular_iff_minvtblebGE_false : forall {n} (M : smat n),
msingular M <-> minvtblebGE M = false.
Proof. intros. apply msingular_iff_minvtbleb_false. Qed.
msingular M <-> minvtblebGE M = false.
Proof. intros. apply msingular_iff_minvtbleb_false. Qed.
Inverse matrix (option version)
`minvoGE` return `Some`, iff M is invertible
Lemma minvoGE_Some_iff_minvtble : forall {n} (M : smat n),
(exists M', minvoGE M = Some M') <-> minvtble M.
Proof. intros. apply minvo_Some_iff_minvtble. Qed.
(exists M', minvoGE M = Some M') <-> minvtble M.
Proof. intros. apply minvo_Some_iff_minvtble. Qed.
`minvoGE` return `None`, iff M is singular
Lemma minvoGE_None_iff_msingular : forall {n} (M : smat n),
minvoGE M = None <-> msingular M.
Proof. intros. apply minvo_None_iff_msingular. Qed.
minvoGE M = None <-> msingular M.
Proof. intros. apply minvo_None_iff_msingular. Qed.
If `minvoGE M` return `Some M'`, then `M' * M = mat1`
Lemma minvoGE_Some_imply_eq1_l : forall {n} (M M' : smat n),
minvoGE M = Some M' -> M' * M = mat1.
Proof. intros. apply minvo_Some_imply_eq1_l; auto. Qed.
minvoGE M = Some M' -> M' * M = mat1.
Proof. intros. apply minvo_Some_imply_eq1_l; auto. Qed.
If `minvoGE M` return `Some M'`, then `M * M' = mat1`
Lemma minvoGE_Some_imply_eq1_r : forall {n} (M M' : smat n),
minvoGE M = Some M' -> M * M' = mat1.
Proof. intros. apply minvo_Some_imply_eq1_r; auto. Qed.
minvoGE M = Some M' -> M * M' = mat1.
Proof. intros. apply minvo_Some_imply_eq1_r; auto. Qed.
Inverse matrix (with identity matrix as default value)
Definition minvGE {n} (M : smat n) : smat n := minv M.
Module MinvGENotations.
Notation "M \-1" := (minvGE M) : mat_scope.
End MinvGENotations.
Module MinvGENotations.
Notation "M \-1" := (minvGE M) : mat_scope.
End MinvGENotations.
If `minvoGE M` return `Some N`, then `M\-1` equal to `N`
Lemma minvoGE_Some_imply_minvGE : forall {n} (M N : smat n),
minvoGE M = Some N -> M\-1 = N.
Proof. intros. apply minvo_Some_imply_minv; auto. Qed.
minvoGE M = Some N -> M\-1 = N.
Proof. intros. apply minvo_Some_imply_minv; auto. Qed.
If `minvoGE M` return `None`, then `M\-1` equal to `mat1`
Lemma minvoGE_None_imply_minv : forall {n} (M : smat n),
minvoGE M = None -> M\-1 = mat1.
Proof. intros. apply minvo_None_imply_minv; auto. Qed.
minvoGE M = None -> M\-1 = mat1.
Proof. intros. apply minvo_None_imply_minv; auto. Qed.
M\-1 * M = mat1
Lemma mmul_minvGE_l : forall {n} (M : smat n), minvtble M -> M\-1 * M = mat1.
Proof. intros. apply mmul_minv_l; auto. Qed.
Proof. intros. apply mmul_minv_l; auto. Qed.
M * N = mat1 -> minvtblebGE M = true
Lemma mmul_eq1_imply_minvtblebGE_true_l : forall {n} (M N : smat n),
M * N = mat1 -> minvtblebGE M = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_l in H; auto. Qed.
M * N = mat1 -> minvtblebGE M = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_l in H; auto. Qed.
M * N = mat1 -> minvtblebGE N = true.
Lemma mmul_eq1_imply_minvtblebGE_true_r : forall {n} (M N : smat n),
M * N = mat1 -> minvtblebGE N = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_r in H; auto. Qed.
M * N = mat1 -> minvtblebGE N = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_r in H; auto. Qed.
minvtble M -> minvtble (M \-1)
Lemma minvGE_minvtble : forall {n} (M : smat n),
minvtble M -> minvtble (M\-1).
Proof. intros. apply minv_minvtble; auto. Qed.
minvtble M -> minvtble (M\-1).
Proof. intros. apply minv_minvtble; auto. Qed.
M * M\-1 = mat1
Lemma mmul_minvGE_r : forall {n} (M : smat n), minvtble M -> M * M\-1 = mat1.
Proof. intros. apply mmul_minv_r; auto. Qed.
Proof. intros. apply mmul_minv_r; auto. Qed.
M * N = mat1 -> M \-1 = N
Lemma mmul_eq1_imply_minvGE_l : forall {n} (M N : smat n), M * N = mat1 -> M\-1 = N.
Proof. intros. apply mmul_eq1_imply_minv_l; auto. Qed.
Proof. intros. apply mmul_eq1_imply_minv_l; auto. Qed.
M * N = mat1 -> N \-1 = M
Lemma mmul_eq1_imply_minvGE_r : forall {n} (M N : smat n), M * N = mat1 -> N\-1 = M.
Proof. intros. apply mmul_eq1_imply_minv_r; auto. Qed.
Proof. intros. apply mmul_eq1_imply_minv_r; auto. Qed.
mat1 \-1 = mat1
minvtble M -> M \-1 \-1 = M
Lemma minvGE_minvGE : forall n (M : smat n), minvtble M -> M \-1 \-1 = M.
Proof. intros. apply minv_minv; auto. Qed.
Proof. intros. apply minv_minv; auto. Qed.
(M * N)\-1 = (N\-1) * (M\-1)
Lemma minvGE_mmul : forall n (M N : smat n),
minvtble M -> minvtble N -> (M * N)\-1 = N\-1 * M\-1.
Proof. intros. apply minv_mmul; auto. Qed.
minvtble M -> minvtble N -> (M * N)\-1 = N\-1 * M\-1.
Proof. intros. apply minv_mmul; auto. Qed.
(M \T) \-1 = (M \-1) \T
Lemma minvGE_mtrans : forall n (M : smat n),
minvtble M -> (M \T) \-1 = (M \-1) \T.
Proof. intros. apply minv_mtrans; auto. Qed.
minvtble M -> (M \T) \-1 = (M \-1) \T.
Proof. intros. apply minv_mtrans; auto. Qed.
|M \-1| = / |M|
Lemma mdet_minvGE : forall {n} (M : smat n), minvtble M -> |M\-1| = / |M|.
Proof. intros. apply mdet_minv; auto. Qed.
Proof. intros. apply mdet_minv; auto. Qed.
Check matrix invertibility with lists as input
Inverse matrix with lists for input and output
`minvtblebListGE` is equal to `minvtblebGE`, by definition
Lemma minvtblebListGE_spec : forall (n : nat) (dl : dlist A),
minvtblebListGE n dl = @minvtblebGE n (l2m dl).
Proof. intros. apply minvtblebList_spec. Qed.
minvtblebListGE n dl = @minvtblebGE n (l2m dl).
Proof. intros. apply minvtblebList_spec. Qed.
Lemma minvListGE_spec : forall (n : nat) (dl : dlist A),
let M : smat n := l2m dl in
let M' : smat n := l2m (minvListGE n dl) in
minvtblebListGE n dl = true ->
M' * M = mat1.
Proof. intros. apply minvList_spec; auto. Qed.
let M : smat n := l2m dl in
let M' : smat n := l2m (minvListGE n dl) in
minvtblebListGE n dl = true ->
M' * M = mat1.
Proof. intros. apply minvList_spec; auto. Qed.
Solve the equation with the form of C*x=b.
C *v (solveEqGE C b) = b
Lemma solveEqGE_spec : forall {n} (C : smat n) (b : vec n),
minvtble C -> C *v (solveEqGE C b) = b.
Proof. intros. apply solveEq_spec; auto. Qed.
minvtble C -> C *v (solveEqGE C b) = b.
Proof. intros. apply solveEq_spec; auto. Qed.
Solve the equation with the form of C*x=b over list
{solveEqListGE lC lb} = solveEq {lC} {lb}
Lemma solveEqListGE_spec : forall n (lC : dlist A) (lb : list A),
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (solveEqList n lC lb) = solveEqGE C b.
Proof. intros. apply solveEqList_spec. Qed.
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (solveEqList n lC lb) = solveEqGE C b.
Proof. intros. apply solveEqList_spec. Qed.
Check the invertibility of matrix `M`
minvtble M <-> minvtblebAM M = true
Lemma minvtble_iff_minvtblebAM_true : forall {n} (M : smat n),
minvtble M <-> minvtblebAM M = true.
Proof. intros. apply minvtble_iff_minvtbleb_true. Qed.
minvtble M <-> minvtblebAM M = true.
Proof. intros. apply minvtble_iff_minvtbleb_true. Qed.
msingular M <-> minvtblebAM M = false
Lemma msingular_iff_minvtblebAM_false : forall {n} (M : smat n),
msingular M <-> minvtblebAM M = false.
Proof. intros. apply msingular_iff_minvtbleb_false. Qed.
msingular M <-> minvtblebAM M = false.
Proof. intros. apply msingular_iff_minvtbleb_false. Qed.
Inverse matrix (option version)
`minvoAM` return `Some`, iff M is invertible
Lemma minvoAM_Some_iff_minvtble : forall {n} (M : smat n),
(exists M', minvoAM M = Some M') <-> minvtble M.
Proof. intros. apply minvo_Some_iff_minvtble. Qed.
(exists M', minvoAM M = Some M') <-> minvtble M.
Proof. intros. apply minvo_Some_iff_minvtble. Qed.
`minvoAM` return `None`, iff M is singular
Lemma minvoAM_None_iff_msingular : forall {n} (M : smat n),
minvoAM M = None <-> msingular M.
Proof. intros. apply minvo_None_iff_msingular. Qed.
minvoAM M = None <-> msingular M.
Proof. intros. apply minvo_None_iff_msingular. Qed.
If `minvoAM M` return `Some M'`, then `M' * M = mat1`
Lemma minvoAM_Some_imply_eq1_l : forall {n} (M M' : smat n),
minvoAM M = Some M' -> M' * M = mat1.
Proof. intros. apply minvo_Some_imply_eq1_l; auto. Qed.
minvoAM M = Some M' -> M' * M = mat1.
Proof. intros. apply minvo_Some_imply_eq1_l; auto. Qed.
If `minvoAM M` return `Some M'`, then `M * M' = mat1`
Lemma minvoAM_Some_imply_eq1_r : forall {n} (M M' : smat n),
minvoAM M = Some M' -> M * M' = mat1.
Proof. intros. apply minvo_Some_imply_eq1_r; auto. Qed.
minvoAM M = Some M' -> M * M' = mat1.
Proof. intros. apply minvo_Some_imply_eq1_r; auto. Qed.
Inverse matrix (with identity matrix as default value)
Definition minvAM {n} (M : smat n) : smat n := minv M.
Module Export MinvAMNotations.
Notation "M \-1" := (minvAM M) : mat_scope.
End MinvAMNotations.
Module Export MinvAMNotations.
Notation "M \-1" := (minvAM M) : mat_scope.
End MinvAMNotations.
If `minvoAM M` return `Some N`, then `M\-1` equal to `N`
Lemma minvoAM_Some_imply_minvAM : forall {n} (M N : smat n),
minvoAM M = Some N -> M\-1 = N.
Proof. intros. apply minvo_Some_imply_minv; auto. Qed.
minvoAM M = Some N -> M\-1 = N.
Proof. intros. apply minvo_Some_imply_minv; auto. Qed.
If `minvoAM M` return `None`, then `M\-1` equal to `mat1`
Lemma minvoAM_None_imply_minv : forall {n} (M : smat n),
minvoAM M = None -> M\-1 = mat1.
Proof. intros. apply minvo_None_imply_minv; auto. Qed.
minvoAM M = None -> M\-1 = mat1.
Proof. intros. apply minvo_None_imply_minv; auto. Qed.
M\-1 * M = mat1
Lemma mmul_minvAM_l : forall {n} (M : smat n), minvtble M -> M\-1 * M = mat1.
Proof. intros. apply mmul_minv_l; auto. Qed.
Proof. intros. apply mmul_minv_l; auto. Qed.
Formula of inversion matrix on dimension-1
minvtble M -> minvAM1 M = M\-1
Lemma minvAM1_eq_minvAM : forall M, minvtble M -> minvAM1 M = M\-1.
Proof. intros. apply minv1_eq_minv; auto. Qed.
Proof. intros. apply minv1_eq_minv; auto. Qed.
Formula of inversion matrix on dimension-2
minvtble M -> minv2 M = M\-1
Lemma minvAM2_eq_minvAM : forall M, minvtble M -> minvAM2 M = M\-1.
Proof. intros. apply minv2_eq_minv; auto. Qed.
Proof. intros. apply minv2_eq_minv; auto. Qed.
Formula of inversion matrix on dimension-3
minvtble M -> minv3 M = M\-1
Lemma minvAM3_eq_minvAM : forall M, minvtble M -> minvAM3 M = M\-1.
Proof. intros. apply minv3_eq_minv; auto. Qed.
Proof. intros. apply minv3_eq_minv; auto. Qed.
Formula of inversion matrix on dimension-4
minvtble M -> minv4 M = M\-1
Lemma minvAM4_eq_minvAM : forall M, minvtble M -> minvAM4 M = M\-1.
Proof. intros. apply minv4_eq_minv; auto. Qed.
Proof. intros. apply minv4_eq_minv; auto. Qed.
M * N = mat1 -> minvtblebAM M = true
Lemma mmul_eq1_imply_minvtblebAM_true_l : forall {n} (M N : smat n),
M * N = mat1 -> minvtblebAM M = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_l in H; auto. Qed.
M * N = mat1 -> minvtblebAM M = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_l in H; auto. Qed.
M * N = mat1 -> minvtblebAM N = true.
Lemma mmul_eq1_imply_minvtblebAM_true_r : forall {n} (M N : smat n),
M * N = mat1 -> minvtblebAM N = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_r in H; auto. Qed.
M * N = mat1 -> minvtblebAM N = true.
Proof. intros. apply mmul_eq1_imply_minvtbleb_true_r in H; auto. Qed.
minvtble M -> minvtble (M \-1)
Lemma minvAM_minvtble : forall {n} (M : smat n),
minvtble M -> minvtble (M\-1).
Proof. intros. apply minv_minvtble; auto. Qed.
minvtble M -> minvtble (M\-1).
Proof. intros. apply minv_minvtble; auto. Qed.
M * M\-1 = mat1
Lemma mmul_minvAM_r : forall {n} (M : smat n), minvtble M -> M * M\-1 = mat1.
Proof. intros. apply mmul_minv_r; auto. Qed.
Proof. intros. apply mmul_minv_r; auto. Qed.
M * N = mat1 -> M \-1 = N
Lemma mmul_eq1_imply_minvAM_l : forall {n} (M N : smat n), M * N = mat1 -> M\-1 = N.
Proof. intros. apply mmul_eq1_imply_minv_l; auto. Qed.
Proof. intros. apply mmul_eq1_imply_minv_l; auto. Qed.
M * N = mat1 -> N \-1 = M
Lemma mmul_eq1_imply_minvAM_r : forall {n} (M N : smat n), M * N = mat1 -> N\-1 = M.
Proof. intros. apply mmul_eq1_imply_minv_r; auto. Qed.
Proof. intros. apply mmul_eq1_imply_minv_r; auto. Qed.
mat1 \-1 = mat1
minvtble M -> M \-1 \-1 = M
Lemma minvAM_minvAM : forall n (M : smat n), minvtble M -> M \-1 \-1 = M.
Proof. intros. apply minv_minv; auto. Qed.
Proof. intros. apply minv_minv; auto. Qed.
(M * N)\-1 = (N\-1) * (M\-1)
Lemma minvAM_mmul : forall n (M N : smat n),
minvtble M -> minvtble N -> (M * N)\-1 = N\-1 * M\-1.
Proof. intros. apply minv_mmul; auto. Qed.
minvtble M -> minvtble N -> (M * N)\-1 = N\-1 * M\-1.
Proof. intros. apply minv_mmul; auto. Qed.
(M \T) \-1 = (M \-1) \T
Lemma minvAM_mtrans : forall n (M : smat n),
minvtble M -> (M \T) \-1 = (M \-1) \T.
Proof. intros. apply minv_mtrans; auto. Qed.
minvtble M -> (M \T) \-1 = (M \-1) \T.
Proof. intros. apply minv_mtrans; auto. Qed.
|M \-1| = / |M|
Lemma mdet_minvAM : forall {n} (M : smat n), minvtble M -> |M\-1| = / |M|.
Proof. intros. apply mdet_minv; auto. Qed.
Proof. intros. apply mdet_minv; auto. Qed.
Check matrix invertibility with lists as input
Inverse matrix with lists for input and output
`minvtblebListAM` is equal to `minvtblebAM`, by definition
Lemma minvtblebListAM_spec : forall (n : nat) (dl : dlist A),
minvtblebListAM n dl = @minvtblebAM n (l2m dl).
Proof. intros. apply minvtblebList_spec. Qed.
minvtblebListAM n dl = @minvtblebAM n (l2m dl).
Proof. intros. apply minvtblebList_spec. Qed.
Lemma minvListAM_spec : forall (n : nat) (dl : dlist A),
let M : smat n := l2m dl in
let M' : smat n := l2m (minvListAM n dl) in
minvtblebListAM n dl = true ->
M' * M = mat1.
Proof. intros. apply minvList_spec; auto. Qed.
let M : smat n := l2m dl in
let M' : smat n := l2m (minvListAM n dl) in
minvtblebListAM n dl = true ->
M' * M = mat1.
Proof. intros. apply minvList_spec; auto. Qed.
Solve the equation with the form of C*x=b.
C *v (solveEqAM C b) = b
Lemma solveEqAM_spec : forall {n} (C : smat n) (b : vec n),
minvtble C -> C *v (solveEqAM C b) = b.
Proof. intros. apply solveEq_spec; auto. Qed.
minvtble C -> C *v (solveEqAM C b) = b.
Proof. intros. apply solveEq_spec; auto. Qed.
Solve the equation with the form of C*x=b over list
{solveEqListAM lC lb} = solveEq {lC} {lb}
Lemma solveEqListAM_spec : forall n (lC : dlist A) (lb : list A),
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (solveEqList n lC lb) = solveEqAM C b.
Proof. intros. apply solveEqList_spec. Qed.
let C : smat n := l2m lC in
let b : vec n := l2v lb in
l2v (solveEqList n lC lb) = solveEqAM C b.
Proof. intros. apply solveEqList_spec. Qed.
Inverse matrix (won't check the inversibility)
If `M` is invertible, then minvNoCheckAM is equivalent to minvAM
Lemma minvNoCheckAM_spec : forall {n} (M : smat n),
minvtble M -> minvNoCheckAM M = M\-1.
Proof. intros. apply minvNoCheck_spec; auto. Qed.
minvtble M -> minvNoCheckAM M = M\-1.
Proof. intros. apply minvNoCheck_spec; auto. Qed.
Solve the equation with the form of C*x=b, but without check the inversibility.
minvtble C -> solveEqNoCheckAM C b = solveEqAM C b
Theorem solveEqNoCheckAM_spec : forall {n} (C : smat n) (b : vec n),
minvtble C -> solveEqNoCheckAM C b = solveEqAM C b.
Proof. intros. apply solveEqNoCheck_spec; auto. Qed.
minvtble C -> solveEqNoCheckAM C b = solveEqAM C b.
Proof. intros. apply solveEqNoCheck_spec; auto. Qed.
Solve the equation with the form of C*x=b over list, but without check the
inversibility
Definition solveEqListNoCheckAM (n : nat) (lC : dlist A) (lb : list A) : list A :=
solveEqListNoCheck n lC lb.
solveEqListNoCheck n lC lb.
minvtble {lC} -> {solveEqListNoCheckAM lC lb} = solveEqListAM {lC} {lb}
Theorem solveEqListNoCheckAM_spec : forall n (lC : dlist A) (lb : list A),
let C : smat n := l2m lC in
minvtble C -> solveEqListNoCheckAM n lC lb = solveEqListAM n lC lb.
Proof. intros. apply solveEqListNoCheck_spec; auto. Qed.
let C : smat n := l2m lC in
minvtble C -> solveEqListNoCheckAM n lC lb = solveEqListAM n lC lb.
Proof. intros. apply solveEqListNoCheck_spec; auto. Qed.
Import AM.
Import MinvAMNotations.
Notation minvtbleb := minvtblebAM.
Notation minvtble_iff_minvtbleb_true := minvtble_iff_minvtblebAM_true.
Notation msingular_iff_minvtbleb_false := msingular_iff_minvtblebAM_false.
Notation minvo := minvoAM.
Notation minvo_Some_iff_minvtble := minvoAM_Some_iff_minvtble.
Notation minvo_None_iff_msingular := minvoAM_None_iff_msingular.
Notation minvo_Some_imply_eq1_l := minvoAM_Some_imply_eq1_l.
Notation minvo_Some_imply_eq1_r := minvoAM_Some_imply_eq1_r.
Notation minv := minvAM.
Notation minvo_Some_imply_minv := minvoAM_Some_imply_minvAM.
Notation minvo_None_imply_minv := minvoAM_None_imply_minv.
Notation mmul_minv_l := mmul_minvAM_l.
Notation mmul_minv_r := mmul_minvAM_r.
Notation minv_minvtble := minvAM_minvtble.
Notation mmul_eq1_imply_minv_l := mmul_eq1_imply_minvAM_l.
Notation mmul_eq1_imply_minv_r := mmul_eq1_imply_minvAM_r.
Notation minv_mat1 := minvAM_mat1.
Notation minv_minv := minvAM_minvAM.
Notation minv_mmul := minvAM_mmul.
Notation minv_mtrans := minvAM_mtrans.
Notation mdet_minv := mdet_minvAM.
Notation minvtblebList := minvtblebListAM.
Notation minvtblebList_spec := minvtblebListAM_spec.
Notation minvList := minvListAM.
Notation minvList_spec := minvListAM_spec.
Notation solveEq := solveEqGE.
Notation solveEq_spec := solveEqGE_spec.
Notation minvNoCheck := minvNoCheckAM.
Notation minvNoCheck_spec := minvNoCheckAM_spec.
Notation solveEqNoCheck := solveEqNoCheckAM.
Notation solveEqNoCheck_spec := solveEqNoCheckAM_spec.
Notation solveEqListNoCheck := solveEqListNoCheckAM.
Notation solveEqListNoCheck_spec := solveEqListNoCheckAM_spec.
Import MinvAMNotations.
Notation minvtbleb := minvtblebAM.
Notation minvtble_iff_minvtbleb_true := minvtble_iff_minvtblebAM_true.
Notation msingular_iff_minvtbleb_false := msingular_iff_minvtblebAM_false.
Notation minvo := minvoAM.
Notation minvo_Some_iff_minvtble := minvoAM_Some_iff_minvtble.
Notation minvo_None_iff_msingular := minvoAM_None_iff_msingular.
Notation minvo_Some_imply_eq1_l := minvoAM_Some_imply_eq1_l.
Notation minvo_Some_imply_eq1_r := minvoAM_Some_imply_eq1_r.
Notation minv := minvAM.
Notation minvo_Some_imply_minv := minvoAM_Some_imply_minvAM.
Notation minvo_None_imply_minv := minvoAM_None_imply_minv.
Notation mmul_minv_l := mmul_minvAM_l.
Notation mmul_minv_r := mmul_minvAM_r.
Notation minv_minvtble := minvAM_minvtble.
Notation mmul_eq1_imply_minv_l := mmul_eq1_imply_minvAM_l.
Notation mmul_eq1_imply_minv_r := mmul_eq1_imply_minvAM_r.
Notation minv_mat1 := minvAM_mat1.
Notation minv_minv := minvAM_minvAM.
Notation minv_mmul := minvAM_mmul.
Notation minv_mtrans := minvAM_mtrans.
Notation mdet_minv := mdet_minvAM.
Notation minvtblebList := minvtblebListAM.
Notation minvtblebList_spec := minvtblebListAM_spec.
Notation minvList := minvListAM.
Notation minvList_spec := minvListAM_spec.
Notation solveEq := solveEqGE.
Notation solveEq_spec := solveEqGE_spec.
Notation minvNoCheck := minvNoCheckAM.
Notation minvNoCheck_spec := minvNoCheckAM_spec.
Notation solveEqNoCheck := solveEqNoCheckAM.
Notation solveEqNoCheck_spec := solveEqNoCheckAM_spec.
Notation solveEqListNoCheck := solveEqListNoCheckAM.
Notation solveEqListNoCheck_spec := solveEqListNoCheckAM_spec.
Orthonormal vectors 标准正交的向量组
All (different) rows of a matrix are orthogonal each other.
Definition mrowsOrth {r c} (M : mat r c) : Prop := mrowsOrth M.
Lemma mtrans_mcolsOrth : forall {r c} (M : mat r c), mrowsOrth M -> mcolsOrth (M\T).
Proof. intros. apply mtrans_mcolsOrth; auto. Qed.
Lemma mtrans_mrowsOrth : forall {r c} (M : mat r c), mcolsOrth M -> mrowsOrth (M\T).
Proof. intros. apply mtrans_mrowsOrth; auto. Qed.
Lemma mtrans_mcolsOrth : forall {r c} (M : mat r c), mrowsOrth M -> mcolsOrth (M\T).
Proof. intros. apply mtrans_mcolsOrth; auto. Qed.
Lemma mtrans_mrowsOrth : forall {r c} (M : mat r c), mcolsOrth M -> mrowsOrth (M\T).
Proof. intros. apply mtrans_mrowsOrth; auto. Qed.
All columns of a matrix are unit vector.
For example: v1;v2;v3 => unit v1 && unit v2 && unit v3
All rows of a matrix are unit vector.
Definition mrowsUnit {r c} (M : mat r c) : Prop := mrowsUnit M.
Lemma mtrans_mcolsUnit : forall {r c} (M : mat r c), mrowsUnit M -> mcolsUnit (M\T).
Proof. intros. apply mtrans_mcolsUnit; auto. Qed.
Lemma mtrans_mrowsUnit : forall {r c} (M : mat r c), mcolsUnit M -> mrowsUnit (M\T).
Proof. intros. apply mtrans_mrowsUnit; auto. Qed.
Lemma mtrans_mcolsUnit : forall {r c} (M : mat r c), mrowsUnit M -> mcolsUnit (M\T).
Proof. intros. apply mtrans_mcolsUnit; auto. Qed.
Lemma mtrans_mrowsUnit : forall {r c} (M : mat r c), mcolsUnit M -> mrowsUnit (M\T).
Proof. intros. apply mtrans_mrowsUnit; auto. Qed.
The columns of a matrix is orthogomal
The rows of a matrix is orthogomal
mrowsOrthonormal M -> mcolsOrthonormal (M\T)
Lemma mtrans_mcolsOrthonormal : forall {r c} (M : mat r c),
mrowsOrthonormal M -> mcolsOrthonormal (M\T).
Proof. intros. apply mtrans_mcolsOrthonormal; auto. Qed.
mrowsOrthonormal M -> mcolsOrthonormal (M\T).
Proof. intros. apply mtrans_mcolsOrthonormal; auto. Qed.
mcolsOrthonormal M -> mrowsOrthonormal (M\T)
Lemma mtrans_mrowsOrthonormal : forall {r c} (M : mat r c),
mcolsOrthonormal M -> mrowsOrthonormal (M\T).
Proof. intros. apply mtrans_mrowsOrthonormal; auto. Qed.
mcolsOrthonormal M -> mrowsOrthonormal (M\T).
Proof. intros. apply mtrans_mrowsOrthonormal; auto. Qed.
matrix M is orthogonal <-> columns of M are orthogomal
Lemma morth_iff_mcolsOrthonormal : forall {n} (M : smat n),
morth M <-> mcolsOrthonormal M.
Proof. intros. apply morth_iff_mcolsOrthonormal. Qed.
morth M <-> mcolsOrthonormal M.
Proof. intros. apply morth_iff_mcolsOrthonormal. Qed.
matrix M is orthogonal <-> rows of M are orthogomal
Lemma morth_iff_mrowsOrthonormal : forall {n} (M : smat n),
morth M <-> mrowsOrthonormal M.
Proof. intros. apply morth_iff_mrowsOrthonormal. Qed.
morth M <-> mrowsOrthonormal M.
Proof. intros. apply morth_iff_mrowsOrthonormal. Qed.
columns of M are orthonormal <-> rows of M are orthonormal
Lemma mcolsOrthonormal_iff_mrowsOrthonormal : forall {n} (M : smat n),
mcolsOrthonormal M <-> mrowsOrthonormal M.
Proof. intros. apply mcolsOrthonormal_iff_mrowsOrthonormal. Qed.
mcolsOrthonormal M <-> mrowsOrthonormal M.
Proof. intros. apply mcolsOrthonormal_iff_mrowsOrthonormal. Qed.
orthogonal M -> invertible M
Lemma morth_minvtble : forall {n} (M : smat n), morth M -> minvtble M.
Proof. intros. apply morth_minvtble; auto. Qed.
Proof. intros. apply morth_minvtble; auto. Qed.
orthogonal M -> M \-1 = M \T
Lemma morth_imply_minv_eq_trans : forall {n} (M : smat n), morth M -> M\-1 = M \T.
Proof. intros. apply morth_imply_minv_eq_trans in H; auto. Qed.
Proof. intros. apply morth_imply_minv_eq_trans in H; auto. Qed.
M \-1 = M \T -> orthogonal M
Lemma minv_eq_trans_imply_morth : forall {n} (M : smat n),
minvtble M -> M\-1 = M \T -> morth M.
Proof. intros. apply minv_eq_trans_imply_morth; auto. Qed.
minvtble M -> M\-1 = M \T -> morth M.
Proof. intros. apply minv_eq_trans_imply_morth; auto. Qed.
orthogonal M <-> M \T * M = mat1
Lemma morth_iff_mul_trans_l : forall {n} (M : smat n), morth M <-> M \T * M = mat1.
Proof. intros. apply morth_iff_mul_trans_l; auto. Qed.
Proof. intros. apply morth_iff_mul_trans_l; auto. Qed.
orthogonal M <-> M * M \T = mat1
Lemma morth_iff_mul_trans_r : forall {n} (M : smat n), morth M <-> M * M \T = mat1.
Proof. intros. apply morth_iff_mul_trans_r; auto. Qed.
Proof. intros. apply morth_iff_mul_trans_r; auto. Qed.
orthogonal mat1
orthogonal M -> orthogonal N -> orthogonal (M * N)
Lemma morth_mul : forall {n} (M N : smat n), morth M -> morth N -> morth (M * N).
Proof. intros. apply morth_mul; auto. Qed.
Proof. intros. apply morth_mul; auto. Qed.
orthogonal M -> orthogonal M \T
Lemma morth_mtrans : forall {n} (M : smat n), morth M -> morth (M \T).
Proof. intros. apply morth_mtrans; auto. Qed.
Proof. intros. apply morth_mtrans; auto. Qed.
orthogonal M -> orthogonal M \-1
Lemma morth_minv : forall {n} (M : smat n), morth M -> morth (M\-1).
Proof. intros. apply morth_minv; auto. Qed.
Proof. intros. apply morth_minv; auto. Qed.
orthogonal M -> |M| = ± 1
Lemma morth_mdet : forall {n} (M : smat n), morth M -> |M| = 1 \/ |M| = (- (1))%A.
Proof. intros. apply morth_mdet; auto. Qed.
Proof. intros. apply morth_mdet; auto. Qed.
Transformation by orthogonal matrix will keep inner-product
Lemma morth_keep_dot : forall {n} (M : smat n) (a b : vec n),
morth M -> <M *v a, M *v b> = <a, b>.
Proof. intros. apply morth_keep_dot; auto. Qed.
morth M -> <M *v a, M *v b> = <a, b>.
Proof. intros. apply morth_keep_dot; auto. Qed.
Additional coercion, hence the re-definition of `mat` and `GOn`
The condition to form a GOn from a matrix
Definition GOnP {n} (M : smat n) : Prop := GOnP M.
Lemma GOnP_spec : forall {n} (M : @GOn n), GOnP M.
Proof. intros. apply GOnP_spec. Qed.
Lemma GOnP_spec : forall {n} (M : @GOn n), GOnP M.
Proof. intros. apply GOnP_spec. Qed.
Create a GOn from a matrix satisfing `GOnP`
Multiplication of elements in GOn
Identity element in GOn
Inverse operation of multiplication in GOn
GOn_mul is associative
Lemma GOn_mul_assoc : forall n, Associative (@GOn_mul n).
Proof. intros. apply GOn_mul_assoc; auto. Qed.
Proof. intros. apply GOn_mul_assoc; auto. Qed.
GOn_1 is left-identity-element of GOn_mul operation
Lemma GOn_mul_id_l : forall n, IdentityLeft GOn_mul (@GOn_1 n).
Proof. intros. apply GOn_mul_id_l. Qed.
Proof. intros. apply GOn_mul_id_l. Qed.
GOn_1 is right-identity-element of GOn_mul operation
Lemma GOn_mul_id_r : forall n, IdentityRight GOn_mul (@GOn_1 n).
Proof. intros. apply GOn_mul_id_r. Qed.
Proof. intros. apply GOn_mul_id_r. Qed.
GOn_inv is left-inversion of <GOn_mul,GOn_1>
Lemma GOn_mul_inv_l : forall n, InverseLeft GOn_mul GOn_1 (@GOn_inv n).
Proof. intros. apply GOn_mul_inv_l. Qed.
Proof. intros. apply GOn_mul_inv_l. Qed.
GOn_inv is right-inversion of <GOn_mul,GOn_1>
Lemma GOn_mul_inv_r : forall n, InverseRight GOn_mul GOn_1 (@GOn_inv n).
Proof. intros. apply GOn_mul_inv_r. Qed.
Proof. intros. apply GOn_mul_inv_r. Qed.
<GOn, +, 1> is a monoid
<GOn, +, 1, /x> is a group
M \-1 = M \T
Lemma GOn_imply_inv_eq_trans : forall {n} (M : @GOn n), M\-1 = (GOn_mat M) \T.
Proof. intros. apply GOn_imply_minv_eq_trans. Qed.
Proof. intros. apply GOn_imply_minv_eq_trans. Qed.
Additional coercion, hence the re-definition of `mat` and `SOn`
The condition to form a SOn from a matrix
Definition SOnP {n} (M : smat n) : Prop := SOnP M.
Lemma SOnP_spec : forall {n} (M : @SOn n), SOnP M.
Proof. intros. apply SOnP_spec. Qed.
Lemma SOnP_spec : forall {n} (M : @SOn n), SOnP M.
Proof. intros. apply SOnP_spec. Qed.
The transpose also keep SOn
Lemma SOnP_mtrans : forall {n} (M : smat n), SOnP M -> SOnP (M\T).
Proof. intros. apply SOnP_mtrans; auto. Qed.
Proof. intros. apply SOnP_mtrans; auto. Qed.
Create a SOn from a matrix satisfing `SOnP`
Multiplication of elements in SOn
Identity element in SOn
SOn_mul is associative
SOn_1 is left-identity-element of SOn_mul operation
Lemma SOn_mul_id_l : forall n, IdentityLeft SOn_mul (@SOn_1 n).
Proof. intros. apply SOn_mul_id_l. Qed.
Proof. intros. apply SOn_mul_id_l. Qed.
SOn_1 is right-identity-element of SOn_mul operation
Lemma SOn_mul_id_r : forall n, IdentityRight SOn_mul (@SOn_1 n).
Proof. intros. apply SOn_mul_id_r. Qed.
Proof. intros. apply SOn_mul_id_r. Qed.
<SOn, +, 1> is a monoid
Inverse operation of multiplication in GOn
SOn_inv is left-inversion of <SOn_mul,SOn_1>
Lemma SOn_mul_inv_l : forall n, InverseLeft SOn_mul SOn_1 (@SOn_inv n).
Proof. intros. apply SOn_mul_inv_l. Qed.
Proof. intros. apply SOn_mul_inv_l. Qed.
SOn_inv is right-inversion of <SOn_mul,SOn_1>
Lemma SOn_mul_inv_r : forall n, InverseRight SOn_mul SOn_1 (@SOn_inv n).
Proof. intros. apply SOn_mul_inv_r. Qed.
Proof. intros. apply SOn_mul_inv_r. Qed.
<SOn, +, 1, /x> is a group
M \-1 = M \T
Lemma SOn_minv_eq_trans : forall {n} (M : @SOn n), M\-1 = (GOn_mat M) \T.
Proof. intros. apply SOn_minv_eq_trans. Qed.
Proof. intros. apply SOn_minv_eq_trans. Qed.
M\T * M = mat1
Lemma SOn_mul_trans_l_eq1 : forall {n} (M : @SOn n), (GOn_mat M)\T * M = mat1.
Proof. intros. apply SOn_mul_trans_l_eq1. Qed.
Proof. intros. apply SOn_mul_trans_l_eq1. Qed.
M * M\T = mat1
Lemma SOn_mul_trans_r_eq1 : forall {n} (M : @SOn n), M * (GOn_mat M)\T = mat1.
Proof. intros. apply SOn_mul_trans_r_eq1. Qed.
End FieldMatrixTheory.
Proof. intros. apply SOn_mul_trans_r_eq1. Qed.
End FieldMatrixTheory.
Module OrderedFieldMatrixTheory (E : OrderedFieldElementType).
Include (FieldMatrixTheory E).
Open Scope vec_scope.
Section THESE_CODE_ARE_COPIED_FROM_OrderedRingMatrixTheroy.
Include (FieldMatrixTheory E).
Open Scope vec_scope.
Section THESE_CODE_ARE_COPIED_FROM_OrderedRingMatrixTheroy.
0 <= <a, a>
<a, b>² <= <a, a> * <b, b>
Lemma vdot_sqr_le : forall {n} (a b : vec n), (<a, b>²) <= (<a, a> * <b, b>)%A.
Proof. intros. apply vdot_sqr_le. Qed.
Proof. intros. apply vdot_sqr_le. Qed.
(v i)² <= <a, a>
Lemma vnth_sqr_le_vdot : forall {n} (a : vec n) (i : 'I_n), (a i) ² <= <a, a>.
Proof. intros. apply vnth_sqr_le_vdot. Qed.
Proof. intros. apply vnth_sqr_le_vdot. Qed.
(∀ i, 0 <= a.i) -> a.i <= ∑a
Lemma vsum_ge_any : forall {n} (a : vec n) i, (forall i, 0 <= a.[i]) -> a.[i] <= vsum a.
Proof. intros. apply vsum_ge_any; auto. Qed.
Proof. intros. apply vsum_ge_any; auto. Qed.
(∀ i, 0 <= a.i) -> 0 <= ∑a
Lemma vsum_ge0 : forall {n} (a : vec n), (forall i, 0 <= a.[i]) -> 0 <= vsum a.
Proof. intros. apply vsum_ge0; auto. Qed.
Proof. intros. apply vsum_ge0; auto. Qed.
(∀ i, 0 <= a.i) -> (∃ i, a.i <> 0) -> 0 < ∑a
Lemma vsum_gt0 : forall {n} (a : vec n),
(forall i, 0 <= a.[i]) -> (exists i, a.[i] <> 0) -> 0 < vsum a.
Proof. intros. apply vsum_gt0; auto. Qed.
End THESE_CODE_ARE_COPIED_FROM_OrderedRingMatrixTheroy.
(forall i, 0 <= a.[i]) -> (exists i, a.[i] <> 0) -> 0 < vsum a.
Proof. intros. apply vsum_gt0; auto. Qed.
End THESE_CODE_ARE_COPIED_FROM_OrderedRingMatrixTheroy.
a = 0 -> <a, a> = 0
Lemma vdot_same_eq0_if_vzero : forall {n} (a : vec n), a = vzero -> <a, a> = 0.
Proof. intros. apply vdot_same_eq0_if_vzero; auto. Qed.
Proof. intros. apply vdot_same_eq0_if_vzero; auto. Qed.
<a, a> = 0 -> a = 0
Lemma vdot_same_eq0_then_vzero : forall {n} (a : vec n), <a, a> = 0 -> a = vzero.
Proof. intros. apply vdot_same_eq0_then_vzero; auto. Qed.
Proof. intros. apply vdot_same_eq0_then_vzero; auto. Qed.
a <> vzero -> <a, a> <> 0
Lemma vdot_same_neq0_if_vnonzero : forall {n} (a : vec n), a <> vzero -> <a, a> <> 0.
Proof. intros. apply vdot_same_neq0_if_vnonzero; auto. Qed.
Proof. intros. apply vdot_same_neq0_if_vnonzero; auto. Qed.
<a, a> <> 0 -> a <> vzero
Lemma vdot_same_neq0_then_vnonzero : forall {n} (a : vec n), <a, a> <> 0 -> a <> vzero.
Proof. intros. apply vdot_same_neq0_then_vnonzero; auto. Qed.
Proof. intros. apply vdot_same_neq0_then_vnonzero; auto. Qed.
0 < <a, a>
Lemma vdot_gt0 : forall {n} (a : vec n), a <> vzero -> 0 < (<a, a>).
Proof. intros. apply vdot_gt0; auto. Qed.
Proof. intros. apply vdot_gt0; auto. Qed.
<a, b>² / (<a, a> * <b, b>) <= 1.
Lemma vdot_sqr_le_form2 : forall {n} (a b : vec n),
a <> vzero -> b <> vzero -> <a, b>² / (<a, a> * <b, b>)%A <= 1.
Proof. intros. apply vdot_sqr_le_form2; auto. Qed.
a <> vzero -> b <> vzero -> <a, b>² / (<a, a> * <b, b>)%A <= 1.
Proof. intros. apply vdot_sqr_le_form2; auto. Qed.
vproj (a + b) c = vproj a c + vproj b c
Lemma vproj_vadd : forall {n} (a b c : vec n),
c <> vzero -> vproj (a + b) c = vproj a c + vproj b c.
Proof. intros. apply vproj_vadd; auto. Qed.
c <> vzero -> vproj (a + b) c = vproj a c + vproj b c.
Proof. intros. apply vproj_vadd; auto. Qed.
vproj (x .* a) b = x .* (vproj a b)
Lemma vproj_vcmul : forall {n} (a b : vec n) x,
b <> vzero -> vproj (x \.* a) b = x \.* (vproj a b).
Proof. intros. apply vproj_vcmul; auto. Qed.
b <> vzero -> vproj (x \.* a) b = x \.* (vproj a b).
Proof. intros. apply vproj_vcmul; auto. Qed.
vproj a a = a
Lemma vproj_same : forall {n} (a : vec n), a <> vzero -> vproj a a = a.
Proof. intros. apply vproj_same; auto. Qed.
Proof. intros. apply vproj_same; auto. Qed.
(vproj a b) _| (vperp a b)
Lemma vorth_vproj_vperp : forall {n} (a b : vec n),
b <> vzero -> vproj a b _|_ vperp a b.
Proof. intros. apply vorth_vproj_vperp; auto. Qed.
b <> vzero -> vproj a b _|_ vperp a b.
Proof. intros. apply vorth_vproj_vperp; auto. Qed.
vperp (a + b) c = vperp a c + vperp b c
Lemma vperp_vadd : forall {n} (a b c : vec n),
c <> vzero -> vperp (a + b) c = vperp a c + vperp b c.
Proof. intros. apply vperp_vadd; auto. Qed.
c <> vzero -> vperp (a + b) c = vperp a c + vperp b c.
Proof. intros. apply vperp_vadd; auto. Qed.
vperp (x .* a) b = x .* (vperp a b)
Lemma vperp_vcmul : forall {n} (x : A) (a b : vec n),
b <> vzero -> vperp (x \.* a) b = x \.* (vperp a b).
Proof. intros. apply vperp_vcmul; auto. Qed.
b <> vzero -> vperp (x \.* a) b = x \.* (vperp a b).
Proof. intros. apply vperp_vcmul; auto. Qed.
vperp a a = vzero
Lemma vperp_self : forall {n} (a : vec n), a <> vzero -> vperp a a = vzero.
Proof. intros. apply vperp_self; auto. Qed.
Proof. intros. apply vperp_self; auto. Qed.
Definition vcoll {n} (a b : vec n) : Prop := @vcoll _ 0 Amul _ a b.
Infix "//" := vcoll : vec_scope.
Infix "//" := vcoll : vec_scope.
a // a
Lemma vcoll_refl : forall {n} (a : vec n), a <> vzero -> a // a.
Proof. intros; apply vcoll_refl; auto. Qed.
Proof. intros; apply vcoll_refl; auto. Qed.
a // b -> a // u
Lemma vcoll_sym : forall {n} (a b : vec n), a // b -> b // a.
Proof. intros; apply vcoll_sym; auto. Qed.
Proof. intros; apply vcoll_sym; auto. Qed.
a // b -> b // c -> a // c
Lemma vcoll_trans : forall {n} (a b c: vec n), a // b -> b // c -> a // c.
Proof. intros; apply vcoll_trans with b; auto. Qed.
Proof. intros; apply vcoll_trans with b; auto. Qed.
a // b => ∃! x, x <> 0 /\ x .* a = b
Lemma vcoll_imply_uniqueX : forall {n} (a b : vec n),
a // b -> (exists ! x, x <> 0 /\ x \.* a = b).
Proof. intros; apply vcoll_imply_uniqueX; auto. Qed.
a // b -> (exists ! x, x <> 0 /\ x \.* a = b).
Proof. intros; apply vcoll_imply_uniqueX; auto. Qed.
a // b -> (x \.* a) // b
Lemma vcoll_vcmul_l : forall {n} x (a b : vec n), x <> 0 -> a // b -> x \.* a // b.
Proof. intros; apply vcoll_vcmul_l; auto. Qed.
Proof. intros; apply vcoll_vcmul_l; auto. Qed.
a // b -> a // (x \.* b)
Lemma vcoll_vcmul_r : forall {n} x (a b : vec n), x <> 0 -> a // b -> a // (x \.* b).
Proof. intros; apply vcoll_vcmul_r; auto. Qed.
Proof. intros; apply vcoll_vcmul_r; auto. Qed.
Two vectors are parallel (i.e., collinear with same direction)
Definition vpara {n} (a b : vec n) : Prop := @vpara _ 0 Amul Alt _ a b.
Infix "//+" := vpara : vec_scope.
Infix "//+" := vpara : vec_scope.
a //+ a
Lemma vpara_refl : forall {n} (a : vec n), a <> vzero -> a //+ a.
Proof. intros. apply vpara_refl; auto. Qed.
Proof. intros. apply vpara_refl; auto. Qed.
a //+ b -> b //+ a
Lemma vpara_sym : forall {n} (a b : vec n), a //+ b -> b //+ a.
Proof. intros. apply vpara_sym; auto. Qed.
Proof. intros. apply vpara_sym; auto. Qed.
a //+ b -> b //+ c -> a //+ c
Lemma vpara_trans : forall {n} (a b c: vec n), a //+ b -> b //+ c -> a //+ c.
Proof. intros. apply vpara_trans with b; auto. Qed.
Proof. intros. apply vpara_trans with b; auto. Qed.
a //+ b => ∃! x, 0 < x /\ x .* a = b
Lemma vpara_imply_uniqueX : forall {n} (a b : vec n),
a //+ b -> (exists ! x, 0 < x /\ x \.* a = b).
Proof. intros. apply vpara_imply_uniqueX; auto. Qed.
a //+ b -> (exists ! x, 0 < x /\ x \.* a = b).
Proof. intros. apply vpara_imply_uniqueX; auto. Qed.
a //+ b -> (x \.* u) //+ a
Lemma vpara_vcmul_l : forall {n} x (a b : vec n),
0 < x -> a //+ b -> x \.* a //+ b.
Proof. intros. apply vpara_vcmul_l; auto. Qed.
0 < x -> a //+ b -> x \.* a //+ b.
Proof. intros. apply vpara_vcmul_l; auto. Qed.
a //+ b -> a //+ (x .* b)
Lemma vpara_vcmul_r : forall {n} x (a b : vec n),
0 < x -> a //+ b -> a //+ (x \.* b).
Proof. intros. apply vpara_vcmul_r; auto. Qed.
0 < x -> a //+ b -> a //+ (x \.* b).
Proof. intros. apply vpara_vcmul_r; auto. Qed.
Two vectors are antiparallel (i.e., collinear with opposite direction)
Definition vantipara {n} (a b : vec n) : Prop := @vantipara _ 0 Amul Alt _ a b.
Infix "//-" := vantipara : vec_scope.
Infix "//-" := vantipara : vec_scope.
a //- b -> b //- a
Lemma vantipara_sym : forall {n} (a b : vec n), a //- b -> b //- a.
Proof. intros. apply vantipara_sym; auto. Qed.
Proof. intros. apply vantipara_sym; auto. Qed.
a //- b => ∃! x, x < 0 /\ x * a = b
Lemma vantipara_imply_uniqueX : forall {n} (a b : vec n),
a //- b -> (exists ! x, x < 0 /\ x \.* a = b).
Proof. intros. apply vantipara_imply_uniqueX; auto. Qed.
a //- b -> (exists ! x, x < 0 /\ x \.* a = b).
Proof. intros. apply vantipara_imply_uniqueX; auto. Qed.
a //- b -> (x .* a) //- b
Lemma vantipara_vcmul_l : forall {n} x (a b : vec n),
0 < x -> a //- b -> x \.* a //- b.
Proof. intros. apply vantipara_vcmul_l; auto. Qed.
0 < x -> a //- b -> x \.* a //- b.
Proof. intros. apply vantipara_vcmul_l; auto. Qed.
a //- b -> a //- (x .* b)
Lemma vantipara_vcmul_r : forall {n} x (a b : vec n),
0 < x -> a //- b -> a //- (x \.* b).
Proof. intros. apply vantipara_vcmul_r; auto. Qed.
0 < x -> a //- b -> a //- (x \.* b).
Proof. intros. apply vantipara_vcmul_r; auto. Qed.
Lemma vpara_imply_vcoll : forall {n} (a b : vec n), a //+ b -> a // b.
Proof. intros. apply vpara_imply_vcoll; auto. Qed.
Proof. intros. apply vpara_imply_vcoll; auto. Qed.
a //- b -> a // b
Lemma vantipara_imply_vcoll : forall {n} (a b : vec n), a //- b -> a // b.
Proof. intros. apply vantipara_imply_vcoll; auto. Qed.
Proof. intros. apply vantipara_imply_vcoll; auto. Qed.
a //+ b -> (-a) //- b
Lemma vpara_imply_vantipara_opp_l : forall {n} (a b : vec n), a //+ b -> (-a) //- b.
Proof. intros. apply vpara_imply_vantipara_opp_l; auto. Qed.
Proof. intros. apply vpara_imply_vantipara_opp_l; auto. Qed.
a //+ b -> a //- (-b)
Lemma vpara_imply_vantipara_opp_r : forall {n} (a b : vec n), a //+ b -> a //- (-b).
Proof. intros. apply vpara_imply_vantipara_opp_r; auto. Qed.
Proof. intros. apply vpara_imply_vantipara_opp_r; auto. Qed.
a // b -> (a //+ b) \/ (a //- b)
Lemma vcoll_imply_vpara_or_vantipara : forall {n} (a b : vec n),
a // b -> a //+ b \/ a //- b.
Proof. intros. apply vpara_imply_vpara_or_vantipara; auto. Qed.
End OrderedFieldMatrixTheory.
a // b -> a //+ b \/ a //- b.
Proof. intros. apply vpara_imply_vpara_or_vantipara; auto. Qed.
End OrderedFieldMatrixTheory.
Module NormedOrderedFieldMatrixTheory (E : NormedOrderedFieldElementType).
Include (OrderedFieldMatrixTheory E).
Import OrthAM.
Open Scope vec_scope.
Include (OrderedFieldMatrixTheory E).
Import OrthAM.
Open Scope vec_scope.
Length of a vector
Definition vlen {n} (a : vec n) : R := @vlen _ Aadd 0 Amul a2r _ a.
Notation "|| a ||" := (vlen a) : vec_scope.
Notation "|| a ||" := (vlen a) : vec_scope.
||vzero|| = 0
0 <= ||a||
||a|| = ||b|| <-> <a, a> = <b, b>
Lemma vlen_eq_iff_dot_eq : forall {n} (a b : vec n), ||a|| = ||b|| <-> <a, a> = <b, b>.
Proof. intros. apply vlen_eq_iff_dot_eq. Qed.
Proof. intros. apply vlen_eq_iff_dot_eq. Qed.
<a, a> = ||a||²
Lemma vdot_same : forall {n} (a : vec n), a2r (<a, a>) = (||a||²)%R.
Proof. intros. apply vdot_same. Qed.
Proof. intros. apply vdot_same. Qed.
|a i| <= ||a||
Lemma vnth_le_vlen : forall {n} (a : vec n) (i : 'I_n),
a <> vzero -> (a2r (|a i|%A) <= ||a||)%R.
Proof. intros. apply vnth_le_vlen; auto. Qed.
a <> vzero -> (a2r (|a i|%A) <= ||a||)%R.
Proof. intros. apply vnth_le_vlen; auto. Qed.
|| a || = 1 <-> <a, a> = 1
Lemma vlen_eq1_iff_vdot1 : forall {n} (a : vec n), ||a|| = 1%R <-> <a, a> = 1.
Proof. intros. apply vlen_eq1_iff_vdot1. Qed.
Proof. intros. apply vlen_eq1_iff_vdot1. Qed.
||- a|| = ||a||
||x .* a|| = |k| * ||a||
Lemma vlen_vcmul : forall n x (a : vec n), ||x \.* a|| = ((a2r (|x|))%A * ||a||)%R.
Proof. intros. apply vlen_vcmul. Qed.
Proof. intros. apply vlen_vcmul. Qed.
||a + b||² = ||a||² + ||b||² + 2 * <a, b>
Lemma vlen_sqr_vadd : forall {n} (a b : vec n),
(||(a + b)%V||² = ||a||² + ||b||² + 2 * a2r (<a,b>))%R.
Proof. intros. apply vlen_sqr_vadd. Qed.
(||(a + b)%V||² = ||a||² + ||b||² + 2 * a2r (<a,b>))%R.
Proof. intros. apply vlen_sqr_vadd. Qed.
||a - b||² = ||a||² + ||b||² - 2 * <a, b>
Lemma vlen_sqr_vsub : forall {n} (a b : vec n),
(||(a - b)%V||² = ||a||² + ||b||² - 2 * a2r (<a, b>))%R.
Proof. intros. apply vlen_sqr_vsub. Qed.
(||(a - b)%V||² = ||a||² + ||b||² - 2 * a2r (<a, b>))%R.
Proof. intros. apply vlen_sqr_vsub. Qed.
|<a, b>| <= ||a|| * ||b||
Lemma vdot_abs_le : forall {n} (a b : vec n), (|a2r (<a, b>)| <= ||a|| * ||b||)%R.
Proof. intros. apply vdot_abs_le. Qed.
Proof. intros. apply vdot_abs_le. Qed.
<a, b> <= ||a|| * ||b||
Lemma vdot_le_mul_vlen : forall {n} (a b : vec n), (a2r (<a, b>) <= ||a|| * ||b||)%R.
Proof. intros. apply vdot_le_mul_vlen. Qed.
Proof. intros. apply vdot_le_mul_vlen. Qed.
- ||a|| * ||b|| <= <a, b>
Lemma vdot_ge_mul_vlen_neg : forall {n} (a b : vec n),
(- (||a|| * ||b||) <= a2r (<a, b>))%R.
Proof. intros. apply vdot_ge_mul_vlen_neg. Qed.
(- (||a|| * ||b||) <= a2r (<a, b>))%R.
Proof. intros. apply vdot_ge_mul_vlen_neg. Qed.
||a + b|| <= ||a|| + ||b||
Lemma vlen_le_add : forall {n} (a b : vec n), (||(a + b)%V|| <= ||a|| + ||b||)%R.
Proof. intros. apply vlen_le_add. Qed.
Proof. intros. apply vlen_le_add. Qed.
||a|| - ||b|| <= ||a + b||
Lemma vlen_ge_sub : forall {n} (a b : vec n), ((||a|| - ||b||) <= ||(a + b)%V||)%R.
Proof. intros. apply vlen_ge_sub. Qed.
Proof. intros. apply vlen_ge_sub. Qed.
||a|| = 0 <-> a = 0
Lemma vlen_eq0_iff_eq0 : forall {n} (a : vec n), ||a|| = 0%R <-> a = vzero.
Proof. intros. apply vlen_eq0_iff_eq0. Qed.
Proof. intros. apply vlen_eq0_iff_eq0. Qed.
||a|| <> 0 <-> a <> 0
Lemma vlen_neq0_iff_neq0 : forall {n} (a : vec n), ||a|| <> 0%R <-> a <> vzero.
Proof. intros. apply vlen_neq0_iff_neq0. Qed.
Proof. intros. apply vlen_neq0_iff_neq0. Qed.
a <> vzero -> 0 < ||a||
Lemma vlen_gt0 : forall {n} (a : vec n), a <> vzero -> (0 < ||a||)%R.
Proof. intros. apply vlen_gt0; auto. Qed.
Proof. intros. apply vlen_gt0; auto. Qed.
0 <= <a, a>
Verify the definition is reasonable
Lemma vunit_spec : forall {n} (a : vec n), vunit a <-> ||a|| = 1%R.
Proof. intros. apply vunit_spec. Qed.
Proof. intros. apply vunit_spec. Qed.
Transformation by orthogonal matrix will keep length.
Lemma morth_keep_length : forall {n} (M : smat n) (a : vec n),
morth M -> ||M *v a|| = ||a||.
Proof. intros. apply morth_keep_length. auto. Qed.
morth M -> ||M *v a|| = ||a||.
Proof. intros. apply morth_keep_length. auto. Qed.
Transformation by orthogonal matrix will keep zero.