Nominal-General/nominal_library.ML
author Christian Urban <urbanc@in.tum.de>
Tue, 17 Aug 2010 17:52:25 +0800
changeset 2407 49ab06c0ca64
parent 2399 107c06267f33
child 2408 f1980f89c405
permissions -rw-r--r--
improved code
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
(*  Title:      nominal_library.ML
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
    Author:     Christian Urban
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
     4
  Basic functions for nominal.
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
*)
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
signature NOMINAL_LIBRARY =
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
sig
2313
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
     9
  val last2: 'a list -> 'a * 'a
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
    10
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    11
  val dest_listT: typ -> typ
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    12
2399
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    13
  val size_const: typ -> term 
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    14
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
  val mk_minus: term -> term
1896
996d4411e95e tuned; fleshed out some library functions about permutations; closed Datatype_Aux structure (increases readability)
Christian Urban <urbanc@in.tum.de>
parents: 1871
diff changeset
    16
  val mk_plus: term -> term -> term
996d4411e95e tuned; fleshed out some library functions about permutations; closed Datatype_Aux structure (increases readability)
Christian Urban <urbanc@in.tum.de>
parents: 1871
diff changeset
    17
1899
8e0bfb14f6bf optimised the code of define_raw_perm
Christian Urban <urbanc@in.tum.de>
parents: 1896
diff changeset
    18
  val perm_ty: typ -> typ 
1871
c704d129862b moved some general function into nominal_library.ML
Christian Urban <urbanc@in.tum.de>
parents: 1834
diff changeset
    19
  val mk_perm_ty: typ -> term -> term -> term
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
  val mk_perm: term -> term -> term
1834
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
    21
  val dest_perm: term -> term * term
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
    22
1962
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    23
  val mk_sort_of: term -> term
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    24
  val atom_ty: typ -> typ
1962
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    25
  val mk_atom_ty: typ -> term -> term
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    26
  val mk_atom: term -> term
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    27
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    28
  val supp_ty: typ -> typ
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
    29
  val supp_const: typ -> term
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    30
  val mk_supp_ty: typ -> term -> term
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    31
  val mk_supp: term -> term
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    32
1834
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
    33
  val mk_equiv: thm -> thm
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
    34
  val safe_mk_equiv: thm -> thm
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    35
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
    36
  val mk_diff: term * term -> term
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
    37
  val mk_append: term * term -> term
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
    38
  val mk_union: term * term -> term
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
    39
  val fold_union: term list -> term
2389
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
    40
  val mk_conj: term * term -> term
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
    41
  val fold_conj: term list -> term
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
    42
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    43
  (* datatype operations *)
2407
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
    44
  type cns_info = (term * typ * typ list * bool list) list
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
    45
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
    46
  val all_dtyps: Datatype_Aux.descr -> (string * sort) list -> typ list
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    47
  val nth_dtyp: Datatype_Aux.descr -> (string * sort) list -> int -> typ
2407
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
    48
  val all_dtyp_constrs_types: Datatype_Aux.descr -> (string * sort) list -> cns_info list
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
    49
  val nth_dtyp_constrs_types: Datatype_Aux.descr -> (string * sort) list -> int -> cns_info
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    50
  val prefix_dt_names: Datatype_Aux.descr -> (string * sort) list -> string -> string list
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    51
2304
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
    52
  (* tactics for function package *)
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
    53
  val pat_completeness_auto: Proof.context -> tactic
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
    54
  val pat_completeness_simp: thm list -> Proof.context -> tactic
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
    55
  val prove_termination: Proof.context -> Function.info * local_theory
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
    56
2311
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
    57
  (* transformations of premises in inductions *)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
    58
  val transform_prem1: Proof.context -> string list -> thm -> thm
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
    59
  val transform_prem2: Proof.context -> string list -> thm -> thm
2397
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
    60
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
    61
  (* transformation into the object logic *)
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
    62
  val atomize: thm -> thm
2398
1e6160690546 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2397
diff changeset
    63
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    64
end
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    65
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    66
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    67
structure Nominal_Library: NOMINAL_LIBRARY =
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    68
struct
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    69
2313
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
    70
fun last2 [] = raise Empty
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
    71
  | last2 [_] = raise Empty
2375
e163fd99de44 minor polishing
Christian Urban <urbanc@in.tum.de>
parents: 2313
diff changeset
    72
  | last2 [x, y] = (x, y)
2313
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
    73
  | last2 (_ :: xs) = last2 xs
25d2cdf7d7e4 transitivity proofs done
Christian Urban <urbanc@in.tum.de>
parents: 2311
diff changeset
    74
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    75
fun dest_listT (Type (@{type_name list}, [T])) = T
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    76
  | dest_listT T = raise TYPE ("dest_listT: list type expected", [T], [])
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
    77
2399
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    78
fun size_const ty = Const (@{const_name size}, ty --> @{typ nat})
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    79
2399
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    80
fun mk_minus p = @{term "uminus::perm => perm"} $ p
1896
996d4411e95e tuned; fleshed out some library functions about permutations; closed Datatype_Aux structure (increases readability)
Christian Urban <urbanc@in.tum.de>
parents: 1871
diff changeset
    81
2399
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    82
fun mk_plus p q = @{term "plus::perm => perm => perm"} $ p $ q
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    83
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    84
fun perm_ty ty = @{typ "perm"} --> ty --> ty
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    85
fun mk_perm_ty ty p trm = Const (@{const_name "permute"}, perm_ty ty) $ p $ trm
107c06267f33 simplified code
Christian Urban <urbanc@in.tum.de>
parents: 2398
diff changeset
    86
fun mk_perm p trm = mk_perm_ty (fastype_of trm) p trm
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    87
1834
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
    88
fun dest_perm (Const (@{const_name "permute"}, _) $ p $ t) = (p, t)
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    89
  | dest_perm t = raise TERM ("dest_perm", [t]);
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    90
1962
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    91
fun mk_sort_of t = @{term "sort_of"} $ t;
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    92
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    93
fun atom_ty ty = ty --> @{typ "atom"};
1963
0c9ef14e9ba4 some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1962
diff changeset
    94
fun mk_atom_ty ty t = Const (@{const_name "atom"}, atom_ty ty) $ t;
1962
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    95
fun mk_atom t = mk_atom_ty (fastype_of t) t;
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
    96
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    97
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
    98
fun supp_ty ty = ty --> @{typ "atom set"};
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
    99
fun supp_const ty = Const (@{const_name "supp"}, supp_ty ty)
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   100
fun mk_supp_ty ty t = supp_const ty $ t;
1979
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
   101
fun mk_supp t = mk_supp_ty (fastype_of t) t;
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
   102
760257a66604 added basic functions for constructing supp-terms
Christian Urban <urbanc@in.tum.de>
parents: 1963
diff changeset
   103
1834
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
   104
fun mk_equiv r = r RS @{thm eq_reflection};
9909cc3566c5 moved a couple of more functions to the library
Christian Urban <urbanc@in.tum.de>
parents: 1833
diff changeset
   105
fun safe_mk_equiv r = mk_equiv r handle Thm.THM _ => r;
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   106
1962
84a13d1e2511 moved mk_atom into the library; that meant that concrete atom classes need to be in Nominal2_Base
Christian Urban <urbanc@in.tum.de>
parents: 1899
diff changeset
   107
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   108
(* functions that construct differences, appends and unions
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   109
   but avoid producing empty atom sets or empty atom lists *)
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   110
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   111
fun mk_diff (@{term "{}::atom set"}, _) = @{term "{}::atom set"}
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   112
  | mk_diff (t1, @{term "{}::atom set"}) = t1
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   113
  | mk_diff (t1, t2) = HOLogic.mk_binop @{const_name minus} (t1, t2)
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   114
2389
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   115
fun mk_append (t1, @{term "[]::atom list"}) = t1
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   116
  | mk_append (@{term "[]::atom list"}, t2) = t2
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   117
  | mk_append (t1, t2) = HOLogic.mk_binop @{const_name "append"} (t1, t2) 
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   118
2389
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   119
fun mk_union (t1, @{term "{}::atom set"}) = t1
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   120
  | mk_union (@{term "{}::atom set"}, t2) = t2
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   121
  | mk_union (t1, t2) = HOLogic.mk_binop @{const_name "sup"} (t1, t2)  
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   122
 
2384
841b7e34e70a fixed order of fold_union to make alpha and fv agree
Christian Urban <urbanc@in.tum.de>
parents: 2375
diff changeset
   123
fun fold_union trms = fold_rev (curry mk_union) trms @{term "{}::atom set"}
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   124
2389
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   125
fun mk_conj (t1, @{term "True"}) = t1
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   126
  | mk_conj (@{term "True"}, t2) = t2
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   127
  | mk_conj (t1, t2) = HOLogic.mk_conj (t1, t2)
2289
bf748be70109 moved some mk_union and mk_diff into the library
Christian Urban <urbanc@in.tum.de>
parents: 2288
diff changeset
   128
2389
0f24c961b5f6 introduced a general alpha_prove method
Christian Urban <urbanc@in.tum.de>
parents: 2384
diff changeset
   129
fun fold_conj trms = fold_rev (curry mk_conj) trms @{term "True"}
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   130
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   131
(** datatypes **)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   132
2407
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
   133
(* constructor infos *)
49ab06c0ca64 improved code
Christian Urban <urbanc@in.tum.de>
parents: 2399
diff changeset
   134
type cns_info = (term * typ * typ list * bool list) list
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   135
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   136
(* returns the type of the nth datatype *)
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   137
fun all_dtyps descr sorts = 
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   138
  map (fn n => Datatype_Aux.typ_of_dtyp descr sorts (Datatype_Aux.DtRec n)) (0 upto (length descr - 1))
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   139
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   140
fun nth_dtyp descr sorts n = 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   141
  Datatype_Aux.typ_of_dtyp descr sorts (Datatype_Aux.DtRec n);
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   142
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   143
(* returns info about constructors in a datatype *)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   144
fun all_dtyp_constrs_info descr = 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   145
  map (fn (_, (ty, vs, constrs)) => map (pair (ty, vs)) constrs) descr
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   146
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   147
(* returns the constants of the constructors plus the 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   148
   corresponding type and types of arguments *)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   149
fun all_dtyp_constrs_types descr sorts = 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   150
let
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   151
  fun aux ((ty_name, vs), (cname, args)) =
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   152
  let
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   153
    val vs_tys = map (Datatype_Aux.typ_of_dtyp descr sorts) vs
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   154
    val ty = Type (ty_name, vs_tys)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   155
    val arg_tys = map (Datatype_Aux.typ_of_dtyp descr sorts) args
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   156
    val is_rec = map Datatype_Aux.is_rec_type args
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   157
  in
2296
45a69c9cc4cc alpha works now
Christian Urban <urbanc@in.tum.de>
parents: 2289
diff changeset
   158
    (Const (cname, arg_tys ---> ty), ty, arg_tys, is_rec)
2288
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   159
  end
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   160
in
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   161
  map (map aux) (all_dtyp_constrs_info descr)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   162
end
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   163
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   164
fun nth_dtyp_constrs_types descr sorts n =
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   165
  nth (all_dtyp_constrs_types descr sorts) n
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   166
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   167
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   168
(* generates for every datatype a name str ^ dt_name 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   169
   plus and index for multiple occurences of a string *)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   170
fun prefix_dt_names descr sorts str = 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   171
let
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   172
  fun get_nth_name (i, _) = 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   173
    Datatype_Aux.name_of_typ (nth_dtyp descr sorts i) 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   174
in
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   175
  Datatype_Prop.indexify_names 
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   176
    (map (prefix str o get_nth_name) descr)
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   177
end
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   178
3b83960f9544 new fv/fv_bn function (supp breaks now); exported raw perms and raw funs into separate ML-files
Christian Urban <urbanc@in.tum.de>
parents: 1979
diff changeset
   179
2311
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   180
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   181
(** function package tactics **)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   182
2304
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   183
fun pat_completeness_auto lthy =
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   184
  Pat_Completeness.pat_completeness_tac lthy 1
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   185
    THEN auto_tac (clasimpset_of lthy)
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   186
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   187
fun pat_completeness_simp simps lthy =
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   188
let
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   189
  val simp_set = HOL_basic_ss addsimps (@{thms sum.inject sum.distinct} @ simps)
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   190
in
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   191
  Pat_Completeness.pat_completeness_tac lthy 1
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   192
    THEN ALLGOALS (asm_full_simp_tac simp_set)
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   193
end
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   194
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   195
fun prove_termination lthy =
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   196
  Function.prove_termination NONE
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   197
    (Lexicographic_Order.lexicographic_order_tac true lthy) lthy
8a98171ba1fc all raw definitions are defined using function
Christian Urban <urbanc@in.tum.de>
parents: 2296
diff changeset
   198
2311
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   199
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   200
(** transformations of premises (in inductive proofs) **)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   201
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   202
(* 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   203
 given the theorem F[t]; proves the theorem F[f t] 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   204
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   205
  - F needs to be monotone
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   206
  - f returns either SOME for a term it fires on 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   207
    and NONE elsewhere 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   208
*)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   209
fun map_term f t = 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   210
  (case f t of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   211
     NONE => map_term' f t 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   212
   | x => x)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   213
and map_term' f (t $ u) = 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   214
    (case (map_term f t, map_term f u) of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   215
        (NONE, NONE) => NONE
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   216
      | (SOME t'', NONE) => SOME (t'' $ u)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   217
      | (NONE, SOME u'') => SOME (t $ u'')
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   218
      | (SOME t'', SOME u'') => SOME (t'' $ u''))
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   219
  | map_term' f (Abs (s, T, t)) = 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   220
      (case map_term f t of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   221
        NONE => NONE
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   222
      | SOME t'' => SOME (Abs (s, T, t'')))
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   223
  | map_term' _ _  = NONE;
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   224
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   225
fun map_thm_tac ctxt tac thm =
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   226
let
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   227
  val monos = Inductive.get_monos ctxt
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   228
  val simps = HOL_basic_ss addsimps @{thms split_def}
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   229
in
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   230
  EVERY [cut_facts_tac [thm] 1, etac rev_mp 1, 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   231
    REPEAT_DETERM (FIRSTGOAL (simp_tac simps THEN' resolve_tac monos)),
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   232
    REPEAT_DETERM (rtac impI 1 THEN (atac 1 ORELSE tac))]
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   233
end
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   234
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   235
fun map_thm ctxt f tac thm =
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   236
let
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   237
  val opt_goal_trm = map_term f (prop_of thm)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   238
in
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   239
  case opt_goal_trm of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   240
    NONE => thm
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   241
  | SOME goal =>
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   242
     Goal.prove ctxt [] [] goal (fn _ => map_thm_tac ctxt tac thm) 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   243
end
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   244
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   245
(*
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   246
 inductive premises can be of the form
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   247
 R ... /\ P ...; split_conj_i picks out
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   248
 the part R or P part
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   249
*)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   250
fun split_conj1 names (Const ("op &", _) $ f1 $ f2) = 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   251
  (case head_of f1 of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   252
     Const (name, _) => if member (op =) names name then SOME f1 else NONE
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   253
   | _ => NONE)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   254
| split_conj1 _ _ = NONE;
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   255
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   256
fun split_conj2 names (Const ("op &", _) $ f1 $ f2) = 
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   257
  (case head_of f1 of
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   258
     Const (name, _) => if member (op =) names name then SOME f2 else NONE
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   259
   | _ => NONE)
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   260
| split_conj2 _ _ = NONE;
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   261
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   262
fun transform_prem1 ctxt names thm =
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   263
  map_thm ctxt (split_conj1 names) (etac conjunct1 1) thm
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   264
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   265
fun transform_prem2 ctxt names thm =
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   266
  map_thm ctxt (split_conj2 names) (etac conjunct2 1) thm
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   267
4da5c5c29009 work on transitivity proof
Christian Urban <urbanc@in.tum.de>
parents: 2304
diff changeset
   268
2397
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
   269
(* transformes a theorem into one of the object logic *)
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
   270
val atomize = Conv.fconv_rule Object_Logic.atomize o forall_intr_vars
c670a849af65 more experiments with lifting
Christian Urban <urbanc@in.tum.de>
parents: 2389
diff changeset
   271
1833
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   272
end (* structure *)
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   273
2050b5723c04 added a library for basic nominal functions; separated nominal_eqvt file
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   274
open Nominal_Library;