Attic/Quot/quotient_term.ML
author Christian Urban <urbanc@in.tum.de>
Tue, 24 Jan 2012 16:51:01 +0000
changeset 3112 e4050732ba15
parent 2317 7412424213ec
permissions -rw-r--r--
tuned make-file
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1438
61671de8a545 synchronised with main hg-repository; used add_typedef_global in nominal_atoms
Christian Urban <urbanc@in.tum.de>
parents: 1260
diff changeset
     1
(*  Title:      HOL/Tools/Quotient/quotient_term.thy
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
     2
    Author:     Cezary Kaliszyk and Christian Urban
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
     3
1438
61671de8a545 synchronised with main hg-repository; used add_typedef_global in nominal_atoms
Christian Urban <urbanc@in.tum.de>
parents: 1260
diff changeset
     4
Constructs terms corresponding to goals from lifting theorems to
61671de8a545 synchronised with main hg-repository; used add_typedef_global in nominal_atoms
Christian Urban <urbanc@in.tum.de>
parents: 1260
diff changeset
     5
quotient types.
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
     6
*)
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
     7
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
signature QUOTIENT_TERM =
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
sig
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    10
  datatype flag = AbsF | RepF
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    11
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    12
  val absrep_fun: flag -> Proof.context -> typ * typ -> term
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    13
  val absrep_fun_chk: flag -> Proof.context -> typ * typ -> term
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    14
974
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
    15
  (* Allows Nitpick to represent quotient types as single elements from raw type *)
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
    16
  val absrep_const_chk: flag -> Proof.context -> string -> term
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
    17
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    18
  val equiv_relation: Proof.context -> typ * typ -> term
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    19
  val equiv_relation_chk: Proof.context -> typ * typ -> term
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
    20
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    21
  val regularize_trm: Proof.context -> term * term -> term
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    22
  val regularize_trm_chk: Proof.context -> term * term -> term
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    23
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    24
  val inj_repabs_trm: Proof.context -> term * term -> term
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
    25
  val inj_repabs_trm_chk: Proof.context -> term * term -> term
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
    26
1188
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
    27
  val quotient_lift_const: string * term -> local_theory -> term
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
    28
  val quotient_lift_all: Proof.context -> term -> term
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
end;
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    31
structure Quotient_Term: QUOTIENT_TERM =
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    32
struct
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
762
baac4639ecef avoided global "open"s - replaced by local "open"s
Christian Urban <urbanc@in.tum.de>
parents: 761
diff changeset
    34
open Quotient_Info;
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    35
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    36
exception LIFT_MATCH of string
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    37
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
    38
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
    39
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
    40
(*** Aggregate Rep/Abs Function ***)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
    41
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
    42
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    43
(* The flag RepF is for types in negative position; AbsF is for types
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    44
   in positive position. Because of this, function types need to be
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    45
   treated specially, since there the polarity changes.
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    46
*)
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    47
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    48
datatype flag = AbsF | RepF
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    49
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    50
fun negF AbsF = RepF
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    51
  | negF RepF = AbsF
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    52
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    53
fun is_identity (Const (@{const_name "id"}, _)) = true
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    54
  | is_identity _ = false
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    55
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    56
fun mk_identity ty = Const (@{const_name "id"}, ty --> ty)
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    57
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    58
fun mk_fun_compose flag (trm1, trm2) =
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    59
  case flag of
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    60
    AbsF => Const (@{const_name "comp"}, dummyT) $ trm1 $ trm2
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
    61
  | RepF => Const (@{const_name "comp"}, dummyT) $ trm2 $ trm1
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    62
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    63
fun get_mapfun ctxt s =
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    64
let
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
    65
  val thy = ProofContext.theory_of ctxt
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
    66
  val exn = error ("No map function for type " ^ quote s ^ " found.")
1100
2fb07e01c57b 'exc' -> 'exn' and more name and space cleaning.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1099
diff changeset
    67
  val mapfun = #mapfun (maps_lookup thy s) handle Quotient_Info.NotFound => raise exn
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    68
in
784
da75568e7f12 renamed some fields in the info records
Christian Urban <urbanc@in.tum.de>
parents: 783
diff changeset
    69
  Const (mapfun, dummyT)
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    70
end
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
    71
800
71225f4a4635 some slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 797
diff changeset
    72
(* makes a Free out of a TVar *)
71225f4a4635 some slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 797
diff changeset
    73
fun mk_Free (TVar ((x, i), _)) = Free (unprefix "'" x ^ string_of_int i, dummyT)
71225f4a4635 some slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 797
diff changeset
    74
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    75
(* produces an aggregate map function for the
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    76
   rty-part of a quotient definition; abstracts
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    77
   over all variables listed in vs (these variables
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    78
   correspond to the type variables in rty)
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    79
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    80
   for example for: (?'a list * ?'b)
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    81
   it produces:     %a b. prod_map (map a) b
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    82
*)
803
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    83
fun mk_mapfun ctxt vs rty =
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    84
let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    85
  val vs' = map (mk_Free) vs
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    86
803
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    87
  fun mk_mapfun_aux rty =
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    88
    case rty of
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    89
      TVar _ => mk_Free rty
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    90
    | Type (_, []) => mk_identity rty
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    91
    | Type (s, tys) => list_comb (get_mapfun ctxt s, map mk_mapfun_aux tys)
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
    92
    | _ => raise (error "mk_mapfun (default)")
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    93
in
803
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
    94
  fold_rev Term.lambda vs' (mk_mapfun_aux rty)
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    95
end
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
    96
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    97
(* looks up the (varified) rty and qty for
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
    98
   a quotient definition
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
    99
*)
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   100
fun get_rty_qty ctxt s =
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   101
let
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   102
  val thy = ProofContext.theory_of ctxt
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   103
  val exn = error ("No quotient type " ^ quote s ^ " found.")
1100
2fb07e01c57b 'exc' -> 'exn' and more name and space cleaning.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1099
diff changeset
   104
  val qdata = (quotdata_lookup thy s) handle Quotient_Info.NotFound => raise exn
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   105
in
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   106
  (#rtyp qdata, #qtyp qdata)
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   107
end
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   108
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   109
(* takes two type-environments and looks
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   110
   up in both of them the variable v, which
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   111
   must be listed in the environment
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   112
*)
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   113
fun double_lookup rtyenv qtyenv v =
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   114
let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   115
  val v' = fst (dest_TVar v)
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   116
in
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   117
  (snd (the (Vartab.lookup rtyenv v')), snd (the (Vartab.lookup qtyenv v')))
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   118
end
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   119
832
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   120
(* matches a type pattern with a type *)
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   121
fun match ctxt err ty_pat ty =
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   122
let
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   123
  val thy = ProofContext.theory_of ctxt
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   124
in
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   125
  Sign.typ_match thy (ty_pat, ty) Vartab.empty
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   126
  handle MATCH_TYPE => err ctxt ty_pat ty
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   127
end
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   128
800
71225f4a4635 some slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 797
diff changeset
   129
(* produces the rep or abs constant for a qty *)
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   130
fun absrep_const flag ctxt qty_str =
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   131
let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   132
  val thy = ProofContext.theory_of ctxt
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   133
  val qty_name = Long_Name.base_name qty_str
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   134
in
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   135
  case flag of
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
   136
    AbsF => Const (Sign.full_bname thy ("abs_" ^ qty_name), dummyT)
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
   137
  | RepF => Const (Sign.full_bname thy ("rep_" ^ qty_name), dummyT)
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   138
end
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   139
974
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
   140
(* Lets Nitpick represent elements of quotient types as elements of the raw type *)
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
   141
fun absrep_const_chk flag ctxt qty_str =
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
   142
  Syntax.check_term ctxt (absrep_const flag ctxt qty_str)
d44fda0cf393 Recommited the changes for nitpick
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 959
diff changeset
   143
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   144
fun absrep_match_err ctxt ty_pat ty =
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   145
let
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   146
  val ty_pat_str = Syntax.string_of_typ ctxt ty_pat
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   147
  val ty_str = Syntax.string_of_typ ctxt ty
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   148
in
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   149
  raise error (cat_lines
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   150
    ["absrep_fun (Types ", quote ty_pat_str, "and", quote ty_str, " do not match.)"])
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   151
end
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   152
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   153
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   154
(** generation of an aggregate absrep function **)
791
fb4bfbb1a291 commeted the absrep function
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   155
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   156
(* - In case of equal types we just return the identity.
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   157
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   158
   - In case of TFrees we also return the identity.
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   159
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   160
   - In case of function types we recurse taking
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   161
     the polarity change into account.
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   162
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   163
   - If the type constructors are equal, we recurse for the
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   164
     arguments and build the appropriate map function.
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   165
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   166
   - If the type constructors are unequal, there must be an
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   167
     instance of quotient types:
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   168
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   169
       - we first look up the corresponding rty_pat and qty_pat
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   170
         from the quotient definition; the arguments of qty_pat
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   171
         must be some distinct TVars
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   172
       - we then match the rty_pat with rty and qty_pat with qty;
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   173
         if matching fails the types do not correspond -> error
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   174
       - the matching produces two environments; we look up the
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   175
         assignments for the qty_pat variables and recurse on the
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   176
         assignments
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   177
       - we prefix the aggregate map function for the rty_pat,
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   178
         which is an abstraction over all type variables
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   179
       - finally we compose the result with the appropriate
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   180
         absrep function in case at least one argument produced
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   181
         a non-identity function /
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   182
         otherwise we just return the appropriate absrep
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   183
         function
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   184
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   185
     The composition is necessary for types like
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   186
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   187
        ('a list) list / ('a foo) foo
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   188
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   189
     The matching is necessary for types like
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   190
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   191
        ('a * 'a) list / 'a bar
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   192
858
Christian Urban <urbanc@in.tum.de>
parents: 856
diff changeset
   193
     The test is necessary in order to eliminate superfluous
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   194
     identity maps.
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   195
*)
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   196
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   197
fun absrep_fun flag ctxt (rty, qty) =
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   198
  if rty = qty
803
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
   199
  then mk_identity rty
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   200
  else
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   201
    case (rty, qty) of
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   202
      (Type ("fun", [ty1, ty2]), Type ("fun", [ty1', ty2'])) =>
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   203
        let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   204
          val arg1 = absrep_fun (negF flag) ctxt (ty1, ty1')
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   205
          val arg2 = absrep_fun flag ctxt (ty2, ty2')
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   206
        in
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   207
          list_comb (get_mapfun ctxt "fun", [arg1, arg2])
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   208
        end
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   209
    | (Type (s, tys), Type (s', tys')) =>
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   210
        if s = s'
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   211
        then
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   212
           let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   213
             val args = map (absrep_fun flag ctxt) (tys ~~ tys')
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   214
           in
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   215
             list_comb (get_mapfun ctxt s, args)
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   216
           end
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   217
        else
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   218
           let
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   219
             val (rty_pat, qty_pat as Type (_, vs)) = get_rty_qty ctxt s'
832
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   220
             val rtyenv = match ctxt absrep_match_err rty_pat rty
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   221
             val qtyenv = match ctxt absrep_match_err qty_pat qty
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   222
             val args_aux = map (double_lookup rtyenv qtyenv) vs
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   223
             val args = map (absrep_fun flag ctxt) args_aux
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   224
             val map_fun = mk_mapfun ctxt vs rty_pat
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   225
             val result = list_comb (map_fun, args)
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   226
           in
2317
Christian Urban <urbanc@in.tum.de>
parents: 1450
diff changeset
   227
             (*if forall is_identity args
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   228
             then absrep_const flag ctxt s'
2317
Christian Urban <urbanc@in.tum.de>
parents: 1450
diff changeset
   229
             else*) mk_fun_compose flag (absrep_const flag ctxt s', result)
830
89d772dae4d4 New_relations, all works again including concat examples.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 826
diff changeset
   230
           end
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   231
    | (TFree x, TFree x') =>
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   232
        if x = x'
803
6f6ee78c7357 a slight change to abs/rep generation
Christian Urban <urbanc@in.tum.de>
parents: 801
diff changeset
   233
        then mk_identity rty
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   234
        else raise (error "absrep_fun (frees)")
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 786
diff changeset
   235
    | (TVar _, TVar _) => raise (LIFT_MATCH "absrep_fun (vars)")
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   236
    | _ => raise (error "absrep_fun (default)")
774
b4ffb8826105 moved get_fun into quotient_term; this simplifies the overall including structure of the package
Christian Urban <urbanc@in.tum.de>
parents: 762
diff changeset
   237
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   238
fun absrep_fun_chk flag ctxt (rty, qty) =
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   239
  absrep_fun flag ctxt (rty, qty)
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   240
  |> Syntax.check_term ctxt
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   241
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   242
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   243
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   244
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   245
(*** Aggregate Equivalence Relation ***)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   246
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   247
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   248
(* works very similar to the absrep generation,
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   249
   except there is no need for polarities
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   250
*)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   251
783
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   252
(* instantiates TVars so that the term is of type ty *)
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   253
fun force_typ ctxt trm ty =
783
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   254
let
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   255
  val thy = ProofContext.theory_of ctxt
783
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   256
  val trm_ty = fastype_of trm
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   257
  val ty_inst = Sign.typ_match thy (trm_ty, ty) Vartab.empty
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   258
in
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   259
  map_types (Envir.subst_type ty_inst) trm
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   260
end
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   261
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   262
fun is_eq (Const (@{const_name "op ="}, _)) = true
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   263
  | is_eq _ = false
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   264
825
970e86082cd7 Modifictaions for new_relation.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 808
diff changeset
   265
fun mk_rel_compose (trm1, trm2) =
1438
61671de8a545 synchronised with main hg-repository; used add_typedef_global in nominal_atoms
Christian Urban <urbanc@in.tum.de>
parents: 1260
diff changeset
   266
  Const (@{const_abbrev "rel_conj"}, dummyT) $ trm1 $ trm2
807
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   267
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   268
fun get_relmap ctxt s =
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   269
let
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   270
  val thy = ProofContext.theory_of ctxt
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   271
  val exn = error ("get_relmap (no relation map function found for type " ^ s ^ ")")
1100
2fb07e01c57b 'exc' -> 'exn' and more name and space cleaning.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1099
diff changeset
   272
  val relmap = #relmap (maps_lookup thy s) handle Quotient_Info.NotFound => raise exn
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   273
in
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   274
  Const (relmap, dummyT)
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   275
end
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   276
807
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   277
fun mk_relmap ctxt vs rty =
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   278
let
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   279
  val vs' = map (mk_Free) vs
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   280
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   281
  fun mk_relmap_aux rty =
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   282
    case rty of
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   283
      TVar _ => mk_Free rty
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   284
    | Type (_, []) => HOLogic.eq_const rty
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   285
    | Type (s, tys) => list_comb (get_relmap ctxt s, map mk_relmap_aux tys)
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   286
    | _ => raise (error "mk_relmap (default)")
807
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   287
in
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   288
  fold_rev Term.lambda vs' (mk_relmap_aux rty)
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   289
end
a5495a323b49 added a new version of equiv_relation (is not yet used anywhere except in AbsRepTest)
Christian Urban <urbanc@in.tum.de>
parents: 804
diff changeset
   290
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   291
fun get_equiv_rel ctxt s =
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   292
let
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   293
  val thy = ProofContext.theory_of ctxt
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   294
  val exn = error ("get_quotdata (no quotient found for type " ^ s ^ ")")
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   295
in
1100
2fb07e01c57b 'exc' -> 'exn' and more name and space cleaning.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1099
diff changeset
   296
  #equiv_rel (quotdata_lookup thy s) handle Quotient_Info.NotFound => raise exn
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   297
end
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   298
808
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   299
fun equiv_match_err ctxt ty_pat ty =
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   300
let
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   301
  val ty_pat_str = Syntax.string_of_typ ctxt ty_pat
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   302
  val ty_str = Syntax.string_of_typ ctxt ty
808
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   303
in
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   304
  raise error (space_implode " "
808
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   305
    ["equiv_relation (Types ", quote ty_pat_str, "and", quote ty_str, " do not match.)"])
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   306
end
90bde96f5dd1 proper handling of error messages (code copy - maybe this can be avoided)
Christian Urban <urbanc@in.tum.de>
parents: 807
diff changeset
   307
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   308
(* builds the aggregate equivalence relation
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   309
   that will be the argument of Respects
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   310
*)
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   311
fun equiv_relation ctxt (rty, qty) =
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   312
  if rty = qty
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   313
  then HOLogic.eq_const rty
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   314
  else
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   315
    case (rty, qty) of
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   316
      (Type (s, tys), Type (s', tys')) =>
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   317
       if s = s'
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   318
       then
761
e2ac18492c68 small tuning
Christian Urban <urbanc@in.tum.de>
parents: 760
diff changeset
   319
         let
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   320
           val args = map (equiv_relation ctxt) (tys ~~ tys')
761
e2ac18492c68 small tuning
Christian Urban <urbanc@in.tum.de>
parents: 760
diff changeset
   321
         in
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   322
           list_comb (get_relmap ctxt s, args)
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   323
         end
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   324
       else
784
da75568e7f12 renamed some fields in the info records
Christian Urban <urbanc@in.tum.de>
parents: 783
diff changeset
   325
         let
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   326
           val (rty_pat, qty_pat as Type (_, vs)) = get_rty_qty ctxt s'
832
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   327
           val rtyenv = match ctxt equiv_match_err rty_pat rty
b3bb2bad952f introduced separate match function
Christian Urban <urbanc@in.tum.de>
parents: 831
diff changeset
   328
           val qtyenv = match ctxt equiv_match_err qty_pat qty
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   329
           val args_aux = map (double_lookup rtyenv qtyenv) vs
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   330
           val args = map (equiv_relation ctxt) args_aux
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   331
           val rel_map = mk_relmap ctxt vs rty_pat
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   332
           val result = list_comb (rel_map, args)
792
Christian Urban <urbanc@in.tum.de>
parents: 791
diff changeset
   333
           val eqv_rel = get_equiv_rel ctxt s'
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   334
           val eqv_rel' = force_typ ctxt eqv_rel ([rty, rty] ---> @{typ bool})
761
e2ac18492c68 small tuning
Christian Urban <urbanc@in.tum.de>
parents: 760
diff changeset
   335
         in
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   336
           if forall is_eq args
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   337
           then eqv_rel'
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   338
           else mk_rel_compose (result, eqv_rel')
761
e2ac18492c68 small tuning
Christian Urban <urbanc@in.tum.de>
parents: 760
diff changeset
   339
         end
783
06e17083e90b modified mk_resp_arg so that the user can give terms as equivalence relations, not just constants
Christian Urban <urbanc@in.tum.de>
parents: 782
diff changeset
   340
      | _ => HOLogic.eq_const rty
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   341
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   342
fun equiv_relation_chk ctxt (rty, qty) =
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   343
  equiv_relation ctxt (rty, qty)
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   344
  |> Syntax.check_term ctxt
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   345
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   346
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   347
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   348
(*** Regularization ***)
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   349
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   350
(* Regularizing an rtrm means:
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   351
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   352
 - Quantifiers over types that need lifting are replaced
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   353
   by bounded quantifiers, for example:
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   354
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   355
      All P  ----> All (Respects R) P
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   356
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   357
   where the aggregate relation R is given by the rty and qty;
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   358
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   359
 - Abstractions over types that need lifting are replaced
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   360
   by bounded abstractions, for example:
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   361
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   362
      %x. P  ----> Ball (Respects R) %x. P
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   363
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   364
 - Equalities over types that need lifting are replaced by
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   365
   corresponding equivalence relations, for example:
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   366
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   367
      A = B  ----> R A B
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   368
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
   369
   or
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   370
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   371
      A = B  ----> (R ===> R) A B
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
   372
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   373
   for more complicated types of A and B
955
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   374
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   375
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   376
 The regularize_trm accepts raw theorems in which equalities
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   377
 and quantifiers match exactly the ones in the lifted theorem
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   378
 but also accepts partially regularized terms.
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   379
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   380
 This means that the raw theorems can have:
982
54faefa53745 End of renaming.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 974
diff changeset
   381
   Ball (Respects R),  Bex (Respects R), Bex1_rel (Respects R), Babs, R
955
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   382
 in the places where:
959
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   383
   All, Ex, Ex1, %, (op =)
955
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   384
 is required the lifted theorem.
da270d122965 Commenting regularize
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 952
diff changeset
   385
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   386
*)
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   387
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   388
val mk_babs = Const (@{const_name Babs}, dummyT)
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   389
val mk_ball = Const (@{const_name Ball}, dummyT)
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   390
val mk_bex  = Const (@{const_name Bex}, dummyT)
999
64874975f087 renamed function according to the name of the constant
Christian Urban <urbanc@in.tum.de>
parents: 982
diff changeset
   391
val mk_bex1_rel = Const (@{const_name Bex1_rel}, dummyT)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   392
val mk_resp = Const (@{const_name Respects}, dummyT)
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   393
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   394
(* - applies f to the subterm of an abstraction,
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   395
     otherwise to the given term,
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   396
   - used by regularize, therefore abstracted
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   397
     variables do not have to be treated specially
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   398
*)
775
Christian Urban <urbanc@in.tum.de>
parents: 774
diff changeset
   399
fun apply_subt f (trm1, trm2) =
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   400
  case (trm1, trm2) of
775
Christian Urban <urbanc@in.tum.de>
parents: 774
diff changeset
   401
    (Abs (x, T, t), Abs (_ , _, t')) => Abs (x, T, f (t, t'))
Christian Urban <urbanc@in.tum.de>
parents: 774
diff changeset
   402
  | _ => f (trm1, trm2)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   403
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   404
fun term_mismatch str ctxt t1 t2 =
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   405
let
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   406
  val t1_str = Syntax.string_of_term ctxt t1
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   407
  val t2_str = Syntax.string_of_term ctxt t2
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   408
  val t1_ty_str = Syntax.string_of_typ ctxt (fastype_of t1)
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   409
  val t2_ty_str = Syntax.string_of_typ ctxt (fastype_of t2)
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   410
in
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   411
  raise error (cat_lines [str, t1_str ^ "::" ^ t1_ty_str, t2_str ^ "::" ^ t2_ty_str])
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   412
end
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   413
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   414
(* the major type of All and Ex quantifiers *)
853
3fd1365f5729 More indenting, bracket removing and comment restructuring.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 849
diff changeset
   415
fun qnt_typ ty = domain_type (domain_type ty)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   416
867
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   417
(* Checks that two types match, for example:
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   418
     rty -> rty   matches   qty -> qty *)
875
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   419
fun matches_typ thy rT qT =
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   420
  if rT = qT then true else
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   421
  case (rT, qT) of
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   422
    (Type (rs, rtys), Type (qs, qtys)) =>
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   423
      if rs = qs then
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   424
        if length rtys <> length qtys then false else
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   425
        forall (fn x => x = true) (map2 (matches_typ thy) rtys qtys)
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   426
      else
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   427
        (case Quotient_Info.quotdata_lookup_raw thy qs of
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   428
          SOME quotinfo => Sign.typ_instance thy (rT, #rtyp quotinfo)
cc951743c5e2 Simplified matches_typ.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 867
diff changeset
   429
        | NONE => false)
867
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   430
  | _ => false
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   431
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   432
856
Christian Urban <urbanc@in.tum.de>
parents: 854 853
diff changeset
   433
(* produces a regularized version of rtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   434
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   435
   - the result might contain dummyTs
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   436
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   437
   - for regularisation we do not need any
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   438
     special treatment of bound variables
854
5961edda27d7 absrep_fun and equiv_relation do not produce anymore spurious maps; two problems arose in IntEx, which are marked with "INJECTION PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 836
diff changeset
   439
*)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   440
fun regularize_trm ctxt (rtrm, qtrm) =
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   441
  case (rtrm, qtrm) of
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   442
    (Abs (x, ty, t), Abs (_, ty', t')) =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   443
       let
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   444
         val subtrm = Abs(x, ty, regularize_trm ctxt (t, t'))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   445
       in
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   446
         if ty = ty' then subtrm
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   447
         else mk_babs $ (mk_resp $ equiv_relation ctxt (ty, ty')) $ subtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   448
       end
1000
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   449
  | (Const (@{const_name "Babs"}, T) $ resrel $ (t as (Abs (_, ty, _))), t' as (Abs (_, ty', _))) =>
959
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   450
       let
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   451
         val subtrm = regularize_trm ctxt (t, t')
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   452
         val needres = mk_resp $ equiv_relation_chk ctxt (ty, ty')
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   453
       in
1000
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   454
         if resrel <> needres
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   455
         then term_mismatch "regularize (Babs)" ctxt resrel needres
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   456
         else mk_babs $ resrel $ subtrm
959
1786aa86e52b When commenting discovered a missing case of Babs->Abs regularization.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 956
diff changeset
   457
       end
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   458
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   459
  | (Const (@{const_name "All"}, ty) $ t, Const (@{const_name "All"}, ty') $ t') =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   460
       let
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   461
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   462
       in
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   463
         if ty = ty' then Const (@{const_name "All"}, ty) $ subtrm
831
224909b9399f removed obsolete equiv_relation and rnamed new_equiv_relation
Christian Urban <urbanc@in.tum.de>
parents: 830
diff changeset
   464
         else mk_ball $ (mk_resp $ equiv_relation ctxt (qnt_typ ty, qnt_typ ty')) $ subtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   465
       end
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   466
953
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   467
  | (Const (@{const_name "Ex"}, ty) $ t, Const (@{const_name "Ex"}, ty') $ t') =>
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   468
       let
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   469
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   470
       in
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   471
         if ty = ty' then Const (@{const_name "Ex"}, ty) $ subtrm
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   472
         else mk_bex $ (mk_resp $ equiv_relation ctxt (qnt_typ ty, qnt_typ ty')) $ subtrm
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   473
       end
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   474
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   475
  | (Const (@{const_name "Ex1"}, ty) $ (Abs (_, _,
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   476
      (Const (@{const_name "op &"}, _) $ (Const (@{const_name "op :"}, _) $ _ $
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   477
        (Const (@{const_name "Respects"}, _) $ resrel)) $ (t $ _)))),
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   478
     Const (@{const_name "Ex1"}, ty') $ t') =>
1074
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   479
       let
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   480
         val t_ = incr_boundvars (~1) t
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   481
         val subtrm = apply_subt (regularize_trm ctxt) (t_, t')
1074
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   482
         val needrel = equiv_relation_chk ctxt (qnt_typ ty, qnt_typ ty')
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   483
       in
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   484
         if resrel <> needrel
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   485
         then term_mismatch "regularize (Bex1)" ctxt resrel needrel
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   486
         else mk_bex1_rel $ resrel $ subtrm
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   487
       end
7a42cc191111 Fixes for Bex1 removal.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   488
953
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   489
  | (Const (@{const_name "Ex1"}, ty) $ t, Const (@{const_name "Ex1"}, ty') $ t') =>
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   490
       let
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   491
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   492
       in
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   493
         if ty = ty' then Const (@{const_name "Ex1"}, ty) $ subtrm
999
64874975f087 renamed function according to the name of the constant
Christian Urban <urbanc@in.tum.de>
parents: 982
diff changeset
   494
         else mk_bex1_rel $ (equiv_relation ctxt (qnt_typ ty, qnt_typ ty')) $ subtrm
953
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   495
       end
1235336f4661 reordered cases in regularize (will be merged into two cases)
Christian Urban <urbanc@in.tum.de>
parents: 952
diff changeset
   496
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   497
  | (Const (@{const_name "Ball"}, ty) $ (Const (@{const_name "Respects"}, _) $ resrel) $ t,
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   498
     Const (@{const_name "All"}, ty') $ t') =>
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   499
       let
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   500
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   501
         val needrel = equiv_relation_chk ctxt (qnt_typ ty, qnt_typ ty')
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   502
       in
904
4f5512569468 Better error messages for non matching quantifiers.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 891
diff changeset
   503
         if resrel <> needrel
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   504
         then term_mismatch "regularize (Ball)" ctxt resrel needrel
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   505
         else mk_ball $ (mk_resp $ resrel) $ subtrm
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   506
       end
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   507
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   508
  | (Const (@{const_name "Bex"}, ty) $ (Const (@{const_name "Respects"}, _) $ resrel) $ t,
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   509
     Const (@{const_name "Ex"}, ty') $ t') =>
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   510
       let
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   511
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   512
         val needrel = equiv_relation_chk ctxt (qnt_typ ty, qnt_typ ty')
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   513
       in
904
4f5512569468 Better error messages for non matching quantifiers.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 891
diff changeset
   514
         if resrel <> needrel
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   515
         then term_mismatch "regularize (Bex)" ctxt resrel needrel
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   516
         else mk_bex $ (mk_resp $ resrel) $ subtrm
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   517
       end
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   518
982
54faefa53745 End of renaming.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 974
diff changeset
   519
  | (Const (@{const_name "Bex1_rel"}, ty) $ resrel $ t, Const (@{const_name "Ex1"}, ty') $ t') =>
906
a394c7337966 Ex1 -> Bex1 Regularization, Preparing Exeq.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 904
diff changeset
   520
       let
a394c7337966 Ex1 -> Bex1 Regularization, Preparing Exeq.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 904
diff changeset
   521
         val subtrm = apply_subt (regularize_trm ctxt) (t, t')
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   522
         val needrel = equiv_relation_chk ctxt (qnt_typ ty, qnt_typ ty')
906
a394c7337966 Ex1 -> Bex1 Regularization, Preparing Exeq.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 904
diff changeset
   523
       in
a394c7337966 Ex1 -> Bex1 Regularization, Preparing Exeq.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 904
diff changeset
   524
         if resrel <> needrel
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   525
         then term_mismatch "regularize (Bex1_res)" ctxt resrel needrel
999
64874975f087 renamed function according to the name of the constant
Christian Urban <urbanc@in.tum.de>
parents: 982
diff changeset
   526
         else mk_bex1_rel $ resrel $ subtrm
946
46cc6708c3b3 Bex1_Bexeq_regular.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 944
diff changeset
   527
       end
46cc6708c3b3 Bex1_Bexeq_regular.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 944
diff changeset
   528
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   529
  | (* equalities need to be replaced by appropriate equivalence relations *)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   530
    (Const (@{const_name "op ="}, ty), Const (@{const_name "op ="}, ty')) =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   531
         if ty = ty' then rtrm
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   532
         else equiv_relation ctxt (domain_type ty, domain_type ty')
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   533
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   534
  | (* in this case we just check whether the given equivalence relation is correct *)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   535
    (rel, Const (@{const_name "op ="}, ty')) =>
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   536
       let
785
Christian Urban <urbanc@in.tum.de>
parents: 784
diff changeset
   537
         val rel_ty = fastype_of rel
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   538
         val rel' = equiv_relation_chk ctxt (domain_type rel_ty, domain_type ty')
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   539
       in
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   540
         if rel' aconv rel then rtrm
952
9c3b3eaecaff use of equiv_relation_chk in quotient_term
Christian Urban <urbanc@in.tum.de>
parents: 946
diff changeset
   541
         else term_mismatch "regularise (relation mismatch)" ctxt rel rel'
865
5c6d76c3ba5c Put relation_error as a separate function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 858
diff changeset
   542
       end
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   543
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   544
  | (_, Const _) =>
835
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   545
       let
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   546
         val thy = ProofContext.theory_of ctxt
867
9e247b9505f0 Moved the matches_typ function outside a?d simplified it.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 865
diff changeset
   547
         fun same_const (Const (s, T)) (Const (s', T')) = (s = s') andalso matches_typ thy T T'
835
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   548
           | same_const _ _ = false
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   549
       in
835
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   550
         if same_const rtrm qtrm then rtrm
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   551
         else
c4fa87dd0208 Fix for testing matching constants in regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 834
diff changeset
   552
           let
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   553
             val rtrm' = #rconst (qconsts_lookup thy qtrm)
1099
fe3f227a59cd Fully qualified exception names.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1098
diff changeset
   554
               handle Quotient_Info.NotFound => term_mismatch "regularize(constant notfound)" ctxt rtrm qtrm
891
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   555
           in
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   556
             if Pattern.matches thy (rtrm', rtrm)
7bac7dffadeb hom lifted to hom', so it is true. Infrastructure for partially regularized quantifiers. Nicer errors for regularize.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 890
diff changeset
   557
             then rtrm else term_mismatch "regularize(constant mismatch)" ctxt rtrm qtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   558
           end
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   559
       end
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   560
1000
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   561
  | (((t1 as Const (@{const_name "split"}, _)) $ Abs (v1, ty, Abs(v1', ty', s1))),
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   562
     ((t2 as Const (@{const_name "split"}, _)) $ Abs (v2, _ , Abs(v2', _  , s2)))) =>
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   563
       regularize_trm ctxt (t1, t2) $ Abs (v1, ty, Abs (v1', ty', regularize_trm ctxt (s1, s2)))
944
6267ad688ea8 2 cases for regularize with split, lemmas with split now lift.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 909
diff changeset
   564
1000
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   565
  | (((t1 as Const (@{const_name "split"}, _)) $ Abs (v1, ty, s1)),
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   566
     ((t2 as Const (@{const_name "split"}, _)) $ Abs (v2, _ , s2))) =>
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   567
       regularize_trm ctxt (t1, t2) $ Abs (v1, ty, regularize_trm ctxt (s1, s2))
944
6267ad688ea8 2 cases for regularize with split, lemmas with split now lift.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 909
diff changeset
   568
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   569
  | (t1 $ t2, t1' $ t2') =>
1000
1893316b9ef8 slight tuning
Christian Urban <urbanc@in.tum.de>
parents: 999
diff changeset
   570
       regularize_trm ctxt (t1, t1') $ regularize_trm ctxt (t2, t2')
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   571
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   572
  | (Bound i, Bound i') =>
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   573
       if i = i' then rtrm
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   574
       else raise (error "regularize (bounds mismatch)")
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   575
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   576
  | _ =>
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   577
       let
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   578
         val rtrm_str = Syntax.string_of_term ctxt rtrm
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   579
         val qtrm_str = Syntax.string_of_term ctxt qtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   580
       in
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   581
         raise (error ("regularize failed (default: " ^ rtrm_str ^ "," ^ qtrm_str ^ ")"))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   582
       end
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   583
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   584
fun regularize_trm_chk ctxt (rtrm, qtrm) =
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   585
  regularize_trm ctxt (rtrm, qtrm)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   586
  |> Syntax.check_term ctxt
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   587
797
35436401f00d added a functor that allows checking what is added to the theorem lists
Christian Urban <urbanc@in.tum.de>
parents: 796
diff changeset
   588
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   589
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   590
(*** Rep/Abs Injection ***)
795
a28f805df355 renamed mk_resp_arg to equiv_relation and exported it in the signature; added tests in AbsRepFun.thy
Christian Urban <urbanc@in.tum.de>
parents: 792
diff changeset
   591
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   592
(*
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   593
Injection of Rep/Abs means:
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   594
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   595
  For abstractions:
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   596
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   597
  * If the type of the abstraction needs lifting, then we add Rep/Abs
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   598
    around the abstraction; otherwise we leave it unchanged.
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   599
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   600
  For applications:
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   601
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   602
  * If the application involves a bounded quantifier, we recurse on
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   603
    the second argument. If the application is a bounded abstraction,
782
86c7ed9f354f cleaed a bit function mk_typedef_main
Christian Urban <urbanc@in.tum.de>
parents: 779
diff changeset
   604
    we always put an Rep/Abs around it (since bounded abstractions
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   605
    are assumed to always need lifting). Otherwise we recurse on both
782
86c7ed9f354f cleaed a bit function mk_typedef_main
Christian Urban <urbanc@in.tum.de>
parents: 779
diff changeset
   606
    arguments.
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   607
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   608
  For constants:
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   609
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   610
  * If the constant is (op =), we leave it always unchanged.
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   611
    Otherwise the type of the constant needs lifting, we put
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   612
    and Rep/Abs around it.
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   613
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   614
  For free variables:
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   615
797
35436401f00d added a functor that allows checking what is added to the theorem lists
Christian Urban <urbanc@in.tum.de>
parents: 796
diff changeset
   616
  * We put a Rep/Abs around it if the type needs lifting.
760
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   617
c1989de100b4 various tunings; map_lookup now raises an exception; addition to FIXME-TODO
Christian Urban <urbanc@in.tum.de>
parents: 758
diff changeset
   618
  Vars case cannot occur.
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   619
*)
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   620
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   621
fun mk_repabs ctxt (T, T') trm =
1097
551eacf071d7 More indentation, names and todo cleaning in the quotient package
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1090
diff changeset
   622
  absrep_fun RepF ctxt (T, T') $ (absrep_fun AbsF ctxt (T, T') $ trm)
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   623
833
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   624
fun inj_repabs_err ctxt msg rtrm qtrm =
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   625
let
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   626
  val rtrm_str = Syntax.string_of_term ctxt rtrm
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   627
  val qtrm_str = Syntax.string_of_term ctxt qtrm
833
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   628
in
1450
1ae5afcddcd4 another synchronisation
Christian Urban <urbanc@in.tum.de>
parents: 1438
diff changeset
   629
  raise error (space_implode " " [msg, quote rtrm_str, "and", quote qtrm_str])
833
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   630
end
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   631
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   632
849
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   633
(* bound variables need to be treated properly,
fa2b4b7af755 modifying comments/indentation in quotient_term.ml
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 836
diff changeset
   634
   as the type of subterms needs to be calculated   *)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   635
fun inj_repabs_trm ctxt (rtrm, qtrm) =
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   636
 case (rtrm, qtrm) of
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   637
    (Const (@{const_name "Ball"}, T) $ r $ t, Const (@{const_name "All"}, _) $ t') =>
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   638
       Const (@{const_name "Ball"}, T) $ r $ (inj_repabs_trm ctxt (t, t'))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   639
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   640
  | (Const (@{const_name "Bex"}, T) $ r $ t, Const (@{const_name "Ex"}, _) $ t') =>
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   641
       Const (@{const_name "Bex"}, T) $ r $ (inj_repabs_trm ctxt (t, t'))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   642
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   643
  | (Const (@{const_name "Babs"}, T) $ r $ t, t' as (Abs _)) =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   644
      let
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   645
        val rty = fastype_of rtrm
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   646
        val qty = fastype_of qtrm
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   647
      in
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   648
        mk_repabs ctxt (rty, qty) (Const (@{const_name "Babs"}, T) $ r $ (inj_repabs_trm ctxt (t, t')))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   649
      end
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   650
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   651
  | (Abs (x, T, t), Abs (x', T', t')) =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   652
      let
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   653
        val rty = fastype_of rtrm
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   654
        val qty = fastype_of qtrm
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   655
        val (y, s) = Term.dest_abs (x, T, t)
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   656
        val (_, s') = Term.dest_abs (x', T', t')
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   657
        val yvar = Free (y, T)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   658
        val result = Term.lambda_name (y, yvar) (inj_repabs_trm ctxt (s, s'))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   659
      in
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   660
        if rty = qty then result
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   661
        else mk_repabs ctxt (rty, qty) result
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   662
      end
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   663
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   664
  | (t $ s, t' $ s') =>
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   665
       (inj_repabs_trm ctxt (t, t')) $ (inj_repabs_trm ctxt (s, s'))
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   666
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   667
  | (Free (_, T), Free (_, T')) =>
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   668
        if T = T' then rtrm
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   669
        else mk_repabs ctxt (T, T') rtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   670
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   671
  | (_, Const (@{const_name "op ="}, _)) => rtrm
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   672
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   673
  | (_, Const (_, T')) =>
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   674
      let
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   675
        val rty = fastype_of rtrm
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   676
      in
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   677
        if rty = T' then rtrm
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   678
        else mk_repabs ctxt (rty, T') rtrm
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   679
      end
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   680
833
129caba33c03 the chk-functions in quotient_term also simplify the result according to the id_simps; had to remove id_def from this theorem list though; this caused in FSet3 that relied on this rule; the problem is marked with "ID PROBLEM"
Christian Urban <urbanc@in.tum.de>
parents: 832
diff changeset
   681
  | _ => inj_repabs_err ctxt "injection (default):" rtrm qtrm
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   682
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   683
fun inj_repabs_trm_chk ctxt (rtrm, qtrm) =
1128
17ca92ab4660 Main renaming + fixes for new Isabelle in IntEx2.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1113
diff changeset
   684
  inj_repabs_trm ctxt (rtrm, qtrm)
779
3b21b24a5fb6 corrected map declarations for Sum and Prod; moved absrep_fun examples in separate file
Christian Urban <urbanc@in.tum.de>
parents: 776
diff changeset
   685
  |> Syntax.check_term ctxt
776
d1064fa29424 renamed get_fun to absrep_fun; introduced explicit checked versions of the term functions
Christian Urban <urbanc@in.tum.de>
parents: 775
diff changeset
   686
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   687
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   688
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   689
(*** Wrapper for automatically transforming an rthm into a qthm ***)
1072
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   690
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   691
(* subst_tys takes a list of (rty, qty) substitution pairs
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   692
   and replaces all occurences of rty in the given type
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   693
   by appropriate qty, with substitution *)
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   694
fun subst_ty thy ty (rty, qty) r =
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   695
  if r <> NONE then r else
1090
de2d1929899f Fixed pattern matching, now the test in Abs works correctly.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1085
diff changeset
   696
  case try (Sign.typ_match thy (rty, ty)) Vartab.empty of
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   697
    SOME inst => SOME (Envir.subst_type inst qty)
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   698
  | NONE => NONE
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   699
fun subst_tys thy substs ty =
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   700
  case fold (subst_ty thy ty) substs NONE of
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   701
    SOME ty => ty
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   702
  | NONE =>
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   703
      (case ty of
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   704
        Type (s, tys) => Type (s, map (subst_tys thy substs) tys)
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   705
      | x => x)
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   706
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   707
(* subst_trms takes a list of (rtrm, qtrm) substitution pairs
1113
9f6c606d5b59 more minor space and bracket modifications.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1100
diff changeset
   708
   and if the given term matches any of the raw terms it
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   709
   returns the appropriate qtrm instantiated. If none of
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   710
   them matched it returns NONE. *)
1078
Christian Urban <urbanc@in.tum.de>
parents: 1077
diff changeset
   711
fun subst_trm thy t (rtrm, qtrm) s =
1071
dde8ad700c5b More code abstracted away
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1070
diff changeset
   712
  if s <> NONE then s else
1090
de2d1929899f Fixed pattern matching, now the test in Abs works correctly.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1085
diff changeset
   713
    case try (Pattern.match thy (rtrm, t)) (Vartab.empty, Vartab.empty) of
1078
Christian Urban <urbanc@in.tum.de>
parents: 1077
diff changeset
   714
      SOME inst => SOME (Envir.subst_term inst qtrm)
1071
dde8ad700c5b More code abstracted away
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1070
diff changeset
   715
    | NONE => NONE;
dde8ad700c5b More code abstracted away
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1070
diff changeset
   716
fun subst_trms thy substs t = fold (subst_trm thy t) substs NONE
dde8ad700c5b More code abstracted away
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1070
diff changeset
   717
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   718
(* prepares type and term substitution pairs to be used by above
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   719
   functions that let replace all raw constructs by appropriate
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   720
   lifted counterparts. *)
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   721
fun get_ty_trm_substs ctxt =
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   722
let
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   723
  val thy = ProofContext.theory_of ctxt
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   724
  val quot_infos  = Quotient_Info.quotdata_dest ctxt
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   725
  val const_infos = Quotient_Info.qconsts_dest ctxt
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   726
  val ty_substs = map (fn ri => (#rtyp ri, #qtyp ri)) quot_infos
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   727
  val const_substs = map (fn ci => (#rconst ci, #qconst ci)) const_infos
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   728
  fun rel_eq rel = HOLogic.eq_const (subst_tys thy ty_substs (domain_type (fastype_of rel)))
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   729
  val rel_substs = map (fn ri => (#equiv_rel ri, rel_eq (#equiv_rel ri))) quot_infos
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   730
in
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   731
  (ty_substs, const_substs @ rel_substs)
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   732
end
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   733
1188
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   734
fun quotient_lift_const (b, t) ctxt =
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   735
let
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   736
  val thy = ProofContext.theory_of ctxt
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   737
  val (ty_substs, _) = get_ty_trm_substs ctxt;
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   738
  val (_, ty) = dest_Const t;
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   739
  val nty = subst_tys thy ty_substs ty;
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   740
in
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   741
  Free(b, nty)
e5413596e098 Automatic lifting of constants.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1128
diff changeset
   742
end
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   743
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   744
(*
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   745
Takes a term and
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   746
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   747
* replaces raw constants by the quotient constants
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   748
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   749
* replaces equivalence relations by equalities
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   750
1094
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   751
* replaces raw types by the quotient types
6961fda38e09 minor tuning
Christian Urban <urbanc@in.tum.de>
parents: 1085
diff changeset
   752
1085
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   753
*)
cf53861a00a7 Comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1078
diff changeset
   754
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   755
fun quotient_lift_all ctxt t =
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   756
let
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   757
  val thy = ProofContext.theory_of ctxt
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   758
  val (ty_substs, substs) = get_ty_trm_substs ctxt
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   759
  fun lift_aux t =
1071
dde8ad700c5b More code abstracted away
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1070
diff changeset
   760
    case subst_trms thy substs t of
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   761
      SOME x => x
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   762
    | NONE =>
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   763
      (case t of
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   764
        a $ b => lift_aux a $ lift_aux b
1072
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   765
      | Abs(a, ty, s) =>
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   766
          let
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   767
            val (y, s') = Term.dest_abs (a, ty, s)
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   768
            val nty = subst_tys thy ty_substs ty
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   769
          in
1077
44461d5615eb some tuning
Christian Urban <urbanc@in.tum.de>
parents: 1075
diff changeset
   770
            Abs(y, nty, abstract_over (Free (y, nty), lift_aux s'))
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   771
          end
1072
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   772
      | Free(n, ty) => Free(n, subst_tys thy ty_substs ty)
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   773
      | Var(n, ty) => Var(n, subst_tys thy ty_substs ty)
1070
a8518879ee20 A bit more intelligent and cleaner code.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1065
diff changeset
   774
      | Bound i => Bound i
1072
6deecec6795f A procedure that properly instantiates the types too.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1071
diff changeset
   775
      | Const(s, ty) => Const(s, subst_tys thy ty_substs ty))
1065
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   776
in
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   777
  lift_aux t
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   778
end
3664eafcad09 The automatic lifting translation function, still with dummy types,
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1000
diff changeset
   779
758
3104d62e7a16 moved the QuotMain code into two ML-files
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   780
end; (* structure *)