src/HOL/Real/Lubs.thy
 author wenzelm Fri, 02 Jun 2006 23:22:29 +0200 changeset 19765 dfe940911617 parent 15140 322485b816ac child 21404 eb85850d3eb7 permissions -rw-r--r--
misc cleanup;
```
(*  Title       : Lubs.thy
ID          : \$Id\$
Author      : Jacques D. Fleuriot
Copyright   : 1998  University of Cambridge
*)

header{*Definitions of Upper Bounds and Least Upper Bounds*}

theory Lubs
imports Main
begin

text{*Thanks to suggestions by James Margetson*}

definition

setle :: "['a set, 'a::ord] => bool"     (infixl "*<=" 70)
"S *<= x = (ALL y: S. y <= x)"

setge :: "['a::ord, 'a set] => bool"     (infixl "<=*" 70)
"x <=* S = (ALL y: S. x <= y)"

leastP      :: "['a =>bool,'a::ord] => bool"
"leastP P x = (P x & x <=* Collect P)"

isUb        :: "['a set, 'a set, 'a::ord] => bool"
"isUb R S x = (S *<= x & x: R)"

isLub       :: "['a set, 'a set, 'a::ord] => bool"
"isLub R S x = leastP (isUb R S) x"

ubs         :: "['a set, 'a::ord set] => 'a set"
"ubs R S = Collect (isUb R S)"

subsection{*Rules for the Relations @{text "*<="} and @{text "<=*"}*}

lemma setleI: "ALL y: S. y <= x ==> S *<= x"

lemma setleD: "[| S *<= x; y: S |] ==> y <= x"

lemma setgeI: "ALL y: S. x<= y ==> x <=* S"

lemma setgeD: "[| x <=* S; y: S |] ==> x <= y"

subsection{*Rules about the Operators @{term leastP}, @{term ub}
and @{term lub}*}

lemma leastPD1: "leastP P x ==> P x"

lemma leastPD2: "leastP P x ==> x <=* Collect P"

lemma leastPD3: "[| leastP P x; y: Collect P |] ==> x <= y"
by (blast dest!: leastPD2 setgeD)

lemma isLubD1: "isLub R S x ==> S *<= x"
by (simp add: isLub_def isUb_def leastP_def)

lemma isLubD1a: "isLub R S x ==> x: R"
by (simp add: isLub_def isUb_def leastP_def)

lemma isLub_isUb: "isLub R S x ==> isUb R S x"
apply (blast dest: isLubD1 isLubD1a)
done

lemma isLubD2: "[| isLub R S x; y : S |] ==> y <= x"
by (blast dest!: isLubD1 setleD)

lemma isLubD3: "isLub R S x ==> leastP(isUb R S) x"

lemma isLubI1: "leastP(isUb R S) x ==> isLub R S x"

lemma isLubI2: "[| isUb R S x; x <=* Collect (isUb R S) |] ==> isLub R S x"

lemma isUbD: "[| isUb R S x; y : S |] ==> y <= x"

lemma isUbD2: "isUb R S x ==> S *<= x"

lemma isUbD2a: "isUb R S x ==> x: R"

lemma isUbI: "[| S *<= x; x: R |] ==> isUb R S x"