2014-11-28 07:06:46 -05:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Authors: Leonardo de Moura, Jeremy Avigad
|
|
|
|
|
|
|
|
The sum type, aka disjoint union.
|
|
|
|
-/
|
2014-12-12 13:20:27 -08:00
|
|
|
import logic.connectives
|
2015-01-10 12:45:05 -08:00
|
|
|
open inhabited eq.ops
|
2014-11-19 23:37:45 +01:00
|
|
|
|
2015-02-01 11:39:47 -05:00
|
|
|
notation A ⊎ B := sum A B
|
|
|
|
|
2014-09-04 16:36:06 -07:00
|
|
|
namespace sum
|
2015-02-01 14:14:01 -05:00
|
|
|
notation A + B := sum A B
|
2014-11-19 23:37:45 +01:00
|
|
|
namespace low_precedence_plus
|
2015-09-30 17:06:31 +02:00
|
|
|
reserve infixr ` + `:25 -- conflicts with notation for addition
|
|
|
|
infixr + := sum
|
2014-11-19 23:37:45 +01:00
|
|
|
end low_precedence_plus
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2014-10-05 13:20:04 -07:00
|
|
|
variables {A B : Type}
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-01-10 12:45:05 -08:00
|
|
|
definition inl_ne_inr (a : A) (b : B) : inl a ≠ inr b :=
|
2015-04-30 13:56:12 -07:00
|
|
|
by contradiction
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-01-10 12:45:05 -08:00
|
|
|
definition inr_ne_inl (b : B) (a : A) : inr b ≠ inl a :=
|
2015-04-30 13:56:12 -07:00
|
|
|
by contradiction
|
2015-01-10 12:45:05 -08:00
|
|
|
|
|
|
|
definition inl_inj {a₁ a₂ : A} : intro_left B a₁ = intro_left B a₂ → a₁ = a₂ :=
|
2015-05-01 18:18:29 -07:00
|
|
|
assume H, by injection H; assumption
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-01-10 12:45:05 -08:00
|
|
|
definition inr_inj {b₁ b₂ : B} : intro_right A b₁ = intro_right A b₂ → b₁ = b₂ :=
|
2015-05-01 18:18:29 -07:00
|
|
|
assume H, by injection H; assumption
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-02-24 15:25:02 -08:00
|
|
|
protected definition is_inhabited_left [instance] [h : inhabited A] : inhabited (A + B) :=
|
|
|
|
inhabited.mk (inl (default A))
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-02-24 15:25:02 -08:00
|
|
|
protected definition is_inhabited_right [instance] [h : inhabited B] : inhabited (A + B) :=
|
|
|
|
inhabited.mk (inr (default B))
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2015-02-25 16:20:44 -08:00
|
|
|
protected definition has_decidable_eq [instance] [h₁ : decidable_eq A] [h₂ : decidable_eq B] : ∀ s₁ s₂ : A + B, decidable (s₁ = s₂)
|
|
|
|
| has_decidable_eq (inl a₁) (inl a₂) :=
|
2015-01-10 12:45:05 -08:00
|
|
|
match h₁ a₁ a₂ with
|
2015-05-03 21:40:33 -07:00
|
|
|
| decidable.inl hp := by left; congruence; assumption
|
2015-05-25 10:43:28 -07:00
|
|
|
| decidable.inr hn := by right; intro h; injection h; contradiction
|
2015-02-25 16:20:44 -08:00
|
|
|
end
|
2015-05-03 21:40:33 -07:00
|
|
|
| has_decidable_eq (inl a₁) (inr b₂) := by right; contradiction
|
|
|
|
| has_decidable_eq (inr b₁) (inl a₂) := by right; contradiction
|
2015-02-25 16:20:44 -08:00
|
|
|
| has_decidable_eq (inr b₁) (inr b₂) :=
|
2015-01-10 12:45:05 -08:00
|
|
|
match h₂ b₁ b₂ with
|
2015-05-03 21:40:33 -07:00
|
|
|
| decidable.inl hp := by left; congruence; assumption
|
2015-05-25 10:43:28 -07:00
|
|
|
| decidable.inr hn := by right; intro h; injection h; contradiction
|
2015-01-10 12:45:05 -08:00
|
|
|
end
|
2014-08-27 21:39:55 -04:00
|
|
|
end sum
|