Some constructions of matroids #
This file defines some very elementary examples of matroids, namely those with at most one base.
Main definitions #
emptyOn α
is the matroid onα
with empty ground set.
For E : Set α
, ...
loopyOn E
is the matroid onE
whose elements are all loops, or equivalently in which∅
is the only base.freeOn E
is the 'free matroid' whose ground setE
is the only base.- For
I ⊆ E
,uniqueBaseOn I E
is the matroid with ground setE
in whichI
is the only base.
Implementation details #
To avoid the tedious process of certifying the matroid axioms for each of these easy examples,
we bootstrap the definitions starting with emptyOn α
(which simp
can prove is a matroid)
and then construct the other examples using duality and restriction.
@[simp]
The Matroid α
with ground set E
whose only base is ∅
Instances For
@[simp]
The Matroid α
with ground set E
whose only base is E
.
Instances For
@[simp]
@[simp]
theorem
Matroid.Indep.restrict_eq_freeOn
{α : Type u_1}
{M : Matroid α}
{I : Set α}
(hI : M.Indep I)
:
The matroid on E
whose unique base is the subset I
of E
.
Intended for use when I ⊆ E
; if this not not the case, then the base is I ∩ E
.
Instances For
@[simp]
@[simp]
theorem
Matroid.uniqueBaseOn_inter_basis
{α : Type u_1}
{E I X : Set α}
(hX : X ⊆ E)
:
(uniqueBaseOn I E).Basis (X ∩ I) X
@[simp]
@[simp]
@[simp]
theorem
Matroid.uniqueBaseOn_finiteRk
{α : Type u_1}
{E I : Set α}
(hI : I.Finite)
:
(uniqueBaseOn I E).FiniteRk
theorem
Matroid.uniqueBaseOn_rkPos
{α : Type u_1}
{E I : Set α}
(hIE : I ⊆ E)
(hI : I.Nonempty)
:
(uniqueBaseOn I E).RkPos