Linear locally finite orders #
We prove that a LinearOrder
which is a LocallyFiniteOrder
also verifies
Furthermore, we show that there is an OrderIso
between such an order and a subset of ℤ
.
Main definitions #
toZ i0 i
: in a linear order on which we can define predecessors and successors and which is succ-archimedean, we can assign a unique integertoZ i0 i
to each elementi : ι
while respecting the order, starting fromtoZ i0 i0 = 0
.
Main results #
Results about linear locally finite orders:
LinearLocallyFiniteOrder.SuccOrder
: a linear locally finite order has a successor function.LinearLocallyFiniteOrder.PredOrder
: a linear locally finite order has a predecessor function.LinearLocallyFiniteOrder.isSuccArchimedean
: a linear locally finite order is succ-archimedean.LinearOrder.pred_archimedean_of_succ_archimedean
: a succ-archimedean linear order is also pred-archimedean.countable_of_linear_succ_pred_arch
: a succ-archimedean linear order is countable.
About toZ
:
orderIsoRangeToZOfLinearSuccPredArch
:toZ
defines anOrderIso
betweenι
and its range.orderIsoNatOfLinearSuccPredArch
: if the order has a bot but no top,toZ
defines anOrderIso
betweenι
andℕ
.orderIsoIntOfLinearSuccPredArch
: if the order has neither bot nor top,toZ
defines anOrderIso
betweenι
andℤ
.orderIsoRangeOfLinearSuccPredArch
: if the order has both a bot and a top,toZ
gives anOrderIso
betweenι
andFinset.range ((toZ ⊥ ⊤).toNat + 1)
.
In a linear SuccOrder
that's also a PredOrder
, IsSuccArchimedean
and IsPredArchimedean
are equivalent.
Successor in a linear order. This defines a true successor only when i
is isolated from above,
i.e. when i
is not the greatest lower bound of (i, ∞)
.
Equations
- LinearLocallyFiniteOrder.succFn i = ⋯.choose
Instances For
A locally finite order is a SuccOrder
.
This is not an instance, because its succ
field conflicts with computable SuccOrder
structures
on ℕ
and ℤ
.
Equations
- LinearLocallyFiniteOrder.succOrder ι = { succ := LinearLocallyFiniteOrder.succFn, le_succ := ⋯, max_of_succ_le := ⋯, succ_le_of_lt := ⋯ }
Instances For
A locally finite order is a PredOrder
.
This is not an instance, because its succ
field conflicts with computable PredOrder
structures
on ℕ
and ℤ
.
Equations
Instances For
toZ
numbers elements of ι
according to their order, starting from i0
. We prove in
orderIsoRangeToZOfLinearSuccPredArch
that this defines an OrderIso
between ι
and
the range of toZ
.
Instances For
toZ
defines an OrderIso
between ι
and its range.
Equations
- orderIsoRangeToZOfLinearSuccPredArch = { toEquiv := Equiv.ofInjective (toZ hι.some) ⋯, map_rel_iff' := ⋯ }
Instances For
If the order has neither bot nor top, toZ
defines an OrderIso
between ι
and ℤ
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
If the order has a bot but no top, toZ
defines an OrderIso
between ι
and ℕ
.
Equations
- orderIsoNatOfLinearSuccPredArch = { toFun := fun (i : ι) => (toZ ⊥ i).toNat, invFun := fun (n : ℕ) => Order.succ^[n] ⊥, left_inv := ⋯, right_inv := ⋯, map_rel_iff' := ⋯ }
Instances For
If the order has both a bot and a top, toZ
gives an OrderIso
between ι
and
Finset.range n
for some n
.
Equations
- One or more equations did not get rendered due to their size.