Formalized $\Sigma_1$-Completeness #
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
- eq_refl: 𝐑₀' (“∀' !!(LO.FirstOrder.Semiterm.bvar 0) = !!(LO.FirstOrder.Semiterm.bvar 0)”)
- replace: ∀ (φ : LO.FirstOrder.SyntacticSemiformula ℒₒᵣ 1), 𝐑₀' (“∀' ∀' (!!(LO.FirstOrder.Semiterm.bvar 1) = !!(LO.FirstOrder.Semiterm.bvar 0) → !(φ/[LO.FirstOrder.Semiterm.bvar 1] ➝ φ/[LO.FirstOrder.Semiterm.bvar 0]))”)
- Ω₁: ∀ (n m : ℕ), 𝐑₀' (“(!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) + !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))) = !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ (n + m)))”)
- Ω₂: ∀ (n m : ℕ), 𝐑₀' (“(!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) * !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))) = !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ (n * m)))”)
- Ω₃: ∀ (n m : ℕ), n ≠ m → 𝐑₀' (“¬!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) = !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))”)
- Ω₄: ∀ (n : ℕ), 𝐑₀' (“∀' (!!(LO.FirstOrder.Semiterm.bvar 0) < !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) ↔ !(LO.disjLt (fun (i : ℕ) => “!!(LO.FirstOrder.Semiterm.bvar 0) = !!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ i))”) n))”)
Instances For
Equations
- LO.FirstOrder.Theory.«term𝐑₀'» = Lean.ParserDescr.node `LO.FirstOrder.Theory.«term𝐑₀'» 1024 (Lean.ParserDescr.symbol "𝐑₀'")
Instances For
@[reducible, inline]
Instances For
theorem
LO.FirstOrder.Arith.add_cobhamR0'
{T : LO.FirstOrder.Theory ℒₒᵣ}
[𝐑₀ ≼ T]
{φ : LO.FirstOrder.SyntacticFormula ℒₒᵣ}
:
def
LO.Arith.singleton
{L : LO.FirstOrder.Language}
[(k : ℕ) → Encodable (L.Func k)]
[(k : ℕ) → Encodable (L.Rel k)]
[LO.Arith.DefinableLanguage L]
(φ : LO.FirstOrder.SyntacticFormula L)
:
{φ}.Delta1Definable
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
LO.Arith.singleton_toTDef_ch_val
{L : LO.FirstOrder.Language}
[(k : ℕ) → Encodable (L.Func k)]
[(k : ℕ) → Encodable (L.Rel k)]
[LO.Arith.DefinableLanguage L]
(φ : LO.FirstOrder.SyntacticFormula L)
:
def
LO.Arith.Formalized.Theory.CobhamR0'.eqRefl :
{“∀' !!(LO.FirstOrder.Semiterm.bvar 0) = !!(LO.FirstOrder.Semiterm.bvar 0)”}.Delta1Definable
Equations
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.replace :
LO.FirstOrder.Theory.Delta1Definable
{x : LO.FirstOrder.SyntacticFormula ℒₒᵣ |
∃ (φ : LO.FirstOrder.SyntacticSemiformula ℒₒᵣ 1),
(“∀'
∀'
(!!(LO.FirstOrder.Semiterm.bvar 1) = !!(LO.FirstOrder.Semiterm.bvar 0) →
!(φ/[LO.FirstOrder.Semiterm.bvar 1] ➝ φ/[LO.FirstOrder.Semiterm.bvar 0]))”) = x}
Equations
- One or more equations did not get rendered due to their size.
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₁ :
LO.FirstOrder.Theory.Delta1Definable
{φ : LO.FirstOrder.SyntacticFormula ℒₒᵣ |
∃ (n : ℕ) (m : ℕ),
φ = (“(!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) +
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))) =
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ (n + m)))”)}
Equations
- One or more equations did not get rendered due to their size.
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₂ :
LO.FirstOrder.Theory.Delta1Definable
{φ : LO.FirstOrder.SyntacticFormula ℒₒᵣ |
∃ (n : ℕ) (m : ℕ),
φ = (“(!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) *
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))) =
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ (n * m)))”)}
Equations
- One or more equations did not get rendered due to their size.
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₃ :
LO.FirstOrder.Theory.Delta1Definable
{φ : LO.FirstOrder.SyntacticFormula ℒₒᵣ |
∃ (n : ℕ) (m : ℕ),
n ≠ m ∧ φ = (“¬!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) =
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ m))”)}
Equations
- One or more equations did not get rendered due to their size.
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₄ :
LO.FirstOrder.Theory.Delta1Definable
{x : LO.FirstOrder.SyntacticFormula ℒₒᵣ |
∃ (n : ℕ),
(“∀'
(!!(LO.FirstOrder.Semiterm.bvar 0) <
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ n)) ↔
!(LO.disjLt
(fun (i : ℕ) =>
“!!(LO.FirstOrder.Semiterm.bvar 0) =
!!(LO.FirstOrder.Semiterm.Operator.const (LO.FirstOrder.Semiterm.Operator.numeral ℒₒᵣ i))”)
n))”) = x}
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
@[reducible, inline]
Equations
- LO.Arith.Formalized.Theory.CobhamR0' = LO.FirstOrder.Theory.codeIn V 𝐑₀'
Instances For
@[reducible, inline]
abbrev
LO.Arith.Formalized.TTheory.CobhamR0'
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
:
⌜ℒₒᵣ⌝.TTheory
Equations
Instances For
Equations
- LO.Arith.Formalized.«term⌜𝐑₀'⌝» = Lean.ParserDescr.node `LO.Arith.Formalized.«term⌜𝐑₀'⌝» 1024 (Lean.ParserDescr.symbol "⌜𝐑₀'⌝")
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.eqRefl.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
:
⌜𝐑₀'⌝ ⊢ ((LO.Arith.bv 0 ⋯).equals (LO.Arith.bv 0 ⋯)).all
Equations
- LO.Arith.Formalized.Theory.CobhamR0'.eqRefl.proof = LO.Arith.Language.Theory.TProof.byAxm ⋯
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.replace.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(φ : ⌜ℒₒᵣ⌝.Semiformula (0 + 1))
:
⌜𝐑₀'⌝ ⊢ ((LO.Arith.bv 1 ⋯).equals (LO.Arith.bv 0 ⋯) ➝ φ^/[(LO.Arith.bv 1 ⋯).sing] ➝ φ^/[(LO.Arith.bv 0 ⋯).sing]).all.all
Equations
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₁.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(n m : V)
:
⌜𝐑₀'⌝ ⊢ (LO.Arith.Formalized.typedNumeral 0 n + LO.Arith.Formalized.typedNumeral 0 m).equals
(LO.Arith.Formalized.typedNumeral 0 (n + m))
Equations
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₂.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(n m : V)
:
⌜𝐑₀'⌝ ⊢ (LO.Arith.Formalized.typedNumeral 0 n * LO.Arith.Formalized.typedNumeral 0 m).equals
(LO.Arith.Formalized.typedNumeral 0 (n * m))
Equations
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₃.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
{n m : V}
(ne : n ≠ m)
:
⌜𝐑₀'⌝ ⊢ (LO.Arith.Formalized.typedNumeral 0 n).notEquals (LO.Arith.Formalized.typedNumeral 0 m)
Instances For
def
LO.Arith.Formalized.Theory.CobhamR0'.Ω₄.proof
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(n : V)
:
⌜𝐑₀'⌝ ⊢ ((LO.Arith.bv 0 ⋯).lessThan (LO.Arith.Formalized.typedNumeral (0 + 1) n) ⭤ (LO.Arith.Formalized.tSubstItr (LO.Arith.bv 0 ⋯).sing ((LO.Arith.bv 1 ⋯).equals (LO.Arith.bv 0 ⋯)) n).disj).all
Instances For
instance
LO.Arith.Formalized.Theory.addCobhamR0'Delta1Definable
(T : LO.FirstOrder.Theory ℒₒᵣ)
[d : T.Delta1Definable]
:
@[reducible, inline]
abbrev
LO.FirstOrder.Theory.AddR₀TTheory
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
:
⌜ℒₒᵣ⌝.TTheory
Equations
- T.AddR₀TTheory = LO.FirstOrder.Theory.tCodeIn V (T + 𝐑₀')
Instances For
@[simp]
theorem
LO.Arith.Formalized.R₀'_subset_AddR₀
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
{T : LO.FirstOrder.Theory ℒₒᵣ}
[T.Delta1Definable]
:
@[simp]
theorem
LO.Arith.Formalized.theory_subset_AddR₀
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
{T : LO.FirstOrder.Theory ℒₒᵣ}
[T.Delta1Definable]
:
LO.FirstOrder.Theory.tCodeIn V T ⊆ T.AddR₀TTheory
instance
LO.Arith.Formalized.instR₀TheoryAddR₀TTheory
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
{T : LO.FirstOrder.Theory ℒₒᵣ}
[T.Delta1Definable]
:
LO.Arith.Formalized.R₀Theory T.AddR₀TTheory
Equations
- One or more equations did not get rendered due to their size.
def
LO.FirstOrder.Theory.Provableₐ
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
(φ : V)
:
Provability predicate for arithmetic stronger than $\mathbf{R_0}$.
Equations
- T.Provableₐ φ = (LO.FirstOrder.Theory.codeIn V (T + 𝐑₀')).Provable φ
Instances For
theorem
LO.Arith.provableₐ_iff
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
{T : LO.FirstOrder.Theory ℒₒᵣ}
[T.Delta1Definable]
{σ : LO.FirstOrder.Sentence ℒₒᵣ}
:
def
LO.FirstOrder.Theory.provableₐ
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
:
𝚺₁.Semisentence 1
Equations
- T.provableₐ = LO.FirstOrder.Arith.HierarchySymbol.Semiformula.mkSigma ((LO.FirstOrder.Arith.HierarchySymbol.Semiformula.val (T + 𝐑₀').tDef.prv)/[LO.FirstOrder.Semiterm.bvar 0]) ⋯
Instances For
theorem
LO.Arith.provableₐ_defined
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
:
𝚺₁-Predicate T.Provableₐ via T.provableₐ
@[simp]
theorem
LO.Arith.eval_provableₐ
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
(v : Fin 1 → V)
:
V ⊧/v (LO.FirstOrder.Arith.HierarchySymbol.Semiformula.val T.provableₐ) ↔ T.Provableₐ (v 0)
instance
LO.Arith.provableₐ_definable
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
:
𝚺₁-Predicate T.Provableₐ
Equations
- ⋯ = ⋯
instance
LO.Arith.provableₐ_definable'
{V : Type u_1}
[LO.ORingStruc V]
[V ⊧ₘ* 𝐈𝚺₁]
(T : LO.FirstOrder.Theory ℒₒᵣ)
[T.Delta1Definable]
:
{ Γ := 𝚺, rank := 0 + 1 }-Predicate T.Provableₐ
instance for definability tactic
Equations
- ⋯ = ⋯