Acc is the accessibility predicate. Given some relation r (e.g. <) and a value x,
Acc r x means that x is accessible through r:
x is accessible if there exists no infinite sequence ... < y₂ < y₁ < y₀ < x.
- intro
{α : Sort u}
{r : α → α → Prop}
(x : α)
(h : ∀ (y : α), r y x → Acc r y)
 : Acc r xA value is accessible if for all ysuch thatr y x,yis also accessible. Note that if there exists noysuch thatr y x, thenxis accessible. Such anxis called a base case.
Instances For
A relation r is WellFounded if all elements of α are accessible within r.
If a relation is WellFounded, it does not allow for an infinite descent along the relation.
If the arguments of the recursive calls in a function definition decrease according to a well founded relation, then the function terminates. Well-founded relations are sometimes called Artinian or said to satisfy the “descending chain condition”.
- intro
{α : Sort u}
{r : α → α → Prop}
(h : ∀ (a : α), Acc r a)
 : WellFounded rIf all elements are accessible via r, thenris well-founded.
Instances For
A type that has a standard well-founded relation.
Instances are used to prove that functions terminate using well-founded recursion by showing that recursive calls reduce some measure according to a well-founded relation. This relation can combine well-founded relations on the recursive function's parameters.
- rel : α → α → PropA well-founded relation on α.
- wf : WellFounded relA proof that relis, in fact, well-founded.
Instances
Equations
- ⋯ = ⋯
Instances For
Equations
Instances For
Equations
- WellFounded.fixF F x a = Acc.rec (fun (x₁ : α) (h : ∀ (y : α), r y x₁ → Acc r y) (ih : (y : α) → r y x₁ → C y) => F x₁ ih) a
Instances For
Equations
Instances For
A well-founded fixpoint. If satisfying the motive C for all values that are smaller according to a
well-founded relation allows it to be satisfied for the current value, then it is satisfied for all
values.
This function is used as part of the elaboration of well-founded recursion.
Equations
- hwf.fix F x = WellFounded.fixF F x ⋯
Instances For
Equations
- emptyWf = { rel := emptyRelation, wf := ⋯ }
Instances For
Equations
- ⋯ = ⋯
Instances For
The inverse image of a well-founded relation is well-founded.
Instances For
Equations
- Nat.lt_wfRel = { rel := fun (x1 x2 : Nat) => x1 < x2, wf := Nat.lt_wfRel._proof_3 }
Instances For
Strong induction on the natural numbers.
The induction hypothesis is that all numbers less than a given number satisfy the motive, which should be demonstrated for the given number.
Equations
- Nat.strongRecOn n ind = ⋯.fix ind n
Instances For
Case analysis based on strong induction for the natural numbers.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
Instances For
Equations
A lexicographical order based on the orders ra and rb for the elements of pairs.
- left
{α : Type u}
{β : Type v}
{ra : α → α → Prop}
{rb : β → β → Prop}
{a₁ : α}
(b₁ : β)
{a₂ : α}
(b₂ : β)
(h : ra a₁ a₂)
 : Prod.Lex ra rb (a₁, b₁) (a₂, b₂)If the first projections of two pairs are ordered, then they are lexicographically ordered. 
- right
{α : Type u}
{β : Type v}
{ra : α → α → Prop}
{rb : β → β → Prop}
(a : α)
{b₁ b₂ : β}
(h : rb b₁ b₂)
 : Prod.Lex ra rb (a, b₁) (a, b₂)If the first projections of two pairs are equal, then they are lexicographically ordered if the second projections are ordered. 
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- Prod.lex ha hb = { rel := Prod.Lex WellFoundedRelation.rel WellFoundedRelation.rel, wf := ⋯ }
Instances For
Equations
Equations
- Prod.rprod ha hb = { rel := Prod.RProd WellFoundedRelation.rel WellFoundedRelation.rel, wf := ⋯ }
Instances For
- left {α : Sort u} {β : α → Sort v} {r : α → α → Prop} {s : (a : α) → β a → β a → Prop} {a₁ : α} (b₁ : β a₁) {a₂ : α} (b₂ : β a₂) : r a₁ a₂ → Lex r s ⟨a₁, b₁⟩ ⟨a₂, b₂⟩
- right {α : Sort u} {β : α → Sort v} {r : α → α → Prop} {s : (a : α) → β a → β a → Prop} (a : α) {b₁ b₂ : β a} : s a b₁ b₂ → Lex r s ⟨a, b₁⟩ ⟨a, b₂⟩
Instances For
Equations
- PSigma.lex ha hb = { rel := PSigma.Lex WellFoundedRelation.rel fun (a : α) => WellFoundedRelation.rel, wf := ⋯ }
Instances For
Equations
Equations
- PSigma.lexNdep r s = PSigma.Lex r fun (x : α) => s
Instances For
- left {α : Sort u} {β : Sort v} {r : α → α → Prop} {s : β → β → Prop} {a₁ a₂ : α} (b : β) : r a₁ a₂ → RevLex r s ⟨a₁, b⟩ ⟨a₂, b⟩
- right {α : Sort u} {β : Sort v} {r : α → α → Prop} {s : β → β → Prop} (a₁ : α) {b₁ : β} (a₂ : α) {b₂ : β} : s b₁ b₂ → RevLex r s ⟨a₁, b₁⟩ ⟨a₂, b₂⟩
Instances For
Equations
Instances For
Equations
- PSigma.skipLeft α hb = { rel := PSigma.SkipLeft α WellFoundedRelation.rel, wf := ⋯ }
Instances For
Reverse direction of dite_eq_ite. Used by the well-founded definition preprocessor to extend the
context of a termination proof inside if-then-else with the condition.