src/HOL/Relation_Power.thy
author wenzelm
Thu, 03 Apr 2008 16:03:57 +0200
changeset 26527 c392354a1b79
parent 26072 f65a7fa2da6c
child 26799 5bd38256ce5b
permissions -rw-r--r--
Symbol.STX, Symbol.DEL;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/Relation_Power.thy
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
     2
    ID:         $Id$
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
     4
    Copyright   1996  TU Muenchen
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
     5
*)
11306
6f4ed75b2dca added comments
nipkow
parents: 11305
diff changeset
     6
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
     7
header{*Powers of Relations and Functions*}
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
     8
15131
c69542757a4d New theory header syntax.
nipkow
parents: 15112
diff changeset
     9
theory Relation_Power
26072
f65a7fa2da6c <= and < on nat no longer depend on wellfounded relations
haftmann
parents: 25861
diff changeset
    10
imports Power Transitive_Closure
15131
c69542757a4d New theory header syntax.
nipkow
parents: 15112
diff changeset
    11
begin
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
    12
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
    13
instance
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    14
  set :: (type) power ..
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    15
      --{* only type @{typ "('a * 'a) set"} should be in class @{text power}!*}
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
    16
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    17
overloading
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    18
  relpow \<equiv> "power \<Colon> ('a \<times> 'a) set \<Rightarrow> nat \<Rightarrow> ('a \<times> 'a) set"  (unchecked)
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    19
begin
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    20
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    21
text {* @{text "R ^ n = R O ... O R"}, the n-fold composition of @{text R} *}
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
    22
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    23
primrec relpow where
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    24
  "(R \<Colon> ('a \<times> 'a) set)  ^ 0 = Id"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    25
  | "(R \<Colon> ('a \<times> 'a) set) ^ Suc n = R O (R ^ n)"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    26
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    27
end
11305
2ce86fccc95b added ^ on functions.
nipkow
parents: 10213
diff changeset
    28
11306
6f4ed75b2dca added comments
nipkow
parents: 11305
diff changeset
    29
instance
21414
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    30
  "fun" :: (type, type) power ..
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    31
      --{* only type @{typ "'a => 'a"} should be in class @{text power}!*}
11305
2ce86fccc95b added ^ on functions.
nipkow
parents: 10213
diff changeset
    32
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    33
overloading
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    34
  funpow \<equiv> "power \<Colon>  ('a \<Rightarrow> 'a) \<Rightarrow> nat \<Rightarrow> 'a \<Rightarrow> 'a" (unchecked)
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    35
begin
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    36
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    37
text {* @{text "f ^ n = f o ... o f"}, the n-fold composition of @{text f} *}
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    38
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    39
primrec funpow where
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    40
  "(f \<Colon> 'a \<Rightarrow> 'a) ^ 0 = id"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    41
  | "(f \<Colon> 'a \<Rightarrow> 'a) ^ Suc n = f o (f ^ n)"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    42
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    43
end
11305
2ce86fccc95b added ^ on functions.
nipkow
parents: 10213
diff changeset
    44
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    45
text{*WARNING: due to the limits of Isabelle's type classes, exponentiation on
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    46
functions and relations has too general a domain, namely @{typ "('a * 'b)set"}
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    47
and @{typ "'a => 'b"}.  Explicit type constraints may therefore be necessary.
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    48
For example, @{term "range(f^n) = A"} and @{term "Range(R^n) = B"} need
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    49
constraints.*}
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    50
21414
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    51
text {*
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    52
  Circumvent this problem for code generation:
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    53
*}
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    54
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    55
primrec
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    56
  fun_pow :: "nat \<Rightarrow> ('a \<Rightarrow> 'a) \<Rightarrow> 'a \<Rightarrow> 'a"
22737
haftmann
parents: 21414
diff changeset
    57
where
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    58
  "fun_pow 0 f = id"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    59
  | "fun_pow (Suc n) f = f o fun_pow n f"
21414
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    60
25861
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    61
lemma funpow_fun_pow [code inline]: "f ^ n = fun_pow n f"
494d9301cc75 refined overloading target
haftmann
parents: 25295
diff changeset
    62
  unfolding funpow_def fun_pow_def ..
21414
4cb808163adc workaround for definition violating type discipline
haftmann
parents: 20503
diff changeset
    63
15112
6f0772a94299 added a thm
nipkow
parents: 12338
diff changeset
    64
lemma funpow_add: "f ^ (m+n) = f^m o f^n"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    65
  by (induct m) simp_all
15112
6f0772a94299 added a thm
nipkow
parents: 12338
diff changeset
    66
18049
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    67
lemma funpow_swap1: "f((f^n) x) = (f^n)(f x)"
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    68
proof -
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    69
  have "f((f^n) x) = (f^(n+1)) x" by simp
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    70
  also have "\<dots>  = (f^n o f^1) x" by (simp only: funpow_add)
18049
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    71
  also have "\<dots> = (f^n)(f x)" by simp
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    72
  finally show ?thesis .
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    73
qed
156bba334c12 A few new lemmas
nipkow
parents: 15410
diff changeset
    74
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    75
lemma rel_pow_1 [simp]:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    76
  fixes R :: "('a*'a)set"
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    77
  shows "R^1 = R"
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    78
  by simp
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    79
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    80
lemma rel_pow_0_I: "(x,x) : R^0"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    81
  by simp
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    82
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    83
lemma rel_pow_Suc_I: "[| (x,y) : R^n; (y,z):R |] ==> (x,z):R^(Suc n)"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    84
  by auto
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    85
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    86
lemma rel_pow_Suc_I2:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    87
    "(x, y) : R \<Longrightarrow> (y, z) : R^n \<Longrightarrow> (x,z) : R^(Suc n)"
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18398
diff changeset
    88
  apply (induct n arbitrary: z)
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    89
   apply simp
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    90
  apply fastsimp
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    91
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    92
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    93
lemma rel_pow_0_E: "[| (x,y) : R^0; x=y ==> P |] ==> P"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    94
  by simp
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    95
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    96
lemma rel_pow_Suc_E:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    97
    "[| (x,z) : R^(Suc n);  !!y. [| (x,y) : R^n; (y,z) : R |] ==> P |] ==> P"
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
    98
  by auto
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
    99
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   100
lemma rel_pow_E:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   101
    "[| (x,z) : R^n;  [| n=0; x = z |] ==> P;
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   102
        !!y m. [| n = Suc m; (x,y) : R^m; (y,z) : R |] ==> P
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   103
     |] ==> P"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   104
  by (cases n) auto
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   105
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   106
lemma rel_pow_Suc_D2:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   107
    "(x, z) : R^(Suc n) \<Longrightarrow> (\<exists>y. (x,y) : R & (y,z) : R^n)"
20503
503ac4c5ef91 induct method: renamed 'fixing' to 'arbitrary';
wenzelm
parents: 18398
diff changeset
   108
  apply (induct n arbitrary: x z)
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   109
   apply (blast intro: rel_pow_0_I elim: rel_pow_0_E rel_pow_Suc_E)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   110
  apply (blast intro: rel_pow_Suc_I elim: rel_pow_0_E rel_pow_Suc_E)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   111
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   112
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   113
lemma rel_pow_Suc_D2':
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   114
    "\<forall>x y z. (x,y) : R^n & (y,z) : R --> (\<exists>w. (x,w) : R & (w,z) : R^n)"
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   115
  by (induct n) (simp_all, blast)
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   116
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   117
lemma rel_pow_E2:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   118
    "[| (x,z) : R^n;  [| n=0; x = z |] ==> P;
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   119
        !!y m. [| n = Suc m; (x,y) : R; (y,z) : R^m |] ==> P
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   120
     |] ==> P"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   121
  apply (case_tac n, simp)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   122
  apply (cut_tac n=nat and R=R in rel_pow_Suc_D2', simp, blast)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   123
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   124
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   125
lemma rtrancl_imp_UN_rel_pow: "!!p. p:R^* ==> p : (UN n. R^n)"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   126
  apply (simp only: split_tupled_all)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   127
  apply (erule rtrancl_induct)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   128
   apply (blast intro: rel_pow_0_I rel_pow_Suc_I)+
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   129
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   130
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   131
lemma rel_pow_imp_rtrancl: "!!p. p:R^n ==> p:R^*"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   132
  apply (simp only: split_tupled_all)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   133
  apply (induct n)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   134
   apply (blast intro: rtrancl_refl elim: rel_pow_0_E)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   135
  apply (blast elim: rel_pow_Suc_E intro: rtrancl_into_rtrancl)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   136
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   137
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   138
lemma rtrancl_is_UN_rel_pow: "R^* = (UN n. R^n)"
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   139
  by (blast intro: rtrancl_imp_UN_rel_pow rel_pow_imp_rtrancl)
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   140
25295
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   141
lemma trancl_power:
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   142
  "x \<in> r^+ = (\<exists>n > 0. x \<in> r^n)"
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   143
  apply (cases x)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   144
  apply simp
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   145
  apply (rule iffI)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   146
   apply (drule tranclD2)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   147
   apply (clarsimp simp: rtrancl_is_UN_rel_pow)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   148
   apply (rule_tac x="Suc x" in exI)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   149
   apply (clarsimp simp: rel_comp_def)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   150
   apply fastsimp
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   151
  apply clarsimp
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   152
  apply (case_tac n, simp)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   153
  apply clarsimp
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   154
  apply (drule rel_pow_imp_rtrancl)
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   155
  apply fastsimp
12985023be5e tranclD2 (tranclD at the other end) + trancl_power
kleing
parents: 24996
diff changeset
   156
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   157
18398
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   158
lemma single_valued_rel_pow:
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   159
    "!!r::('a * 'a)set. single_valued r ==> single_valued (r^n)"
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   160
  apply (rule single_valuedI)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   161
  apply (induct n)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   162
   apply simp
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   163
  apply (fast dest: single_valuedD elim: rel_pow_Suc_E)
5d63a8b35688 tuned proofs;
wenzelm
parents: 18049
diff changeset
   164
  done
15410
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   165
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   166
ML
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   167
{*
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   168
val funpow_add = thm "funpow_add";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   169
val rel_pow_1 = thm "rel_pow_1";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   170
val rel_pow_0_I = thm "rel_pow_0_I";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   171
val rel_pow_Suc_I = thm "rel_pow_Suc_I";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   172
val rel_pow_Suc_I2 = thm "rel_pow_Suc_I2";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   173
val rel_pow_0_E = thm "rel_pow_0_E";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   174
val rel_pow_Suc_E = thm "rel_pow_Suc_E";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   175
val rel_pow_E = thm "rel_pow_E";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   176
val rel_pow_Suc_D2 = thm "rel_pow_Suc_D2";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   177
val rel_pow_Suc_D2 = thm "rel_pow_Suc_D2";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   178
val rel_pow_E2 = thm "rel_pow_E2";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   179
val rtrancl_imp_UN_rel_pow = thm "rtrancl_imp_UN_rel_pow";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   180
val rel_pow_imp_rtrancl = thm "rel_pow_imp_rtrancl";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   181
val rtrancl_is_UN_rel_pow = thm "rtrancl_is_UN_rel_pow";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   182
val single_valued_rel_pow = thm "single_valued_rel_pow";
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   183
*}
18914688a5fd converted Relation_Power to new-style theory
paulson
parents: 15140
diff changeset
   184
10213
01c2744a3786 *** empty log message ***
nipkow
parents:
diff changeset
   185
end