Built with Alectryon, running Coq+SerAPI v8.10.0+0.7.0. Coq sources are in this panel; goals and messages will appear in the other. Bubbles () indicate interactive fragments: hover for details, tap to reveal contents. Use Ctrl+↑ Ctrl+↓ to navigate, Ctrl+🖱️ to focus.
(************************************************************************)
(*         *   The Coq Proof Assistant / The Coq Development Team       *)
(*  v      *   INRIA, CNRS and contributors - Copyright 1999-2018       *)
(* <O___,, *       (see CREDITS file for the list of authors)           *)
(*   \VV/  **************************************************************)
(*    //   *    This file is distributed under the terms of the         *)
(*         *     GNU Lesser General Public License Version 2.1          *)
(*         *     (see LICENSE file for the text of the license)         *)
(************************************************************************)

Finite sets library : conversion to old Finite_sets

Require Import Ensembles Finite_sets.
Require Import FSetInterface FSetProperties OrderedTypeEx DecidableTypeEx.

Going from FSets with usual Leibniz equality

to the good old Ensembles and Finite_sets theory.
Module WS_to_Finite_set (U:UsualDecidableType)(M: WSfun U).
 Module MP:= WProperties_fun U M.
 Import M MP FM Ensembles Finite_sets.

 Definition mkEns : M.t -> Ensemble M.elt :=
   fun s x => M.In x s.

 Notation " !! " := mkEns.

 

forall (s : t) (x : elt), M.In x s <-> In elt (!! s) x

forall (s : t) (x : elt), M.In x s <-> In elt (!! s) x
unfold In; compute; auto with extcore. Qed.

forall s s' : t, s [<=] s' <-> Included elt (!! s) (!! s')

forall s s' : t, s [<=] s' <-> Included elt (!! s) (!! s')
unfold Subset, Included, In, mkEns; intuition. Qed. Notation " a === b " := (Same_set M.elt a b) (at level 70, no associativity).

forall s s' : t, s [=] s' <-> !! s === !! s'

forall s s' : t, s [=] s' <-> !! s === !! s'
s, s':t

s [=] s' <-> !! s === !! s'
s, s':t

s [<=] s' /\ s' [<=] s <-> !! s === !! s'
unfold Subset, Included, Same_set, In, mkEns; intuition. Qed.

!! empty === Empty_set elt

!! empty === Empty_set elt

(forall x : elt, M.In x empty -> Empty_set elt x) /\ (forall x : elt, Empty_set elt x -> M.In x empty)
split; intro; set_iff; inversion 1. Qed.

forall s : t, Empty s -> !! s === Empty_set elt

forall s : t, Empty s -> !! s === Empty_set elt

forall s : t, Empty s -> (forall x : elt, M.In x s -> Empty_set elt x) /\ (forall x : elt, Empty_set elt x -> M.In x s)
s:t
H:Empty s
x:elt
H0:M.In x s

Empty_set elt x
s:t
H:Empty s
x:elt
H0:Empty_set elt x
M.In x s
s:t
H:Empty s
x:elt
H0:Empty_set elt x

M.In x s
inversion H0. Qed.

forall x : elt, !! (singleton x) === Singleton elt x

forall x : elt, !! (singleton x) === Singleton elt x

forall x : elt, (forall x0 : elt, M.In x0 (singleton x) -> Singleton elt x x0) /\ (forall x0 : elt, Singleton elt x x0 -> M.In x0 (singleton x))
split; intro; set_iff; inversion 1; try constructor; auto. Qed.

forall s s' : t, !! (union s s') === Union elt (!! s) (!! s')

forall s s' : t, !! (union s s') === Union elt (!! s) (!! s')

forall s s' : t, (forall x : elt, M.In x (union s s') -> Union elt (fun x0 : elt => M.In x0 s) (fun x0 : elt => M.In x0 s') x) /\ (forall x : elt, Union elt (fun x0 : elt => M.In x0 s) (fun x0 : elt => M.In x0 s') x -> M.In x (union s s'))
split; intro; set_iff; inversion 1; [ constructor 1 | constructor 2 | | ]; auto. Qed.

forall s s' : t, !! (inter s s') === Intersection elt (!! s) (!! s')

forall s s' : t, !! (inter s s') === Intersection elt (!! s) (!! s')

forall s s' : t, (forall x : elt, M.In x (inter s s') -> Intersection elt (fun x0 : elt => M.In x0 s) (fun x0 : elt => M.In x0 s') x) /\ (forall x : elt, Intersection elt (fun x0 : elt => M.In x0 s) (fun x0 : elt => M.In x0 s') x -> M.In x (inter s s'))
split; intro; set_iff; inversion 1; try constructor; auto. Qed.

forall (x : elt) (s : t), !! (add x s) === Add elt (!! s) x

forall (x : elt) (s : t), !! (add x s) === Add elt (!! s) x

forall (x : elt) (s : t), (forall x0 : elt, M.In x0 (add x s) -> Add elt (fun x1 : elt => M.In x1 s) x x0) /\ (forall x0 : elt, Add elt (fun x1 : elt => M.In x1 s) x x0 -> M.In x0 (add x s))
x:elt
s:t
x0:elt
H:x = x0 \/ M.In x0 s
H0:x = x0

Add elt (fun x1 : elt => M.In x1 s) x x0
x:elt
s:t
x0:elt
H:x = x0 \/ M.In x0 s
H0:M.In x0 s
Add elt (fun x1 : elt => M.In x1 s) x x0
x:elt
s:t
x0:elt
H:x = x0 \/ M.In x0 s
H0, H1:x = x0

Add elt (fun x1 : elt => M.In x1 s) x0 x0
x:elt
s:t
x0:elt
H:x = x0 \/ M.In x0 s
H0:M.In x0 s
Add elt (fun x1 : elt => M.In x1 s) x x0
x:elt
s:t
x0:elt
H:x = x0 \/ M.In x0 s
H0:M.In x0 s

Add elt (fun x1 : elt => M.In x1 s) x x0
constructor 1; auto. Qed.

forall (x : U.t) (s s' : t), MP.Add x s s' -> !! s' === Add elt (!! s) x

forall (x : U.t) (s s' : t), MP.Add x s s' -> !! s' === Add elt (!! s) x

forall (x : U.t) (s s' : t), MP.Add x s s' -> (forall x0 : elt, M.In x0 s' -> Add elt (fun x1 : elt => M.In x1 s) x x0) /\ (forall x0 : elt, Add elt (fun x1 : elt => M.In x1 s) x x0 -> M.In x0 s')
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:M.In x0 s'

Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0
M.In x0 s'
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:x = x0 \/ M.In x0 s

Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0
M.In x0 s'
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:x = x0

Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:M.In x0 s
Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0
M.In x0 s'
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0, H1:x = x0

Add elt (fun x1 : elt => M.In x1 s) x0 x0
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:M.In x0 s
Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0
M.In x0 s'
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:M.In x0 s

Add elt (fun x1 : elt => M.In x1 s) x x0
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0
M.In x0 s'
x:U.t
s, s':t
H:MP.Add x s s'
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0

M.In x0 s'
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:Add elt (fun x1 : elt => M.In x1 s) x x0

x = x0 \/ M.In x0 s
x:U.t
s, s':t
H:forall y : elt, M.In y s' <-> x = y \/ M.In y s
x0:elt
H0:Add elt (fun x2 : elt => M.In x2 s) x x0
x1:elt
H1:In elt (Singleton elt x) x0
H2:x1 = x0

x = x0 \/ M.In x0 s
inversion H1; auto. Qed.

forall (x : elt) (s : t), !! (remove x s) === Subtract elt (!! s) x

forall (x : elt) (s : t), !! (remove x s) === Subtract elt (!! s) x

forall (x : elt) (s : t), (forall x0 : elt, M.In x0 (remove x s) -> Subtract elt (fun x1 : elt => M.In x1 s) x x0) /\ (forall x0 : elt, Subtract elt (fun x1 : elt => M.In x1 s) x x0 -> M.In x0 (remove x s))
x:elt
s:t
x0:elt
H:M.In x0 s /\ x <> x0
H0:M.In x0 s
H1:x <> x0

Subtract elt (fun x1 : elt => M.In x1 s) x x0
x:elt
s:t
x0:elt
H:M.In x0 s /\ x <> x0
H0:M.In x0 s
H1:x <> x0

~ In elt (Singleton elt x) x0
x:elt
s:t
x0:elt
H:M.In x0 s /\ x <> x0
H0:M.In x0 s
H1:In elt (Singleton elt x) x0

x = x0
inversion H1; auto. Qed.

forall s : t, Finite elt (!! s)

forall s : t, Finite elt (!! s)
s:t
H:Empty s

Finite elt (!! s)
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
Finite elt (!! s')
s:t
H:Empty s

Empty_set elt = !! s
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
Finite elt (!! s')
s:t
H:Empty s

!! s === Empty_set elt
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
Finite elt (!! s')
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

Finite elt (!! s')
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

Finite elt (Add elt (!! s) x)
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
Add elt (!! s) x = !! s'
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

Add elt (!! s) x = !! s'
s, s':t
H:Finite elt (!! s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

!! s' === Add elt (!! s) x
apply Add_Add; auto. Qed.

forall s : t, cardinal elt (!! s) (M.cardinal s)

forall s : t, cardinal elt (!! s) (M.cardinal s)
s:t
H:Empty s

cardinal elt (!! s) (M.cardinal s)
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
cardinal elt (!! s') (M.cardinal s')
s:t
H:Empty s

cardinal elt (Empty_set elt) (M.cardinal s)
s:t
H:Empty s
Empty_set elt = !! s
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
cardinal elt (!! s') (M.cardinal s')
s:t
H:Empty s

Empty_set elt = !! s
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
cardinal elt (!! s') (M.cardinal s')
s:t
H:Empty s

!! s === Empty_set elt
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
cardinal elt (!! s') (M.cardinal s')
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

cardinal elt (!! s') (M.cardinal s')
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

cardinal elt (Add elt (!! s) x) (M.cardinal s')
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'
Add elt (!! s) x = !! s'
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

Add elt (!! s) x = !! s'
s, s':t
H:cardinal elt (!! s) (M.cardinal s)
x:elt
H0:~ M.In x s
H1:MP.Add x s s'

!! s' === Add elt (!! s) x
apply Add_Add; auto. Qed.
we can even build a function from Finite Ensemble to FSet ... at least in Prop.
 

forall e : Ensemble elt, Finite elt e -> exists s : t, !! s === e

forall e : Ensemble elt, Finite elt e -> exists s : t, !! s === e

exists s : t, !! s === Empty_set elt
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
IHFinite:exists s : t, !! s === A
exists s : t, !! s === Add elt A x

!! empty === Empty_set elt
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
IHFinite:exists s : t, !! s === A
exists s : t, !! s === Add elt A x
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
IHFinite:exists s : t, !! s === A

exists s : t, !! s === Add elt A x
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
s:t
Hs:!! s === A

exists s0 : t, !! s0 === Add elt A x
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
s:t
Hs:!! s === A

!! (add x s) === Add elt A x
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
s:t
Hs:!! s = A

!! (add x s) === Add elt A x
A:Ensemble elt
H:Finite elt A
x:elt
H0:~ In elt A x
s:t
Hs:!! s = A

!! (add x s) === Add elt (!! s) x
apply add_Add. Qed. End WS_to_Finite_set. Module S_to_Finite_set (U:UsualOrderedType)(M: Sfun U) := WS_to_Finite_set U M.