2015-05-10 17:44:58 +10:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Author: Jeremy Avigad
|
|
|
|
|
|
|
|
|
|
Interactions between finset and set.
|
|
|
|
|
-/
|
|
|
|
|
import data.finset.comb data.set.function
|
|
|
|
|
open nat eq.ops set
|
|
|
|
|
|
|
|
|
|
namespace finset
|
|
|
|
|
|
|
|
|
|
variable {A : Type}
|
|
|
|
|
variable [deceq : decidable_eq A]
|
|
|
|
|
|
2015-08-04 16:47:16 -04:00
|
|
|
|
definition to_set [coercion] (s : finset A) : set A := λx, x ∈ s
|
2015-05-31 10:24:41 +10:00
|
|
|
|
abbreviation ts := @to_set A
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
2015-06-10 17:39:50 +10:00
|
|
|
|
variables (s t : finset A) (x y : A)
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_eq_mem_to_set : x ∈ s = (x ∈ ts s) := rfl
|
2015-06-03 11:36:19 -07:00
|
|
|
|
|
|
|
|
|
definition to_set.inj {s₁ s₂ : finset A} : to_set s₁ = to_set s₂ → s₁ = s₂ :=
|
|
|
|
|
λ h, ext (λ a, iff.of_eq (calc
|
|
|
|
|
(a ∈ s₁) = (a ∈ ts s₁) : mem_eq_mem_to_set
|
|
|
|
|
... = (a ∈ ts s₂) : h
|
|
|
|
|
... = (a ∈ s₂) : mem_eq_mem_to_set))
|
|
|
|
|
|
2015-05-10 17:44:58 +10:00
|
|
|
|
/- operations -/
|
|
|
|
|
|
|
|
|
|
theorem mem_to_set_empty : (x ∈ ts ∅) = (x ∈ ∅) := rfl
|
2015-08-08 04:20:17 -07:00
|
|
|
|
theorem to_set_empty : ts ∅ = (@set.empty A) := rfl
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
|
|
|
|
theorem mem_to_set_univ [h : fintype A] : (x ∈ ts univ) = (x ∈ set.univ) :=
|
|
|
|
|
propext (iff.intro (assume H, trivial) (assume H, !mem_univ))
|
2015-05-18 15:45:23 -07:00
|
|
|
|
theorem to_set_univ [h : fintype A] : ts univ = (set.univ : set A) := funext (λ x, !mem_to_set_univ)
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_to_set_upto (x n : ℕ) : x ∈ ts (upto n) = (x ∈ {a | a < n}) := !mem_upto_eq
|
|
|
|
|
theorem to_set_upto (n : ℕ) : ts (upto n) = {a | a < n} := funext (λ x, !mem_to_set_upto)
|
|
|
|
|
|
2015-05-31 10:24:41 +10:00
|
|
|
|
include deceq
|
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_to_set_insert : x ∈ insert y s = (x ∈ set.insert y s) := !mem_insert_eq
|
2015-08-04 16:47:16 -04:00
|
|
|
|
theorem to_set_insert : insert y s = set.insert y s := funext (λ x, !mem_to_set_insert)
|
2015-06-10 17:39:50 +10:00
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_to_set_union : x ∈ s ∪ t = (x ∈ ts s ∪ ts t) := !mem_union_eq
|
2015-05-10 17:44:58 +10:00
|
|
|
|
theorem to_set_union : ts (s ∪ t) = ts s ∪ ts t := funext (λ x, !mem_to_set_union)
|
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_to_set_inter : x ∈ s ∩ t = (x ∈ ts s ∩ ts t) := !mem_inter_eq
|
2015-05-10 17:44:58 +10:00
|
|
|
|
theorem to_set_inter : ts (s ∩ t) = ts s ∩ ts t := funext (λ x, !mem_to_set_inter)
|
|
|
|
|
|
2015-08-04 22:36:10 -04:00
|
|
|
|
theorem mem_to_set_diff : x ∈ s \ t = (x ∈ ts s \ ts t) := !mem_diff_eq
|
2015-05-10 17:44:58 +10:00
|
|
|
|
theorem to_set_diff : ts (s \ t) = ts s \ ts t := funext (λ x, !mem_to_set_diff)
|
|
|
|
|
|
2015-08-08 18:10:44 -04:00
|
|
|
|
theorem mem_to_set_sep (p : A → Prop) [h : decidable_pred p] : x ∈ sep p s = (x ∈ set.sep p s) :=
|
|
|
|
|
!finset.mem_sep_eq
|
|
|
|
|
theorem to_set_sep (p : A → Prop) [h : decidable_pred p] : sep p s = set.sep p s :=
|
|
|
|
|
funext (λ x, !mem_to_set_sep)
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
|
|
|
|
theorem mem_to_set_image {B : Type} [h : decidable_eq B] (f : A → B) {s : finset A} {y : B} :
|
2015-08-04 22:36:10 -04:00
|
|
|
|
y ∈ image f s = (y ∈ set.image f s) := !mem_image_eq
|
2015-05-10 17:44:58 +10:00
|
|
|
|
theorem to_set_image {B : Type} [h : decidable_eq B] (f : A → B) (s : finset A) :
|
2015-08-04 16:47:16 -04:00
|
|
|
|
image f s = set.image f s := funext (λ x, !mem_to_set_image)
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
|
|
|
|
/- relations -/
|
|
|
|
|
|
2015-05-18 15:45:23 -07:00
|
|
|
|
definition decidable_mem_to_set [instance] (x : A) (s : finset A) : decidable (x ∈ ts s) :=
|
2015-05-10 17:44:58 +10:00
|
|
|
|
decidable_of_decidable_of_eq _ !mem_eq_mem_to_set
|
|
|
|
|
|
2015-08-06 16:43:18 -04:00
|
|
|
|
theorem eq_of_to_set_eq_to_set {s t : finset A} (H : to_set s = to_set t) : s = t :=
|
|
|
|
|
ext (take x, by rewrite [mem_eq_mem_to_set s, H])
|
|
|
|
|
|
2015-05-10 17:44:58 +10:00
|
|
|
|
theorem eq_eq_to_set_eq : (s = t) = (ts s = ts t) :=
|
2015-08-06 16:43:18 -04:00
|
|
|
|
propext (iff.intro (assume H, H ▸ rfl) !eq_of_to_set_eq_to_set)
|
2015-05-10 17:44:58 +10:00
|
|
|
|
|
|
|
|
|
definition decidable_to_set_eq [instance] (s t : finset A) : decidable (ts s = ts t) :=
|
|
|
|
|
decidable_of_decidable_of_eq _ !eq_eq_to_set_eq
|
|
|
|
|
|
|
|
|
|
theorem subset_eq_to_set_subset (s t : finset A) : (s ⊆ t) = (ts s ⊆ ts t) :=
|
|
|
|
|
propext (iff.intro
|
|
|
|
|
(assume H, take x xs, mem_of_subset_of_mem H xs)
|
|
|
|
|
(assume H, subset_of_forall H))
|
|
|
|
|
|
|
|
|
|
definition decidable_to_set_subset (s t : finset A) : decidable (ts s ⊆ ts t) :=
|
|
|
|
|
decidable_of_decidable_of_eq _ !subset_eq_to_set_subset
|
|
|
|
|
|
|
|
|
|
/- bounded quantifiers -/
|
|
|
|
|
|
|
|
|
|
definition decidable_bounded_forall (s : finset A) (p : A → Prop) [h : decidable_pred p] :
|
|
|
|
|
decidable (∀₀ x ∈ ts s, p x) :=
|
|
|
|
|
decidable_of_decidable_of_iff _ !all_iff_forall
|
|
|
|
|
|
|
|
|
|
definition decidable_bounded_exists (s : finset A) (p : A → Prop) [h : decidable_pred p] :
|
|
|
|
|
decidable (∃₀ x ∈ ts s, p x) :=
|
|
|
|
|
decidable_of_decidable_of_iff _ !any_iff_exists
|
|
|
|
|
|
2015-08-07 20:13:39 -04:00
|
|
|
|
/- properties -/
|
|
|
|
|
|
|
|
|
|
theorem inj_on_to_set {B : Type} [h : decidable_eq B] (f : A → B) (s : finset A) :
|
|
|
|
|
inj_on f s = inj_on f (ts s) :=
|
|
|
|
|
rfl
|
|
|
|
|
|
2015-05-10 17:44:58 +10:00
|
|
|
|
end finset
|