src/HOL/TPTP/TPTP_Parser/tptp_interpret.ML
author sultana
Fri, 09 Mar 2012 15:38:55 +0000
changeset 46844 5d9aab0c609c
child 46879 a8b1236e0837
permissions -rw-r--r--
added tptp parser;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46844
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     1
(*  Title:      HOL/TPTP/?/tptp_interpret.ML
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     2
    Author:     Nik Sultana, Cambridge University Computer Laboratory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     3
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     4
Interprets TPTP problems in Isabelle/HOL.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     5
*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     6
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     7
signature TPTP_INTERPRET =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     8
sig
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
     9
  (*signature extension: typing information for variables and constants
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    10
  (note that the former isn't really part of the signature, but it's bundled
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    11
  along for more configurability -- though it's probably useless and could be
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    12
  dropped in the future.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    13
  type const_map = (string * term) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    14
  type var_types = (string * typ option) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    15
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    16
  (*mapping from THF types to Isabelle/HOL types. This map works over all
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    17
  base types (i.e. THF functions must be interpreted as Isabelle/HOL functions).
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    18
  The map must be total wrt THF types. Later on there could be a configuration
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    19
  option to make a map extensible.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    20
  type type_map = (TPTP_Syntax.tptp_type * typ) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    21
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    22
  (*inference info, when available, consists of the name of the inference rule
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    23
  and the names of the inferences involved in the reasoning step.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    24
  type inference_info = (string * string list) option
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    25
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    26
  (*a parsed annotated formula is represented as a triple consisting of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    27
  the formula's label, its role, and a constant function to its Isabelle/HOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    28
  term meaning*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    29
  type tptp_formula_meaning =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    30
    string * TPTP_Syntax.role * TPTP_Syntax.tptp_formula * term * inference_info
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    31
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    32
  (*In general, the meaning of a TPTP statement (which, through the Include
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    33
  directive, may include the meaning of an entire TPTP file, is an extended
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    34
  Isabelle/HOL theory, an explicit map from constants to their Isabelle/HOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    35
  counterparts and their types, the meaning of any TPTP formulas encountered
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    36
  while interpreting that statement, and a map from THF to Isabelle/HOL types
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    37
  (these types would have been added to the theory returned in the first position
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    38
  of the tuple). The last value is NONE when the function which produced the
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    39
  whole tptp_general_meaning value was given a type_map argument -- since
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    40
  this means that the type_map is already known, and it has not been changed.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    41
  type tptp_general_meaning =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    42
    (type_map * const_map * tptp_formula_meaning list)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    43
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    44
  (*if problem_name is given then it is used to qualify types & constants*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    45
  type config =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    46
    {(*init_type_map : type_map with_origin,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    47
     init_const_map : type_map with_origin,*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    48
     cautious : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    49
     problem_name : TPTP_Problem_Name.problem_name option
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    50
     (*dont_build_maps : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    51
     extend_given_type_map : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    52
     extend_given_const_map : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    53
     generative_type_interpretation : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    54
     generative_const_interpretation : bool*)}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    55
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    56
  (*map types form THF to Isabelle/HOL*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    57
  val interpret_type : config -> theory -> type_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    58
    TPTP_Syntax.tptp_type -> typ
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    59
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    60
  (*interpret a TPTP line: return an updated theory including the
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    61
  types & constants which were specified in that formula, a map from
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    62
  constant names to their types, and a map from constant names to Isabelle/HOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    63
  constants; and a list possible formulas resulting from that line.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    64
  Note that type/constant declarations do not result in any formulas being
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    65
  returned. A typical TPTP line might update the theory, or return a single
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    66
  formula. The sole exception is the "include" directive which may update the
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    67
  theory and also return a list of formulas from the included file.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    68
  Arguments:
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    69
    cautious = indicates whether additional checks are made to check
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    70
      that all used types have been declared.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    71
    type_map = mapping of THF-types to Isabelle/HOL types. This argument may be
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    72
      given to force a specific mapping: this is usually done for using an
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    73
      imported THF problem in Isar.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    74
    const_map = as previous, but for constants.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    75
    path_prefix = path where THF problems etc are located (to help the "include"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    76
      directive find the files.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    77
    thy = theory where interpreted info will be stored.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    78
  *)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    79
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    80
  (*map terms form TPTP to Isabelle/HOL*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    81
  val interpret_term : bool -> config -> TPTP_Syntax.language -> theory ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    82
    const_map -> var_types -> type_map -> TPTP_Syntax.tptp_term ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    83
    term * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    84
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    85
  val interpret_formula : config -> TPTP_Syntax.language -> const_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    86
    var_types -> type_map -> TPTP_Syntax.tptp_formula -> theory ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    87
    term * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    88
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    89
  val interpret_line : config -> type_map -> const_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    90
    Path.T -> TPTP_Syntax.tptp_line -> theory -> tptp_general_meaning * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    91
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    92
  (*Like "interpret_line" above, but works over a whole parsed problem.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    93
    Arguments:
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    94
      new_basic_types = indicates whether interpretations of $i and $o
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    95
        types are to be added to the type map (unless it is Given).
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    96
        This is "true" if we are running this over a fresh THF problem, but
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    97
        "false" if we are calling this _during_ the interpretation of a THF file
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    98
        (i.e. when interpreting an "include" directive.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
    99
      config = config
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   100
      path_prefix = " "
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   101
      contents = parsed TPTP syntax
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   102
      type_map = see "interpret_line"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   103
      const_map = " "
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   104
      thy = " "
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   105
  *)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   106
  val interpret_problem : bool -> config -> Path.T ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   107
    TPTP_Syntax.tptp_line list -> type_map -> const_map -> theory ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   108
    tptp_general_meaning * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   109
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   110
  (*Like "interpret_problem" above, but it's given a filename rather than
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   111
  a parsed problem.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   112
  val interpret_file : bool -> Path.T -> Path.T -> type_map -> const_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   113
    theory -> tptp_general_meaning * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   114
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   115
  (*General exception for this signature.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   116
  exception MISINTERPRET_FORMULA of string * TPTP_Syntax.tptp_formula
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   117
  exception MISINTERPRET_SYMBOL of string * TPTP_Syntax.symbol
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   118
  exception MISINTERPRET_TERM of string * TPTP_Syntax.tptp_term
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   119
  exception MISINTERPRET_TYPE of string * TPTP_Syntax.tptp_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   120
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   121
  (*Generates a fresh Isabelle/HOL type for interpreting a THF type in a theory.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   122
  val declare_type : config -> (TPTP_Syntax.tptp_type * string) -> type_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   123
    theory -> type_map * theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   124
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   125
  (*Returns the list of all files included in a directory and its
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   126
  subdirectories. This is only used for testing the parser/interpreter against
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   127
  all THF problems.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   128
  val get_file_list : Path.T -> Path.T list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   129
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   130
  type manifest = TPTP_Problem_Name.problem_name * tptp_general_meaning
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   131
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   132
  val get_manifests : theory -> manifest list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   133
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   134
  val import_file : bool -> Path.T -> Path.T -> type_map -> const_map ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   135
    theory -> theory
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   136
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   137
  val extract_inference_info : (TPTP_Syntax.general_term * 'a list) option ->
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   138
                               (string * string list) option
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   139
end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   140
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   141
structure TPTP_Interpret : TPTP_INTERPRET =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   142
struct
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   143
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   144
open TPTP_Syntax
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   145
exception MISINTERPRET_FORMULA of string * TPTP_Syntax.tptp_formula
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   146
exception MISINTERPRET_SYMBOL of string * TPTP_Syntax.symbol
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   147
exception MISINTERPRET_TERM of string * TPTP_Syntax.tptp_term
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   148
exception MISINTERPRET_TYPE of string * TPTP_Syntax.tptp_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   149
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   150
(* General stuff *)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   151
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   152
type config =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   153
  {(*init_type_map : type_map with_origin,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   154
   init_const_map : type_map with_origin,*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   155
   cautious : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   156
   problem_name : TPTP_Problem_Name.problem_name option
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   157
   (*dont_build_maps : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   158
   extend_given_type_map : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   159
   extend_given_const_map : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   160
   generative_type_interpretation : bool,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   161
   generative_const_interpretation : bool*)}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   162
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   163
(* Interpretation *)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   164
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   165
(** Signatures and other type abbrevations **)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   166
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   167
type const_map = (string * term) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   168
type var_types = (string * typ option) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   169
type type_map = (TPTP_Syntax.tptp_type * typ) list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   170
type inference_info = (string * string list) option
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   171
type tptp_formula_meaning =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   172
  string * TPTP_Syntax.role * TPTP_Syntax.tptp_formula * term * inference_info
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   173
type tptp_general_meaning =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   174
  (type_map * const_map * tptp_formula_meaning list)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   175
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   176
type manifest = TPTP_Problem_Name.problem_name * tptp_general_meaning
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   177
structure TPTP_Data = Theory_Data
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   178
  (type T = manifest list
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   179
   val empty = []
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   180
   val extend = I
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   181
   val merge = Library.merge (op =))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   182
val get_manifests = TPTP_Data.get
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   183
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   184
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   185
(** Adding types to a signature **)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   186
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   187
fun type_exists thy ty_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   188
  Sign.declared_tyname thy (Sign.full_bname thy ty_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   189
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   190
val IND_TYPE = "ind"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   191
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   192
fun mk_binding config ident =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   193
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   194
    val pre_binding = Binding.name ident
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   195
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   196
    case #problem_name config of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   197
      NONE => pre_binding
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   198
    | SOME prob =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   199
        Binding.qualify
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   200
         false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   201
         (TPTP_Problem_Name.mangle_problem_name prob)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   202
         pre_binding
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   203
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   204
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   205
(*Returns updated theory and the name of the final type's name -- i.e. if the
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   206
original name is already taken then the function looks for an available
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   207
alternative. It also returns an updated type_map if one has been passed to it.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   208
fun declare_type (config : config) (thf_type, type_name) ty_map thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   209
  if type_exists thy type_name then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   210
    raise MISINTERPRET_TYPE ("Type already exists", Atom_type type_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   211
  else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   212
    let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   213
      val binding = mk_binding config type_name
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   214
      val final_fqn = Sign.full_name thy binding
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   215
      val thy' = Typedecl.typedecl_global (mk_binding config type_name, [], NoSyn) thy |> snd
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   216
      val typ_map_entry = (thf_type, (Type (final_fqn, [])))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   217
      val ty_map' = typ_map_entry :: ty_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   218
    in (ty_map', thy') end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   219
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   220
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   221
(** Adding constants to signature **)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   222
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   223
fun full_name thy config const_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   224
  Sign.full_name thy (mk_binding config const_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   225
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   226
fun const_exists config thy const_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   227
  Sign.declared_const thy (full_name thy config const_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   228
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   229
fun declare_constant config const_name ty thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   230
  if const_exists config thy const_name then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   231
    raise MISINTERPRET_TERM
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   232
     ("Const already declared", Term_Func (Uninterpreted const_name, []))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   233
  else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   234
    Theory.specify_const
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   235
     ((mk_binding config const_name, ty), NoSyn) thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   236
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   237
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   238
(** Interpretation **)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   239
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   240
(*Types in THF are encoded as formulas. This function translates them to type form.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   241
(*FIXME possibly incomplete hack*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   242
fun fmlatype_to_type (Atom (THF_Atom_term (Term_Func (TypeSymbol typ, [])))) =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   243
      Defined_type typ
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   244
  | fmlatype_to_type (Atom (THF_Atom_term (Term_Func (Uninterpreted str, [])))) =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   245
      Atom_type str
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   246
  | fmlatype_to_type (THF_type (Fn_type (ty1, ty2))) =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   247
      let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   248
        val ty1' = case ty1 of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   249
            Fn_type _ => fmlatype_to_type (THF_type ty1)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   250
          | Fmla_type ty1 => fmlatype_to_type ty1
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   251
        val ty2' = case ty2 of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   252
            Fn_type _ => fmlatype_to_type (THF_type ty2)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   253
          | Fmla_type ty2 => fmlatype_to_type ty2
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   254
      in Fn_type (ty1', ty2') end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   255
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   256
fun interpret_type config thy type_map thf_ty =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   257
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   258
    fun lookup_type ty_map thf_ty =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   259
      (case AList.lookup (op =) ty_map thf_ty of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   260
          NONE =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   261
            raise MISINTERPRET_TYPE
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   262
              ("Could not find the interpretation of this TPTP type in the " ^
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   263
               "mapping to Isabelle/HOL", thf_ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   264
        | SOME ty => ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   265
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   266
    case thf_ty of (*FIXME make tail*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   267
       Prod_type (thf_ty1, thf_ty2) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   268
         Type ("Product_Type.prod",
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   269
          [interpret_type config thy type_map thf_ty1,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   270
           interpret_type config thy type_map thf_ty2])
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   271
     | Fn_type (thf_ty1, thf_ty2) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   272
         Type ("fun",
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   273
          [interpret_type config thy type_map thf_ty1,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   274
           interpret_type config thy type_map thf_ty2])
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   275
     | Atom_type _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   276
         lookup_type type_map thf_ty
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   277
     | Defined_type tptp_base_type =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   278
         (case tptp_base_type of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   279
            Type_Ind =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   280
              lookup_type type_map thf_ty
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   281
          | Type_Bool => HOLogic.boolT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   282
          | Type_Type =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   283
              raise MISINTERPRET_TYPE
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   284
               ("No type interpretation", thf_ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   285
          | Type_Int => Type ("Int.int", [])
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   286
         (*FIXME these types are currently unsupported, so they're treated as
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   287
         individuals*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   288
          | Type_Rat =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   289
              interpret_type config thy type_map (Defined_type Type_Ind)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   290
          | Type_Real =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   291
              interpret_type config thy type_map (Defined_type Type_Ind)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   292
          )
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   293
     | Sum_type _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   294
         raise MISINTERPRET_TYPE (*FIXME*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   295
          ("No type interpretation (sum type)", thf_ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   296
     | Fmla_type tptp_ty =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   297
        fmlatype_to_type tptp_ty
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   298
        |> interpret_type config thy type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   299
     | Subtype _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   300
         raise MISINTERPRET_TYPE (*FIXME*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   301
          ("No type interpretation (subtype)", thf_ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   302
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   303
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   304
fun the_const config thy language const_map_payload str =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   305
  if language = THF then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   306
    (case AList.lookup (op =) const_map_payload str of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   307
        NONE => raise MISINTERPRET_TERM
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   308
          ("Could not find the interpretation of this constant in the " ^
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   309
          "mapping to Isabelle/HOL", Term_Func (Uninterpreted str, []))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   310
      | SOME t => t)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   311
  else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   312
    if const_exists config thy str then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   313
       Sign.mk_const thy ((Sign.full_name thy (mk_binding config str)), [])
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   314
    else raise MISINTERPRET_TERM
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   315
          ("Could not find the interpretation of this constant in the " ^
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   316
          "mapping to Isabelle/HOL: ", Term_Func (Uninterpreted str, []))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   317
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   318
(*Eta-expands Isabelle/HOL binary function.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   319
 "str" is the name of a polymorphic constant in Isabelle/HOL*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   320
fun mk_fun str =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   321
  (Const (str, Term.dummyT) $ Bound 1 $ Bound 0)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   322
   |> (Term.absdummy Term.dummyT #> Term.absdummy Term.dummyT)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   323
(*As above, but swaps the function's arguments*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   324
fun mk_swapped_fun str =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   325
  (Const (str, Term.dummyT) $ Bound 0 $ Bound 1)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   326
   |> (Term.absdummy Term.dummyT #> Term.absdummy Term.dummyT)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   327
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   328
fun dummy_THF () =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   329
  HOLogic.choice_const Term.dummyT $ Term.absdummy Term.dummyT @{term "True"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   330
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   331
fun interpret_symbol config thy language const_map symb =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   332
  case symb of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   333
     Uninterpreted n =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   334
       (*Constant would have been added to the map at the time of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   335
       declaration*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   336
       the_const config thy language const_map n
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   337
   | Interpreted_ExtraLogic interpreted_symbol =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   338
       (case interpreted_symbol of (*FIXME incomplete,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   339
                                     and doesn't work with $i*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   340
          Sum => mk_fun @{const_name Groups.plus}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   341
        | UMinus =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   342
            (Const (@{const_name Groups.uminus}, Term.dummyT) $ Bound 0)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   343
             |> Term.absdummy Term.dummyT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   344
        | Difference => mk_fun @{const_name Groups.minus}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   345
        | Product => mk_fun @{const_name Groups.times}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   346
        | Quotient => mk_fun @{const_name Fields.divide}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   347
        | Less => mk_fun @{const_name Orderings.less}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   348
        | LessEq => mk_fun @{const_name Orderings.less_eq}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   349
        | Greater => mk_swapped_fun @{const_name Orderings.less}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   350
          (*FIXME would be nicer to expand "greater"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   351
            and "greater_eq" abbreviations*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   352
        | GreaterEq => mk_swapped_fun @{const_name Orderings.less_eq}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   353
        (* FIXME todo
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   354
        | Quotient_E | Quotient_T | Quotient_F | Remainder_E | Remainder_T
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   355
        | Remainder_F | Floor | Ceiling | Truncate | Round | To_Int | To_Rat
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   356
        | To_Real | EvalEq | Is_Int | Is_Rat*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   357
        | Apply => raise MISINTERPRET_SYMBOL ("Malformed term?", symb)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   358
        | _ => dummy_THF ()
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   359
        )
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   360
   | Interpreted_Logic logic_symbol =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   361
       (case logic_symbol of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   362
          Equals => HOLogic.eq_const Term.dummyT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   363
        | NEquals =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   364
           HOLogic.mk_not (HOLogic.eq_const Term.dummyT $ Bound 1 $ Bound 0)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   365
           |> (Term.absdummy Term.dummyT #> Term.absdummy Term.dummyT)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   366
        | Or => HOLogic.disj
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   367
        | And => HOLogic.conj
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   368
        | Iff => HOLogic.eq_const HOLogic.boolT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   369
        | If => HOLogic.imp
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   370
        | Fi => @{term "\<lambda> x. \<lambda> y. y \<longrightarrow> x"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   371
        | Xor =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   372
            @{term
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   373
              "\<lambda> x. \<lambda> y. \<not> (x \<longleftrightarrow> y)"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   374
        | Nor => @{term "\<lambda> x. \<lambda> y. \<not> (x \<or> y)"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   375
        | Nand => @{term "\<lambda> x. \<lambda> y. \<not> (x \<and> y)"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   376
        | Not => HOLogic.Not
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   377
        | Op_Forall => HOLogic.all_const Term.dummyT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   378
        | Op_Exists => HOLogic.exists_const Term.dummyT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   379
        | True => @{term "True"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   380
        | False => @{term "False"}
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   381
        )
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   382
   | TypeSymbol _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   383
       raise MISINTERPRET_SYMBOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   384
        ("Cannot have TypeSymbol in term", symb)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   385
   | System str =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   386
       raise MISINTERPRET_SYMBOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   387
        ("How to interpret system terms?", symb)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   388
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   389
(*Apply a function to a list of arguments*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   390
val mapply = fold (fn x => fn y => y $ x)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   391
(*As above, but for products*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   392
fun mtimes thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   393
  fold (fn x => fn y =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   394
    Sign.mk_const thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   395
    ("Product_Type.Pair",[Term.dummyT, Term.dummyT]) $ y $ x)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   396
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   397
(*Adds constants to signature in FOL. "formula_level" means that the constants
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   398
are to be interpreted as predicates, otherwise as functions over individuals.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   399
fun FO_const_types config formula_level type_map tptp_t thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   400
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   401
    val ind_type = interpret_type config thy type_map (Defined_type Type_Ind)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   402
    val value_type =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   403
      if formula_level then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   404
        interpret_type config thy type_map (Defined_type Type_Bool)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   405
      else ind_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   406
  in case tptp_t of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   407
      Term_Func (symb, tptp_ts) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   408
        let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   409
          val thy' = fold (FO_const_types config false type_map) tptp_ts thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   410
          val ty = fold (fn ty1 => fn ty2 => Type ("fun", [ty1, ty2]))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   411
            (map (fn _ => ind_type) tptp_ts) value_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   412
        in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   413
          case symb of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   414
             Uninterpreted const_name =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   415
                 if const_exists config thy' const_name then thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   416
                 else snd (declare_constant config const_name ty thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   417
           | _ => thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   418
        end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   419
     | _ => thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   420
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   421
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   422
(*like FO_const_types but works over symbols*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   423
fun symb_const_types config type_map formula_level const_name n_args thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   424
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   425
    val ind_type = interpret_type config thy type_map (Defined_type Type_Ind)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   426
    val value_type =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   427
      if formula_level then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   428
        interpret_type config thy type_map (Defined_type Type_Bool)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   429
      else interpret_type config thy type_map (Defined_type Type_Ind)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   430
    fun mk_i_fun b n acc =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   431
      if n = 0 then acc b
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   432
      else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   433
        mk_i_fun b (n - 1) (fn ty => Type ("fun", [ind_type, acc ty]))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   434
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   435
    if const_exists config thy const_name then thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   436
    else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   437
      snd (declare_constant config const_name
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   438
           (mk_i_fun value_type n_args I) thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   439
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   440
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   441
(*Next batch of functions give info about Isabelle/HOL types*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   442
fun is_fun (Type ("fun", _)) = true
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   443
  | is_fun _ = false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   444
fun is_prod (Type ("Product_Type.prod", _)) = true
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   445
  | is_prod _ = false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   446
fun dom_type (Type ("fun", [ty1, _])) = ty1
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   447
fun is_prod_typed thy config symb =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   448
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   449
    fun symb_type const_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   450
      Sign.the_const_type thy (full_name thy config const_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   451
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   452
    case symb of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   453
       Uninterpreted const_name =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   454
         if is_fun (symb_type const_name) then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   455
           symb_type const_name |> dom_type |> is_prod
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   456
         else false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   457
     | _ => false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   458
   end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   459
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   460
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   461
(*
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   462
 Information needed to be carried around:
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   463
 - constant mapping: maps constant names to Isabelle terms with fully-qualified
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   464
    names. This is fixed, and it is determined by declaration lines earlier
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   465
    in the script (i.e. constants must be declared before appearing in terms.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   466
 - type context: maps bound variables to their Isabelle type. This is discarded
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   467
    after each call of interpret_term since variables' can't be bound across
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   468
    terms.
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   469
*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   470
fun interpret_term formula_level config language thy const_map var_types type_map tptp_t =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   471
  case tptp_t of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   472
    Term_Func (symb, tptp_ts) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   473
       let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   474
         val thy' = FO_const_types config formula_level type_map tptp_t thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   475
         fun typeof_const const_name = Sign.the_const_type thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   476
             (Sign.full_name thy' (mk_binding config const_name))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   477
       in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   478
         case symb of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   479
           Interpreted_ExtraLogic Apply =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   480
             (*apply the head of the argument list to the tail*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   481
             (mapply
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   482
               (map (interpret_term false config language thy' const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   483
                var_types type_map #> fst) (tl tptp_ts))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   484
               (interpret_term formula_level config language thy' const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   485
                var_types type_map (hd tptp_ts) |> fst),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   486
              thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   487
           | _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   488
              (*apply symb to tptp_ts*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   489
              if is_prod_typed thy' config symb then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   490
                (interpret_symbol config thy' language const_map symb $
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   491
                  mtimes thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   492
                  (map (interpret_term false config language thy' const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   493
                   var_types type_map #> fst) (tl tptp_ts))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   494
                  ((interpret_term false config language thy' const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   495
                   var_types type_map #> fst) (hd tptp_ts)),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   496
                 thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   497
              else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   498
                (mapply
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   499
                  (map (interpret_term false config language thy' const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   500
                   var_types type_map #> fst) tptp_ts)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   501
                  (interpret_symbol config thy' language const_map symb),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   502
                 thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   503
       end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   504
  | Term_Var n =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   505
     (if language = THF orelse language = TFF then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   506
        (case AList.lookup (op =) var_types n of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   507
           SOME ty =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   508
             (case ty of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   509
                SOME ty => Free (n, ty)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   510
              | NONE => Free (n, Term.dummyT) (*to infer the variable's type*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   511
             )
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   512
         | NONE =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   513
             raise MISINTERPRET_TERM ("Could not type variable", tptp_t))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   514
      else (*variables range over individuals*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   515
        Free (n, interpret_type config thy type_map (Defined_type Type_Ind)),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   516
      thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   517
  | Term_Conditional (tptp_formula, tptp_t1, tptp_t2) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   518
      (mk_fun @{const_name If}, thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   519
  | Term_Num (number_kind, num) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   520
      let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   521
        val num_term =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   522
          if number_kind = Int_num then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   523
            HOLogic.mk_number @{typ "int"} (the (Int.fromString num))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   524
          else dummy_THF () (*FIXME: not yet supporting rationals and reals*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   525
      in (num_term, thy) end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   526
  | Term_Distinct_Object str =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   527
      let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   528
        fun alphanumerate c =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   529
          let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   530
            val c' = ord c
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   531
            val out_of_range =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   532
              ((c' > 64) andalso (c' < 91)) orelse ((c' > 96)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   533
               andalso (c' < 123)) orelse ((c' > 47) andalso (c' < 58))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   534
          in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   535
            if (not out_of_range) andalso (not (c = "_")) then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   536
              "_nom_" ^ Int.toString (ord c) ^ "_"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   537
            else c
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   538
          end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   539
        val mangle_name = raw_explode #> map alphanumerate #> implode
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   540
      in declare_constant config (mangle_name str)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   541
          (interpret_type config thy type_map (Defined_type Type_Ind)) thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   542
      end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   543
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   544
(*Given a list of "'a option", then applies a function to each element if that
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   545
element is SOME value, otherwise it leaves it as NONE.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   546
fun map_opt f xs =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   547
  fold
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   548
  (fn x => fn y =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   549
    (if Option.isSome x then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   550
       SOME (f (Option.valOf x))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   551
     else NONE) :: y
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   552
  ) xs []
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   553
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   554
fun interpret_formula config language const_map var_types type_map tptp_fmla thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   555
  case tptp_fmla of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   556
      Pred app =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   557
        interpret_term true config language thy const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   558
         var_types type_map (Term_Func app)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   559
    | Fmla (symbol, tptp_formulas) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   560
       (case symbol of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   561
          Interpreted_ExtraLogic Apply =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   562
            let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   563
              val (args, thy') = (fold_map (interpret_formula config language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   564
               const_map var_types type_map) (tl tptp_formulas) thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   565
              val (func, thy') = interpret_formula config language const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   566
               var_types type_map (hd tptp_formulas) thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   567
            in (mapply args func, thy') end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   568
        | Uninterpreted const_name =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   569
            let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   570
              val (args, thy') = (fold_map (interpret_formula config language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   571
               const_map var_types type_map) tptp_formulas thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   572
              val thy' = symb_const_types config type_map true const_name
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   573
               (length tptp_formulas) thy'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   574
            in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   575
              (if is_prod_typed thy' config symbol then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   576
                 mtimes thy' args (interpret_symbol config thy' language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   577
                  const_map symbol)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   578
               else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   579
                mapply args
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   580
                 (interpret_symbol config thy' language const_map symbol),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   581
              thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   582
            end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   583
        | _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   584
            let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   585
              val (args, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   586
                fold_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   587
                 (interpret_formula config language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   588
                  const_map var_types type_map)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   589
                 tptp_formulas thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   590
            in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   591
              (if is_prod_typed thy' config symbol then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   592
                 mtimes thy' args (interpret_symbol config thy' language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   593
                  const_map symbol)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   594
               else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   595
                 mapply args
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   596
                  (interpret_symbol config thy' language const_map symbol),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   597
               thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   598
            end)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   599
    | Sequent _ =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   600
        raise MISINTERPRET_FORMULA ("Sequent", tptp_fmla) (*FIXME unsupported*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   601
    | Quant (quantifier, bindings, tptp_formula) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   602
        let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   603
          val (bound_vars, bound_var_types) = ListPair.unzip bindings
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   604
          val bound_var_types' : typ option list =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   605
            (map_opt : (tptp_type -> typ) -> (tptp_type option list) -> typ option list)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   606
            (interpret_type config thy type_map) bound_var_types
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   607
          val var_types' =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   608
            ListPair.zip (bound_vars, List.rev bound_var_types')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   609
            |> List.rev
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   610
          fun fold_bind f =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   611
            fold
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   612
              (fn (n, ty) => fn t =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   613
                 case ty of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   614
                   NONE =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   615
                     f (n,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   616
                        if language = THF then Term.dummyT
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   617
                        else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   618
                          interpret_type config thy type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   619
                           (Defined_type Type_Ind),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   620
                        t)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   621
                 | SOME ty => f (n, ty, t)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   622
              )
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   623
              var_types'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   624
        in case quantifier of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   625
          Forall =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   626
            interpret_formula config language const_map (var_types' @ var_types)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   627
             type_map tptp_formula thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   628
            |>> fold_bind HOLogic.mk_all
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   629
        | Exists =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   630
            interpret_formula config language const_map (var_types' @ var_types)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   631
             type_map tptp_formula thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   632
            |>> fold_bind HOLogic.mk_exists
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   633
        | Lambda =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   634
            interpret_formula config language const_map (var_types' @ var_types)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   635
             type_map tptp_formula thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   636
            |>> fold_bind (fn (n, ty, rest) => lambda (Free (n, ty)) rest)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   637
        | Epsilon =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   638
            let val (t, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   639
              interpret_formula config language const_map var_types type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   640
               (Quant (Lambda, bindings, tptp_formula)) thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   641
            in ((HOLogic.choice_const Term.dummyT) $ t, thy') end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   642
        | Iota =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   643
            let val (t, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   644
              interpret_formula config language const_map var_types type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   645
               (Quant (Lambda, bindings, tptp_formula)) thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   646
            in (Const (@{const_name The}, Term.dummyT) $ t, thy') end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   647
        | Dep_Prod =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   648
            raise MISINTERPRET_FORMULA ("Unsupported", tptp_fmla)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   649
        | Dep_Sum =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   650
            raise MISINTERPRET_FORMULA ("Unsupported", tptp_fmla)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   651
        end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   652
  (*FIXME unsupported
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   653
    | Conditional of tptp_formula * tptp_formula * tptp_formula
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   654
    | Let of tptp_let list * tptp_formula
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   655
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   656
    and tptp_let =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   657
        Let_fmla of (string * tptp_type option) * tptp_formula (*both TFF and THF*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   658
      | Let_term of (string * tptp_type option) * tptp_term  (*only TFF*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   659
  *)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   660
    | Atom tptp_atom =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   661
        (case tptp_atom of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   662
          TFF_Typed_Atom (symbol, tptp_type_opt) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   663
            (*FIXME ignoring type info*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   664
            (interpret_symbol config thy language const_map symbol, thy)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   665
        | THF_Atom_term tptp_term =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   666
            interpret_term true config language thy const_map var_types
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   667
             type_map tptp_term
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   668
        | THF_Atom_conn_term symbol =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   669
            (interpret_symbol config thy language const_map symbol, thy))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   670
    | THF_type _ => (*FIXME unsupported*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   671
         raise MISINTERPRET_FORMULA
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   672
          ("Cannot interpret types as formulas", tptp_fmla)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   673
    | THF_typing (tptp_formula, _) => (*FIXME ignoring type info*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   674
        interpret_formula config language
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   675
         const_map var_types type_map tptp_formula thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   676
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   677
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   678
(*Extract name of inference rule, and the inferences it relies on*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   679
(*This is tuned to work with LEO-II, and is brittle to upstream
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   680
  changes of the proof protocol.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   681
fun extract_inference_info annot =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   682
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   683
    fun get_line_id (General_Data (Number (Int_num, num))) = [num]
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   684
      | get_line_id (General_Data (Atomic_Word name)) = [name]
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   685
      | get_line_id (General_Term (Number (Int_num, num), _ (*e.g. a bind*))) = [num]
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   686
      | get_line_id _ = []
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   687
        (*e.g. General_Data (Application ("theory", [General_Data
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   688
          (Atomic_Word "equality")])) -- which would come from E through LEO-II*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   689
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   690
    case annot of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   691
      NONE => NONE
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   692
    | SOME annot =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   693
      (case annot of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   694
        (General_Data (Application ("inference",
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   695
        [General_Data (Atomic_Word inference_name),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   696
         _,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   697
         General_List related_lines])), _) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   698
          (SOME (inference_name, map get_line_id related_lines |> List.concat))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   699
      | _ => NONE)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   700
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   701
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   702
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   703
(*Extract the type from a typing*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   704
local
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   705
  fun extract_type tptp_type =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   706
    case tptp_type of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   707
        Fmla_type typ => fmlatype_to_type typ
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   708
      | _ => tptp_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   709
in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   710
  fun typeof_typing (THF_typing (_, tptp_type)) = extract_type tptp_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   711
  fun typeof_tff_typing (Atom (TFF_Typed_Atom (_, SOME tptp_type))) =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   712
    extract_type tptp_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   713
end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   714
fun nameof_typing
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   715
  (THF_typing
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   716
     ((Atom (THF_Atom_term (Term_Func (Uninterpreted str, [])))), _)) = str
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   717
fun nameof_tff_typing (Atom (TFF_Typed_Atom (Uninterpreted str, _))) = str
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   718
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   719
fun interpret_line config type_map const_map path_prefix line thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   720
  case line of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   721
     Include (quoted_path, _) => (*FIXME currently everything is imported*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   722
       interpret_file'
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   723
        false
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   724
        config
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   725
        path_prefix
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   726
        (Path.append
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   727
          path_prefix
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   728
          (quoted_path
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   729
           |> unenclose
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   730
           |> Path.explode))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   731
        type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   732
        const_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   733
        thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   734
   | Annotated_Formula (pos, lang, label, role, tptp_formula, annotation_opt) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   735
       case role of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   736
         Role_Type =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   737
           let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   738
             val thy_name = Context.theory_name thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   739
             val (tptp_ty, name) =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   740
               if lang = THF then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   741
                 (typeof_typing tptp_formula (*assuming tptp_formula is a typing*),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   742
                  nameof_typing tptp_formula (*and that the LHS is a (atom) name*))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   743
               else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   744
                 (typeof_tff_typing tptp_formula,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   745
                  nameof_tff_typing tptp_formula)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   746
           in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   747
             case tptp_ty of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   748
               Defined_type Type_Type => (*add new type*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   749
                 (*generate an Isabelle/HOL type to interpret this THF type,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   750
                 and add it to both the Isabelle/HOL theory and to the type_map*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   751
                  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   752
                    val (type_map', thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   753
                      declare_type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   754
                       config
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   755
                       (Atom_type name, name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   756
                       type_map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   757
                       thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   758
                  in ((type_map',
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   759
                       const_map,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   760
                       []),
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   761
                      thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   762
                  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   763
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   764
             | _ => (*declaration of constant*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   765
                (*Here we populate the map from constants to the Isabelle/HOL
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   766
                terms they map to (which in turn contain their types).*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   767
                let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   768
                  val ty = interpret_type config thy type_map tptp_ty
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   769
                  (*make sure that the theory contains all the types appearing
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   770
                  in this constant's signature. Exception is thrown if encounter
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   771
                  an undeclared types.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   772
                  val (t, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   773
                    let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   774
                      fun analyse_type thy thf_ty =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   775
                         if #cautious config then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   776
                          case thf_ty of
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   777
                             Fn_type (thf_ty1, thf_ty2) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   778
                               (analyse_type thy thf_ty1;
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   779
                               analyse_type thy thf_ty2)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   780
                           | Atom_type ty_name =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   781
                               if type_exists thy ty_name then ()
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   782
                               else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   783
                                raise MISINTERPRET_TYPE
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   784
                                 ("This type, in signature of " ^
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   785
                                    name ^ " has not been declared.",
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   786
                                   Atom_type ty_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   787
                           | _ => ()
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   788
                         else () (*skip test if we're not being cautious.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   789
                    in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   790
                      analyse_type thy tptp_ty;
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   791
                      declare_constant config name ty thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   792
                    end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   793
                  (*register a mapping from name to t. Constants' type
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   794
                  declarations should occur at most once, so it's justified to
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   795
                  use "::". Note that here we use a constant's name rather
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   796
                  than the possibly- new one, since all references in the
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   797
                  theory will be to this name.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   798
                  val const_map' = ((name, t) :: const_map)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   799
                in ((type_map,(*type_map unchanged, since a constant's
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   800
                                declaration shouldn't include any new types.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   801
                     const_map',(*typing table of constant was extended*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   802
                     []),(*no formulas were interpreted*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   803
                    thy')(*theory was extended with new constant*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   804
                end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   805
           end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   806
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   807
       | _ => (*i.e. the AF is not a type declaration*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   808
           let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   809
             (*gather interpreted term, and the map of types occurring in that term*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   810
             val (t, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   811
               interpret_formula config lang
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   812
                const_map [] type_map tptp_formula thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   813
               |>> HOLogic.mk_Trueprop
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   814
             (*type_maps grow monotonically, so return the newest value (type_mapped);
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   815
             there's no need to unify it with the type_map parameter.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   816
           in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   817
            ((type_map, const_map,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   818
              [(label, role, tptp_formula,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   819
                Syntax.check_term (Proof_Context.init_global thy') t,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   820
                extract_inference_info annotation_opt)]), thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   821
           end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   822
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   823
and interpret_problem new_basic_types config path_prefix lines type_map const_map thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   824
      let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   825
        val thy_name = Context.theory_name thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   826
        (*Add interpretation of $o and generate an Isabelle/HOL type to
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   827
        interpret $i, unless we've been given a mapping of types.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   828
        val (thy', type_map') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   829
          if not new_basic_types then (thy, type_map)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   830
          else
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   831
            let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   832
              val (type_map', thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   833
                declare_type config
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   834
                 (Defined_type Type_Ind, IND_TYPE) type_map thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   835
            in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   836
              (thy', type_map')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   837
            end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   838
      in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   839
        fold (fn line =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   840
               fn ((type_map, const_map, lines), thy) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   841
                 let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   842
                   (*process the line, ignoring the type-context for variables*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   843
                   val ((type_map', const_map', l'), thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   844
                     interpret_line config type_map const_map path_prefix line thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   845
                 in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   846
                   ((type_map',
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   847
                     const_map',
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   848
                     l' @ lines),(*append is sufficient, union would be overkill*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   849
                    thy')
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   850
                 end)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   851
             lines (*lines of the problem file*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   852
             ((type_map', const_map, []), thy') (*initial values*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   853
      end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   854
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   855
and interpret_file' new_basic_types config path_prefix file_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   856
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   857
    val file_name' = Path.expand file_name
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   858
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   859
    if Path.is_absolute file_name' then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   860
      Path.implode file_name
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   861
      |> TPTP_Parser.parse_file
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   862
      |> interpret_problem new_basic_types config path_prefix
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   863
    else error "Could not determine absolute path to file."
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   864
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   865
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   866
and interpret_file cautious path_prefix file_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   867
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   868
    val config =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   869
      {cautious = cautious,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   870
       problem_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   871
        SOME (TPTP_Problem_Name.parse_problem_name ((Path.base #> Path.implode)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   872
         file_name))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   873
      }
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   874
    handle _(*FIXME*) =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   875
      {cautious = cautious,
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   876
       problem_name = NONE
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   877
      }
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   878
  in interpret_file' true config path_prefix file_name end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   879
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   880
fun import_file cautious path_prefix file_name type_map const_map thy =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   881
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   882
    val prob_name =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   883
      TPTP_Problem_Name.parse_problem_name (Path.implode (Path.base file_name))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   884
      handle _(*FIXME*) => TPTP_Problem_Name.Nonstandard (Path.implode file_name)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   885
    val (result, thy') =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   886
      interpret_file cautious path_prefix file_name type_map const_map thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   887
  in TPTP_Data.map (cons ((prob_name, result))) thy' end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   888
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   889
val _ =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   890
  Outer_Syntax.improper_command "import_tptp" "import TPTP problem"
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   891
   Keyword.diag (*FIXME why diag?*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   892
   (Parse.string >>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   893
    (fn file_name =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   894
      Toplevel.theory (fn thy =>
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   895
        import_file true (Path.explode file_name |> Path.dir)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   896
         (Path.explode file_name) [] [] thy
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   897
        )))
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   898
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   899
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   900
(*Used for debugging. Returns all files contained within a directory or its
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   901
subdirectories. Follows symbolic links, filters away directories.*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   902
fun get_file_list path =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   903
  let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   904
    fun check_file_entry f rest =
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   905
      let
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   906
        (*NOTE needed since don't have File.is_link and File.read_link*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   907
        val f_str = Path.implode f
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   908
      in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   909
        if File.is_dir f then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   910
          rest (*filter out directories*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   911
        else if OS.FileSys.isLink f_str then
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   912
          (*follow links -- NOTE this breaks if links are relative paths*)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   913
          check_file_entry (Path.explode (OS.FileSys.readLink f_str)) rest
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   914
        else f :: rest
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   915
      end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   916
  in
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   917
    File.read_dir path
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   918
    |> map
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   919
        (Path.explode
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   920
        #> Path.append path)
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   921
    |> (fn l => fold check_file_entry l [])
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   922
  end
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   923
5d9aab0c609c added tptp parser;
sultana
parents:
diff changeset
   924
end