mathlib3 documentation

core / init.logic

@[simp]
theorem opt_param_eq (α : Sort u) (default : α) :
:= default) = α
def flip {α : Sort u} {β : Sort v} {φ : Sort w} (f : α β φ) :
β α φ
Equations
  • flip f = λ (b : β) (a : α), f a b
Instances for flip
def implies (a b : Prop) :
Prop

implication

Equations
Instances for implies
@[trans]
theorem implies.trans {p q r : Prop} (h₁ : implies p q) (h₂ : implies q r) :

Implication is transitive. If P → Q and Q → R then P → R.

theorem trivial  :
def absurd {a : Prop} {b : Sort v} (h₁ : a) (h₂ : ¬a) :
b

We can't have a and ¬a, that would be absurd!

Equations
theorem not.intro {a : Prop} (h : a false) :
theorem mt {a b : Prop} (h₁ : a b) (h₂ : ¬b) :

Modus tollens. If an implication is true, then so is its contrapositive.

not

theorem not_false  :
def non_contradictory (a : Prop) :
Prop
Equations
theorem non_contradictory_intro {a : Prop} (ha : a) :

false

def false.elim {C : Sort u} (h : false) :
C
Equations

eq

theorem proof_irrel {a : Prop} (h₁ h₂ : a) :
h₁ = h₂
@[simp]
theorem id.def {α : Sort u} (a : α) :
id a = a
def eq.mp {α β : Sort u} :
α = β α β
Equations
def eq.mpr {α β : Sort u} :
α = β β α
Equations
  • eq.mpr = λ (h₁ : α = β) (h₂ : β), _.rec_on h₂
theorem eq.substr {α : Sort u} {p : α Prop} {a b : α} (h₁ : b = a) :
p a p b
theorem congr {α : Sort u} {β : Sort v} {f₁ f₂ : α β} {a₁ a₂ : α} (h₁ : f₁ = f₂) (h₂ : a₁ = a₂) :
f₁ a₁ = f₂ a₂
theorem congr_fun {α : Sort u} {β : α Sort v} {f g : Π (x : α), β x} (h : f = g) (a : α) :
f a = g a
theorem congr_arg {α : Sort u} {β : Sort v} {a₁ a₂ : α} (f : α β) :
a₁ = a₂ f a₁ = f a₂
theorem trans_rel_left {α : Sort u} {a b c : α} (r : α α Prop) (h₁ : r a b) (h₂ : b = c) :
r a c
theorem trans_rel_right {α : Sort u} {a b c : α} (r : α α Prop) (h₁ : a = b) (h₂ : r b c) :
r a c
theorem of_eq_true {p : Prop} (h : p = true) :
p
theorem not_of_eq_false {p : Prop} (h : p = false) :
def cast {α β : Sort u} (h : α = β) (a : α) :
β
Equations
theorem cast_proof_irrel {α β : Sort u} (h₁ h₂ : α = β) (a : α) :
cast h₁ a = cast h₂ a
@[simp]
theorem cast_eq {α : Sort u} (h : α = α) (a : α) :
cast h a = a

ne

@[reducible]
def ne {α : Sort u} (a b : α) :
Prop
Equations
@[simp]
theorem ne.def {α : Sort u} (a b : α) :
a b = ¬a = b
theorem ne.intro {α : Sort u} {a b : α} (h : a = b false) :
a b
theorem ne.elim {α : Sort u} {a b : α} (h : a b) :
a = b false
theorem ne.irrefl {α : Sort u} {a : α} (h : a a) :
@[symm]
theorem ne.symm {α : Sort u} {a b : α} (h : a b) :
b a
theorem false_of_ne {α : Sort u} {a : α} :
theorem ne_false_of_self {p : Prop} :
theorem ne_true_of_not {p : Prop} :
def heq.elim {α : Sort u} {a : α} {p : α Sort v} {b : α} (h₁ : a == b) :
p a p b
Equations
theorem heq.subst {α β : Sort u} {a : α} {b : β} {p : Π (T : Sort u), T Prop} :
a == b p α a p β b
@[symm]
theorem heq.symm {α β : Sort u} {a : α} {b : β} (h : a == b) :
b == a
theorem heq_of_eq {α : Sort u} {a a' : α} (h : a = a') :
a == a'
@[trans]
theorem heq.trans {α β φ : Sort u} {a : α} {b : β} {c : φ} (h₁ : a == b) (h₂ : b == c) :
a == c
@[trans]
theorem heq_of_heq_of_eq {α β : Sort u} {a : α} {b b' : β} (h₁ : a == b) (h₂ : b = b') :
a == b'
@[trans]
theorem heq_of_eq_of_heq {α β : Sort u} {a a' : α} {b : β} (h₁ : a = a') (h₂ : a' == b) :
a == b
theorem type_eq_of_heq {α β : Sort u} {a : α} {b : β} (h : a == b) :
α = β
theorem eq_rec_heq {α : Sort u} {φ : α Sort v} {a a' : α} (h : a = a') (p : φ a) :
h.rec_on p == p
theorem heq_of_eq_rec_left {α : Sort u} {φ : α Sort v} {a a' : α} {p₁ : φ a} {p₂ : φ a'} (e : a = a') (h₂ : e.rec_on p₁ = p₂) :
p₁ == p₂
theorem heq_of_eq_rec_right {α : Sort u} {φ : α Sort v} {a a' : α} {p₁ : φ a} {p₂ : φ a'} (e : a' = a) (h₂ : p₁ = e.rec_on p₂) :
p₁ == p₂
theorem of_heq_true {a : Prop} (h : a == true) :
a
theorem eq_rec_compose {α β φ : Sort u} (p₁ : β = φ) (p₂ : α = β) (a : α) :
p₁.rec_on (p₂.rec_on a) = _.rec_on a
@[simp]
theorem cast_heq {α β : Sort u} (h : α = β) (a : α) :
cast h a == a

and

theorem and.elim {a b c : Prop} (h₁ : a b) (h₂ : a b c) :
c
theorem and.swap {a b : Prop} :
a b b a
theorem and.symm {a b : Prop} :
a b b a

or

theorem or.elim {a b c : Prop} (h₁ : a b) (h₂ : a c) (h₃ : b c) :
c
theorem non_contradictory_em (a : Prop) :
¬¬(a ¬a)
theorem or.swap {a b : Prop} :
a b b a
theorem or.symm {a b : Prop} :
a b b a

xor

def xor (a b : Prop) :
Prop
Equations
Instances for xor

iff

structure iff (a b : Prop) :
Prop

iff P Q, with notation P ↔ Q, is the proposition asserting that P and Q are equivalent, that is, have the same truth value.

Instances for iff
theorem iff.elim {a b c : Prop} :
((a b) (b a) c) (a b) c
theorem iff.elim_left {a b : Prop} :
(a b) a b
theorem iff.elim_right {a b : Prop} :
(a b) b a
theorem iff_iff_implies_and_implies (a b : Prop) :
a b (a b) (b a)
@[refl]
theorem iff.refl (a : Prop) :
a a
theorem iff.rfl {a : Prop} :
a a
@[trans]
theorem iff.trans {a b c : Prop} (h₁ : a b) (h₂ : b c) :
a c
@[symm]
theorem iff.symm {a b : Prop} (h : a b) :
b a
theorem iff.comm {a b : Prop} :
a b (b a)
theorem eq.to_iff {a b : Prop} (h : a = b) :
a b
theorem neq_of_not_iff {a b : Prop} :
¬(a b) a b
theorem not_iff_not_of_iff {a b : Prop} (h₁ : a b) :
theorem of_iff_true {a : Prop} (h : a true) :
a
theorem not_of_iff_false {a : Prop} :
theorem iff_true_intro {a : Prop} (h : a) :
theorem iff_false_intro {a : Prop} (h : ¬a) :
theorem imp_congr {a b c d : Prop} (h₁ : a c) (h₂ : b d) :
a b c d
theorem imp_congr_ctx {a b c d : Prop} (h₁ : a c) (h₂ : c (b d)) :
a b c d
theorem imp_congr_right {a b c : Prop} (h : a (b c)) :
a b a c
theorem not_not_intro {a : Prop} (ha : a) :
theorem not_of_not_not_not {a : Prop} (h : ¬¬¬a) :
@[simp]
theorem not_true  :
@[simp]
theorem not_congr {a b : Prop} (h : a b) :
theorem ne_self_iff_false {α : Sort u} (a : α) :
@[simp]
theorem eq_self_iff_true {α : Sort u} (a : α) :
a = a true
theorem heq_self_iff_true {α : Sort u} (a : α) :
a == a true
@[simp]
theorem iff_not_self (a : Prop) :
@[simp]
theorem not_iff_self (a : Prop) :
theorem eq_comm {α : Sort u} {a b : α} :
a = b b = a

and simp rules

theorem and.imp {a b c d : Prop} (hac : a c) (hbd : b d) :
a b c d
theorem and_implies {a b c d : Prop} (hac : a c) (hbd : b d) :
a b c d
theorem and_congr {a b c d : Prop} (h₁ : a c) (h₂ : b d) :
a b c d
theorem and_congr_right {a b c : Prop} (h : a (b c)) :
a b a c
theorem and.comm {a b : Prop} :
a b b a
theorem and_comm (a b : Prop) :
a b b a
theorem and.assoc {a b c : Prop} :
(a b) c a b c
theorem and_assoc {c : Prop} (a b : Prop) :
(a b) c a b c
theorem and.left_comm {a b c : Prop} :
a b c b a c
theorem and_iff_left {a b : Prop} (hb : b) :
a b a
theorem and_iff_right {a b : Prop} (ha : a) :
a b b
@[simp]
theorem and_true (a : Prop) :
@[simp]
theorem true_and (a : Prop) :
@[simp]
theorem and_false (a : Prop) :
@[simp]
theorem false_and (a : Prop) :
@[simp]
theorem not_and_self (a : Prop) :
@[simp]
theorem and_not_self (a : Prop) :
@[simp]
theorem and_self (a : Prop) :
a a a

or simp rules

theorem or.imp {a b c d : Prop} (h₂ : a c) (h₃ : b d) :
a b c d
theorem or.imp_left {a b c : Prop} (h : a b) :
a c b c
theorem or.imp_right {a b c : Prop} (h : a b) :
c a c b
theorem or_congr {a b c d : Prop} (h₁ : a c) (h₂ : b d) :
a b c d
theorem or.comm {a b : Prop} :
a b b a
theorem or_comm (a b : Prop) :
a b b a
theorem or.assoc {a b c : Prop} :
(a b) c a b c
theorem or_assoc {c : Prop} (a b : Prop) :
(a b) c a b c
theorem or.left_comm {a b c : Prop} :
a b c b a c
theorem or_iff_right_of_imp {a b : Prop} (ha : a b) :
a b b
theorem or_iff_left_of_imp {a b : Prop} (hb : b a) :
a b a
@[simp]
theorem or_true (a : Prop) :
@[simp]
theorem true_or (a : Prop) :
@[simp]
theorem or_false (a : Prop) :
@[simp]
theorem false_or (a : Prop) :
@[simp]
theorem or_self (a : Prop) :
a a a
theorem not_or {a b : Prop} :
¬a ¬b ¬(a b)

or resolution rulse

theorem or.resolve_left {a b : Prop} (h : a b) (na : ¬a) :
b
theorem or.neg_resolve_left {a b : Prop} (h : ¬a b) (ha : a) :
b
theorem or.resolve_right {a b : Prop} (h : a b) (nb : ¬b) :
a
theorem or.neg_resolve_right {a b : Prop} (h : a ¬b) (hb : b) :
a

iff simp rules

@[simp]
theorem iff_true (a : Prop) :
@[simp]
theorem true_iff (a : Prop) :
@[simp]
theorem iff_false (a : Prop) :
@[simp]
theorem false_iff (a : Prop) :
@[simp]
theorem iff_self (a : Prop) :
theorem iff_congr {a b c d : Prop} (h₁ : a c) (h₂ : b d) :
a b (c d)

implies simp rule

@[simp]
theorem implies_true_iff (α : Sort u) :
theorem false_implies_iff (a : Prop) :
theorem true_implies_iff (α : Prop) :
true α α
inductive Exists {α : Sort u} (p : α Prop) :
Prop

The existential quantifier.

To prove a goal of the form ⊢ ∃ x, p x, you can provide a witness y with the tactic existsi y. If you are working in a project that depends on mathlib, then we recommend the use tactic instead. You'll then be left with the goal ⊢ p y.

To extract a witness x and proof hx : p x from a hypothesis h : ∃ x, p x, use the tactic cases h with x hx. See also the mathlib tactics obtain and rcases.

Instances for Exists
def exists.intro {α : Sort u} {p : α Prop} (w : α) (h : p w) :
(x : α), p x
theorem exists.elim {α : Sort u} {p : α Prop} {b : Prop} (h₁ : (x : α), p x) (h₂ : (a : α), p a b) :
b

exists unique

def exists_unique {α : Sort u} (p : α Prop) :
Prop
Equations
theorem exists_unique.intro {α : Sort u} {p : α Prop} (w : α) (h₁ : p w) (h₂ : (y : α), p y y = w) :
∃! (x : α), p x
theorem exists_unique.elim {α : Sort u} {p : α Prop} {b : Prop} (h₂ : ∃! (x : α), p x) (h₁ : (x : α), p x ( (y : α), p y y = x) b) :
b
theorem exists_unique_of_exists_of_unique {α : Sort u} {p : α Prop} (hex : (x : α), p x) (hunique : (y₁ y₂ : α), p y₁ p y₂ y₁ = y₂) :
∃! (x : α), p x
theorem exists_of_exists_unique {α : Sort u} {p : α Prop} (h : ∃! (x : α), p x) :
(x : α), p x
theorem unique_of_exists_unique {α : Sort u} {p : α Prop} (h : ∃! (x : α), p x) {y₁ y₂ : α} (py₁ : p y₁) (py₂ : p y₂) :
y₁ = y₂

exists, forall, exists unique congruences

theorem forall_congr {α : Sort u} {p q : α Prop} (h : (a : α), p a q a) :
( (a : α), p a) (a : α), q a
theorem exists_imp_exists {α : Sort u} {p q : α Prop} (h : (a : α), p a q a) (p_1 : (a : α), p a) :
(a : α), q a
theorem exists_congr {α : Sort u} {p q : α Prop} (h : (a : α), p a q a) :
Exists p (a : α), q a
theorem exists_unique_congr {α : Sort u} {p₁ p₂ : α Prop} (h : (x : α), p₁ x p₂ x) :
exists_unique p₁ ∃! (x : α), p₂ x
theorem forall_not_of_not_exists {α : Sort u} {p : α Prop} :
(¬ (x : α), p x) (x : α), ¬p x

decidable

def decidable.to_bool (p : Prop) [h : decidable p] :
Equations
@[protected, instance]
Equations
def dite {α : Sort u} (c : Prop) [h : decidable c] :
(c α) (¬c α) α
Equations
Instances for dite
def ite {α : Sort u} (c : Prop) [h : decidable c] (t e : α) :
α

if-then-else

Equations
  • ite c t e = h.rec_on (λ (hnc : ¬c), e) (λ (hc : c), t)
Instances for ite
def decidable.rec_on_true {p : Prop} [h : decidable p] {h₁ : p Sort u} {h₂ : ¬p Sort u} (h₃ : p) (h₄ : h₁ h₃) :
h.rec_on h₂ h₁
Equations
def decidable.rec_on_false {p : Prop} [h : decidable p] {h₁ : p Sort u} {h₂ : ¬p Sort u} (h₃ : ¬p) (h₄ : h₂ h₃) :
h.rec_on h₂ h₁
Equations
def decidable.by_cases {p : Prop} {q : Sort u} [φ : decidable p] :
(p q) (¬p q) q
Equations
theorem decidable.em (p : Prop) [decidable p] :
p ¬p

Law of Excluded Middle.

theorem decidable.by_contradiction {p : Prop} [decidable p] (h : ¬p false) :
p
theorem decidable.of_not_not {p : Prop} [decidable p] :
theorem decidable.not_not_iff (p : Prop) [decidable p] :
theorem decidable.not_and_iff_or_not (p q : Prop) [d₁ : decidable p] [d₂ : decidable q] :
¬(p q) ¬p ¬q
theorem decidable.not_or_iff_and_not (p q : Prop) [d₁ : decidable p] [d₂ : decidable q] :
¬(p q) ¬p ¬q
def decidable_of_decidable_of_iff {p q : Prop} (hp : decidable p) (h : p q) :
Equations
@[protected]
def or.by_cases {p q : Prop} [decidable p] {α : Sort u} (h : p q) (h₁ : p α) (h₂ : q α) :
α

A version of or.elim in Type. If both p and q are true, h₁ is used.

Equations
  • h.by_cases h₁ h₂ = dite p (λ (hp : p), h₁ hp) (λ (hp : ¬p), h₂ _)
@[protected, instance]
def and.decidable {p q : Prop} [decidable p] [decidable q] :
Equations
@[protected, instance]
def or.decidable {p q : Prop} [decidable p] [decidable q] :
Equations
@[protected, instance]
def not.decidable {p : Prop} [decidable p] :
Equations
@[protected, instance]
def implies.decidable {p q : Prop} [decidable p] [decidable q] :
Equations
@[protected, instance]
def iff.decidable {p q : Prop} [decidable p] [decidable q] :
Equations
@[protected, instance]
def xor.decidable {p q : Prop} [decidable p] [decidable q] :
Equations
@[protected, instance]
def exists_prop_decidable {p : Prop} (P : p Prop) [Dp : decidable p] [DP : Π (h : p), decidable (P h)] :
decidable ( (h : p), P h)
Equations
@[protected, instance]
def forall_prop_decidable {p : Prop} (P : p Prop) [Dp : decidable p] [DP : Π (h : p), decidable (P h)] :
decidable ( (h : p), P h)
Equations
@[protected, instance]
def ne.decidable {α : Sort u} [decidable_eq α] (a b : α) :
Equations
def is_dec_eq {α : Sort u} (p : α α bool) :
Prop
Equations
def is_dec_refl {α : Sort u} (p : α α bool) :
Prop
Equations
def decidable_eq_of_bool_pred {α : Sort u} {p : α α bool} (h₁ : is_dec_eq p) (h₂ : is_dec_refl p) :
Equations
theorem decidable_eq_inl_refl {α : Sort u} [h : decidable_eq α] (a : α) :
theorem decidable_eq_inr_neg {α : Sort u} [h : decidable_eq α] {a b : α} (n : a b) :

inhabited

@[class]
structure inhabited (α : Sort u) :
Sort (max 1 u)
  • default : α
Instances of this typeclass
Instances of other typeclasses for inhabited
  • inhabited.has_sizeof_inst
@[irreducible]
def arbitrary (α : Sort u) [inhabited α] :
α
Equations
@[protected, instance]
def prop.inhabited  :
Equations
@[protected, instance]
def pi.inhabited (α : Sort u) {β : α Sort v} [Π (x : α), inhabited (β x)] :
inhabited (Π (x : α), β x)
Equations
@[protected, instance]
Equations
@[protected, instance]
Equations
@[class]
inductive nonempty (α : Sort u) :
Prop
Instances of this typeclass
@[protected]
theorem nonempty.elim {α : Sort u} {p : Prop} (h₁ : nonempty α) (h₂ : α p) :
p
@[protected, simp, instance]
def nonempty_of_inhabited {α : Sort u} [inhabited α] :
theorem nonempty_of_exists {α : Sort u} {p : α Prop} :
( (x : α), p x) nonempty α

subsingleton

@[class]
inductive subsingleton (α : Sort u) :
Prop
Instances of this typeclass
@[protected]
theorem subsingleton.elim {α : Sort u} [h : subsingleton α] (a b : α) :
a = b
@[protected]
theorem subsingleton.helim {α β : Sort u} [h : subsingleton α] (h_1 : α = β) (a : α) (b : β) :
a == b
@[protected, instance]
def subsingleton_prop (p : Prop) :
@[protected, instance]
@[protected]
theorem rec_subsingleton {p : Prop} [h : decidable p] {h₁ : p Sort u} {h₂ : ¬p Sort u} [h₃ : (h : p), subsingleton (h₁ h)] [h₄ : (h : ¬p), subsingleton (h₂ h)] :
subsingleton (h.rec_on h₂ h₁)
theorem if_pos {c : Prop} [h : decidable c] (hc : c) {α : Sort u} {t e : α} :
ite c t e = t
theorem if_neg {c : Prop} [h : decidable c] (hnc : ¬c) {α : Sort u} {t e : α} :
ite c t e = e
@[simp]
theorem if_t_t (c : Prop) [h : decidable c] {α : Sort u} (t : α) :
ite c t t = t
theorem implies_of_if_pos {c t e : Prop} [decidable c] (h : ite c t e) :
c t
theorem implies_of_if_neg {c t e : Prop} [decidable c] (h : ite c t e) :
¬c e
theorem if_ctx_congr {α : Sort u} {b c : Prop} [dec_b : decidable b] [dec_c : decidable c] {x y u v : α} (h_c : b c) (h_t : c x = u) (h_e : ¬c y = v) :
ite b x y = ite c u v
theorem if_congr {α : Sort u} {b c : Prop} [dec_b : decidable b] [dec_c : decidable c] {x y u v : α} (h_c : b c) (h_t : x = u) (h_e : y = v) :
ite b x y = ite c u v
@[simp]
theorem if_true {α : Sort u} {h : decidable true} (t e : α) :
ite true t e = t
@[simp]
theorem if_false {α : Sort u} {h : decidable false} (t e : α) :
ite false t e = e
theorem if_ctx_congr_prop {b c x y u v : Prop} [dec_b : decidable b] [dec_c : decidable c] (h_c : b c) (h_t : c (x u)) (h_e : ¬c (y v)) :
ite b x y ite c u v
theorem if_congr_prop {b c x y u v : Prop} [dec_b : decidable b] [dec_c : decidable c] (h_c : b c) (h_t : x u) (h_e : y v) :
ite b x y ite c u v
theorem if_ctx_simp_congr_prop {b c x y u v : Prop} [dec_b : decidable b] (h_c : b c) (h_t : c (x u)) (h_e : ¬c (y v)) :
ite b x y ite c u v
theorem if_simp_congr_prop {b c x y u v : Prop} [dec_b : decidable b] (h_c : b c) (h_t : x u) (h_e : y v) :
ite b x y ite c u v
@[simp]
theorem dif_pos {c : Prop} [h : decidable c] (hc : c) {α : Sort u} {t : c α} {e : ¬c α} :
dite c t e = t hc
@[simp]
theorem dif_neg {c : Prop} [h : decidable c] (hnc : ¬c) {α : Sort u} {t : c α} {e : ¬c α} :
dite c t e = e hnc
theorem dif_ctx_congr {α : Sort u} {b c : Prop} [dec_b : decidable b] [dec_c : decidable c] {x : b α} {u : c α} {y : ¬b α} {v : ¬c α} (h_c : b c) (h_t : (h : c), x _ = u h) (h_e : (h : ¬c), y _ = v h) :
dite b x y = dite c u v
theorem dif_ctx_simp_congr {α : Sort u} {b c : Prop} [dec_b : decidable b] {x : b α} {u : c α} {y : ¬b α} {v : ¬c α} (h_c : b c) (h_t : (h : c), x _ = u h) (h_e : (h : ¬c), y _ = v h) :
dite b x y = dite c u v
theorem dif_eq_if (c : Prop) [h : decidable c] {α : Sort u} (t e : α) :
dite c (λ (h : c), t) (λ (h : ¬c), e) = ite c t e
@[protected, instance]
def ite.decidable {c t e : Prop} [d_c : decidable c] [d_t : decidable t] [d_e : decidable e] :
decidable (ite c t e)
Equations
@[protected, instance]
def dite.decidable {c : Prop} {t : c Prop} {e : ¬c Prop} [d_c : decidable c] [d_t : Π (h : c), decidable (t h)] [d_e : Π (h : ¬c), decidable (e h)] :
decidable (dite c (λ (h : c), t h) (λ (h : ¬c), e h))
Equations
def as_true (c : Prop) [decidable c] :
Prop
Equations
def as_false (c : Prop) [decidable c] :
Prop
Equations
theorem of_as_true {c : Prop} [h₁ : decidable c] (h₂ : as_true c) :
c
@[ext]
structure ulift (α : Type s) :
Type (max s r)
  • down : α

Universe lifting operation

Instances for ulift
theorem ulift.up_down {α : Type u} (b : ulift α) :
{down := b.down} = b

Bijection between α and ulift.{v} α

theorem ulift.down_up {α : Type u} (a : α) :
{down := a}.down = a
theorem plift.up_down {α : Sort u} (b : plift α) :
{down := b.down} = b

Bijection between α and plift α

theorem plift.down_up {α : Sort u} (a : α) :
{down := a}.down = a
theorem let_value_eq {α : Sort u} {β : Sort v} {a₁ a₂ : α} (b : α β) :
a₁ = a₂ ((let x : α := a₁ in b x) = let x : α := a₂ in b x)

Equalities for rewriting let-expressions

theorem let_value_heq {α : Sort v} {β : α Sort u} {a₁ a₂ : α} (b : Π (x : α), β x) :
a₁ = a₂ ((let x : α := a₁ in b x) == let x : α := a₂ in b x)
theorem let_body_eq {α : Sort v} {β : α Sort u} (a : α) {b₁ b₂ : Π (x : α), β x} :
( (x : α), b₁ x = b₂ x) ((let x : α := a in b₁ x) = let x : α := a in b₂ x)
theorem let_eq {α : Sort v} {β : Sort u} {a₁ a₂ : α} {b₁ b₂ : α β} :
a₁ = a₂ ( (x : α), b₁ x = b₂ x) ((let x : α := a₁ in b₁ x) = let x : α := a₂ in b₂ x)
def reflexive {β : Sort v} (r : β β Prop) :
Prop
Equations
def symmetric {β : Sort v} (r : β β Prop) :
Prop
Equations
def transitive {β : Sort v} (r : β β Prop) :
Prop
Equations
def equivalence {β : Sort v} (r : β β Prop) :
Prop
Equations
def total {β : Sort v} (r : β β Prop) :
Prop
Equations
theorem mk_equivalence {β : Sort v} (r : β β Prop) (rfl : reflexive r) (symm : symmetric r) (trans : transitive r) :
def irreflexive {β : Sort v} (r : β β Prop) :
Prop
Equations
def anti_symmetric {β : Sort v} (r : β β Prop) :
Prop
Equations
def empty_relation {α : Sort u} (a₁ a₂ : α) :
Prop
Equations
Instances for empty_relation
def subrelation {β : Sort v} (q r : β β Prop) :
Prop
Equations
def inv_image {α : Sort u} {β : Sort v} (r : β β Prop) (f : α β) :
α α Prop
Equations
  • inv_image r f = λ (a₁ a₂ : α), r (f a₁) (f a₂)
Instances for inv_image
theorem inv_image.trans {α : Sort u} {β : Sort v} (r : β β Prop) (f : α β) (h : transitive r) :
theorem inv_image.irreflexive {α : Sort u} {β : Sort v} (r : β β Prop) (f : α β) (h : irreflexive r) :
def commutative {α : Type u} (f : α α α) :
Prop
Equations
def associative {α : Type u} (f : α α α) :
Prop
Equations
def left_identity {α : Type u} (f : α α α) (one : α) :
Prop
Equations
def right_identity {α : Type u} (f : α α α) (one : α) :
Prop
Equations
def right_inverse {α : Type u} (f : α α α) (inv : α α) (one : α) :
Prop
Equations
def left_cancelative {α : Type u} (f : α α α) :
Prop
Equations
def right_cancelative {α : Type u} (f : α α α) :
Prop
Equations
def left_distributive {α : Type u} (f g : α α α) :
Prop
Equations
def right_distributive {α : Type u} (f g : α α α) :
Prop
Equations
def right_commutative {α : Type u} {β : Type v} (h : β α β) :
Prop
Equations
def left_commutative {α : Type u} {β : Type v} (h : α β β) :
Prop
Equations
theorem left_comm {α : Type u} (f : α α α) :
theorem right_comm {α : Type u} (f : α α α) :