src/HOL/Tools/Nitpick/kodkod.ML
author blanchet
Mon, 21 Feb 2011 11:50:31 +0100
changeset 41793 c7a2669ae75d
parent 40743 b07a0dbc8a38
child 43085 0a2f5b86bdd7
permissions -rw-r--r--
tweaked Nitpick based on C++ memory model example
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33982
1ae222745c4a fixed paths in Nitpick's ML file headers
blanchet
parents: 33734
diff changeset
     1
(*  Title:      HOL/Tools/Nitpick/kodkod.ML
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     2
    Author:     Jasmin Blanchette, TU Muenchen
34982
7b8c366e34a2 added support for nonstandard models to Nitpick (based on an idea by Koen Claessen) and did other fixes to Nitpick
blanchet
parents: 34936
diff changeset
     3
    Copyright   2008, 2009, 2010
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     4
39456
blanchet
parents: 39326
diff changeset
     5
ML interface for Kodkod.
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     6
*)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     7
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     8
signature KODKOD =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
     9
sig
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    10
  type n_ary_index = int * int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    11
  type setting = string * string
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    12
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    13
  datatype tuple =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    14
    Tuple of int list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    15
    TupleIndex of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    16
    TupleReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    17
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    18
  datatype tuple_set =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    19
    TupleUnion of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    20
    TupleDifference of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    21
    TupleIntersect of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    22
    TupleProduct of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    23
    TupleProject of tuple_set * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    24
    TupleSet of tuple list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    25
    TupleRange of tuple * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    26
    TupleArea of tuple * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    27
    TupleAtomSeq of int * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    28
    TupleSetReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    29
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    30
  datatype tuple_assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    31
    AssignTuple of n_ary_index * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    32
    AssignTupleSet of n_ary_index * tuple_set
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    33
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    34
  type bound = (n_ary_index * string) list * tuple_set list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    35
  type int_bound = int option * tuple_set list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    36
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    37
  datatype formula =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    38
    All of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    39
    Exist of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    40
    FormulaLet of expr_assign list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    41
    FormulaIf of formula * formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    42
    Or of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    43
    Iff of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    44
    Implies of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    45
    And of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    46
    Not of formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    47
    Acyclic of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    48
    Function of n_ary_index * rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    49
    Functional of n_ary_index * rel_expr * rel_expr |
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
    50
    TotalOrdering of n_ary_index * rel_expr * rel_expr * rel_expr |
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    51
    Subset of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    52
    RelEq of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    53
    IntEq of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    54
    LT of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    55
    LE of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    56
    No of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    57
    Lone of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    58
    One of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    59
    Some of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    60
    False |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    61
    True |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    62
    FormulaReg of int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    63
  and rel_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    64
    RelLet of expr_assign list * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    65
    RelIf of formula * rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    66
    Union of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    67
    Difference of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    68
    Override of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    69
    Intersect of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    70
    Product of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    71
    IfNo of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    72
    Project of rel_expr * int_expr list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    73
    Join of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    74
    Closure of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    75
    ReflexiveClosure of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    76
    Transpose of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    77
    Comprehension of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    78
    Bits of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    79
    Int of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    80
    Iden |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    81
    Ints |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    82
    None |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    83
    Univ |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    84
    Atom of int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    85
    AtomSeq of int * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    86
    Rel of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    87
    Var of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    88
    RelReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    89
  and int_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    90
    Sum of decl list * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    91
    IntLet of expr_assign list * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    92
    IntIf of formula * int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    93
    SHL of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    94
    SHA of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    95
    SHR of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    96
    Add of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    97
    Sub of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    98
    Mult of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
    99
    Div of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   100
    Mod of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   101
    Cardinality of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   102
    SetSum of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   103
    BitOr of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   104
    BitXor of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   105
    BitAnd of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   106
    BitNot of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   107
    Neg of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   108
    Absolute of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   109
    Signum of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   110
    Num of int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   111
    IntReg of int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   112
  and decl =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   113
    DeclNo of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   114
    DeclLone of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   115
    DeclOne of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   116
    DeclSome of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   117
    DeclSet of n_ary_index * rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   118
  and expr_assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   119
    AssignFormulaReg of int * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   120
    AssignRelReg of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   121
    AssignIntReg of int * int_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   122
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   123
  type 'a fold_expr_funcs =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   124
    {formula_func: formula -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   125
     rel_expr_func: rel_expr -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   126
     int_expr_func: int_expr -> 'a -> 'a}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   127
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   128
  val fold_formula : 'a fold_expr_funcs -> formula -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   129
  val fold_rel_expr : 'a fold_expr_funcs -> rel_expr -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   130
  val fold_int_expr : 'a fold_expr_funcs -> int_expr -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   131
  val fold_decl : 'a fold_expr_funcs -> decl -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   132
  val fold_expr_assign : 'a fold_expr_funcs -> expr_assign -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   133
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   134
  type 'a fold_tuple_funcs =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   135
    {tuple_func: tuple -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   136
     tuple_set_func: tuple_set -> 'a -> 'a}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   137
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   138
  val fold_tuple : 'a fold_tuple_funcs -> tuple -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   139
  val fold_tuple_set : 'a fold_tuple_funcs -> tuple_set -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   140
  val fold_tuple_assign : 'a fold_tuple_funcs -> tuple_assign -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   141
  val fold_bound :
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   142
      'a fold_expr_funcs -> 'a fold_tuple_funcs -> bound -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   143
  val fold_int_bound : 'a fold_tuple_funcs -> int_bound -> 'a -> 'a
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   144
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   145
  type problem =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   146
    {comment: string,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   147
     settings: setting list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   148
     univ_card: int,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   149
     tuple_assigns: tuple_assign list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   150
     bounds: bound list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   151
     int_bounds: int_bound list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   152
     expr_assigns: expr_assign list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   153
     formula: formula}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   154
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   155
  type raw_bound = n_ary_index * int list list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   156
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   157
  datatype outcome =
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
   158
    JavaNotInstalled |
38516
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
   159
    JavaTooOld |
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
   160
    KodkodiNotInstalled |
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
   161
    Normal of (int * raw_bound list) list * int list * string |
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   162
    TimedOut of int list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   163
    Error of string * int list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   164
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   165
  exception SYNTAX of string * string
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   166
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   167
  val max_arity : int -> int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   168
  val arity_of_rel_expr : rel_expr -> int
35185
9b8f351cced6 added yet another hint to Nitpick's output, this time warning about problems for which nothing was effectively tested
blanchet
parents: 35079
diff changeset
   169
  val is_problem_trivially_false : problem -> bool
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   170
  val problems_equivalent : problem * problem -> bool
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   171
  val solve_any_problem :
41793
c7a2669ae75d tweaked Nitpick based on C++ memory model example
blanchet
parents: 40743
diff changeset
   172
    bool -> bool -> Time.time option -> int -> int -> problem list -> outcome
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   173
end;
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   174
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   175
structure Kodkod : KODKOD =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   176
struct
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   177
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   178
type n_ary_index = int * int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   179
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   180
type setting = string * string
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   181
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   182
datatype tuple =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   183
  Tuple of int list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   184
  TupleIndex of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   185
  TupleReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   186
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   187
datatype tuple_set =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   188
  TupleUnion of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   189
  TupleDifference of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   190
  TupleIntersect of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   191
  TupleProduct of tuple_set * tuple_set |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   192
  TupleProject of tuple_set * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   193
  TupleSet of tuple list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   194
  TupleRange of tuple * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   195
  TupleArea of tuple * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   196
  TupleAtomSeq of int * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   197
  TupleSetReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   198
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   199
datatype tuple_assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   200
  AssignTuple of n_ary_index * tuple |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   201
  AssignTupleSet of n_ary_index * tuple_set
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   202
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   203
type bound = (n_ary_index * string) list * tuple_set list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   204
type int_bound = int option * tuple_set list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   205
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   206
datatype formula =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   207
  All of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   208
  Exist of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   209
  FormulaLet of expr_assign list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   210
  FormulaIf of formula * formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   211
  Or of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   212
  Iff of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   213
  Implies of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   214
  And of formula * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   215
  Not of formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   216
  Acyclic of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   217
  Function of n_ary_index * rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   218
  Functional of n_ary_index * rel_expr * rel_expr |
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   219
  TotalOrdering of n_ary_index * rel_expr * rel_expr * rel_expr |
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   220
  Subset of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   221
  RelEq of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   222
  IntEq of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   223
  LT of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   224
  LE of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   225
  No of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   226
  Lone of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   227
  One of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   228
  Some of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   229
  False |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   230
  True |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   231
  FormulaReg of int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   232
and rel_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   233
  RelLet of expr_assign list * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   234
  RelIf of formula * rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   235
  Union of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   236
  Difference of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   237
  Override of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   238
  Intersect of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   239
  Product of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   240
  IfNo of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   241
  Project of rel_expr * int_expr list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   242
  Join of rel_expr * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   243
  Closure of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   244
  ReflexiveClosure of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   245
  Transpose of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   246
  Comprehension of decl list * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   247
  Bits of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   248
  Int of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   249
  Iden |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   250
  Ints |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   251
  None |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   252
  Univ |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   253
  Atom of int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   254
  AtomSeq of int * int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   255
  Rel of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   256
  Var of n_ary_index |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   257
  RelReg of n_ary_index
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   258
and int_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   259
  Sum of decl list * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   260
  IntLet of expr_assign list * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   261
  IntIf of formula * int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   262
  SHL of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   263
  SHA of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   264
  SHR of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   265
  Add of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   266
  Sub of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   267
  Mult of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   268
  Div of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   269
  Mod of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   270
  Cardinality of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   271
  SetSum of rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   272
  BitOr of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   273
  BitXor of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   274
  BitAnd of int_expr * int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   275
  BitNot of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   276
  Neg of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   277
  Absolute of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   278
  Signum of int_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   279
  Num of int |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   280
  IntReg of int
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   281
and decl =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   282
  DeclNo of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   283
  DeclLone of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   284
  DeclOne of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   285
  DeclSome of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   286
  DeclSet of n_ary_index * rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   287
and expr_assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   288
  AssignFormulaReg of int * formula |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   289
  AssignRelReg of n_ary_index * rel_expr |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   290
  AssignIntReg of int * int_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   291
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   292
type problem =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   293
  {comment: string,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   294
   settings: setting list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   295
   univ_card: int,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   296
   tuple_assigns: tuple_assign list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   297
   bounds: bound list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   298
   int_bounds: int_bound list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   299
   expr_assigns: expr_assign list,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   300
   formula: formula}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   301
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   302
type raw_bound = n_ary_index * int list list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   303
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   304
datatype outcome =
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
   305
  JavaNotInstalled |
38516
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
   306
  JavaTooOld |
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
   307
  KodkodiNotInstalled |
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
   308
  Normal of (int * raw_bound list) list * int list * string |
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   309
  TimedOut of int list |
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   310
  Error of string * int list
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   311
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   312
exception SYNTAX of string * string
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   313
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   314
type 'a fold_expr_funcs =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   315
  {formula_func: formula -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   316
   rel_expr_func: rel_expr -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   317
   int_expr_func: int_expr -> 'a -> 'a}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   318
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   319
fun is_new_kodkodi_version () =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   320
  case getenv "KODKODI_VERSION" of
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   321
    "" => false
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   322
  | s => dict_ord int_ord (s |> space_explode "."
38130
faa18bf13b9b fix bug with Kodkodi < 1.2.14
blanchet
parents: 38126
diff changeset
   323
                             |> map (the_default 0 o Int.fromString),
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   324
                           [1, 2, 13]) = GREATER
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   325
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   326
(** Auxiliary functions on Kodkod problems **)
35718
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   327
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   328
fun fold_formula (F : 'a fold_expr_funcs) formula =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   329
  case formula of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   330
    All (ds, f) => fold (fold_decl F) ds #> fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   331
  | Exist (ds, f) => fold (fold_decl F) ds #> fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   332
  | FormulaLet (bs, f) => fold (fold_expr_assign F) bs #> fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   333
  | FormulaIf (f, f1, f2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   334
    fold_formula F f #> fold_formula F f1 #> fold_formula F f2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   335
  | Or (f1, f2) => fold_formula F f1 #> fold_formula F f2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   336
  | Iff (f1, f2) => fold_formula F f1 #> fold_formula F f2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   337
  | Implies (f1, f2) => fold_formula F f1 #> fold_formula F f2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   338
  | And (f1, f2) => fold_formula F f1 #> fold_formula F f2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   339
  | Not f => fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   340
  | Acyclic x => fold_rel_expr F (Rel x)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   341
  | Function (x, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   342
    fold_rel_expr F (Rel x) #> fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   343
  | Functional (x, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   344
    fold_rel_expr F (Rel x) #> fold_rel_expr F r1 #> fold_rel_expr F r2
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   345
  | TotalOrdering (x, r1, r2, r3) =>
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   346
    fold_rel_expr F (Rel x) #> fold_rel_expr F r1 #> fold_rel_expr F r2
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   347
    #> fold_rel_expr F r3
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   348
  | Subset (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   349
  | RelEq (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   350
  | IntEq (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   351
  | LT (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   352
  | LE (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   353
  | No r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   354
  | Lone r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   355
  | One r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   356
  | Some r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   357
  | False => #formula_func F formula
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   358
  | True => #formula_func F formula
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   359
  | FormulaReg _ => #formula_func F formula
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   360
and fold_rel_expr F rel_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   361
  case rel_expr of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   362
    RelLet (bs, r) => fold (fold_expr_assign F) bs #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   363
  | RelIf (f, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   364
    fold_formula F f #> fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   365
  | Union (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   366
  | Difference (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   367
  | Override (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   368
  | Intersect (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   369
  | Product (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   370
  | IfNo (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   371
  | Project (r1, is) => fold_rel_expr F r1 #> fold (fold_int_expr F) is
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   372
  | Join (r1, r2) => fold_rel_expr F r1 #> fold_rel_expr F r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   373
  | Closure r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   374
  | ReflexiveClosure r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   375
  | Transpose r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   376
  | Comprehension (ds, f) => fold (fold_decl F) ds #> fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   377
  | Bits i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   378
  | Int i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   379
  | Iden => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   380
  | Ints => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   381
  | None => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   382
  | Univ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   383
  | Atom _ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   384
  | AtomSeq _ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   385
  | Rel _ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   386
  | Var _ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   387
  | RelReg _ => #rel_expr_func F rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   388
and fold_int_expr F int_expr =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   389
  case int_expr of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   390
    Sum (ds, i) => fold (fold_decl F) ds #> fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   391
  | IntLet (bs, i) => fold (fold_expr_assign F) bs #> fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   392
  | IntIf (f, i1, i2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   393
    fold_formula F f #> fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   394
  | SHL (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   395
  | SHA (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   396
  | SHR (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   397
  | Add (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   398
  | Sub (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   399
  | Mult (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   400
  | Div (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   401
  | Mod (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   402
  | Cardinality r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   403
  | SetSum r => fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   404
  | BitOr (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   405
  | BitXor (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   406
  | BitAnd (i1, i2) => fold_int_expr F i1 #> fold_int_expr F i2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   407
  | BitNot i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   408
  | Neg i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   409
  | Absolute i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   410
  | Signum i => fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   411
  | Num _ => #int_expr_func F int_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   412
  | IntReg _ => #int_expr_func F int_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   413
and fold_decl F decl =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   414
  case decl of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   415
    DeclNo (x, r) => fold_rel_expr F (Var x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   416
  | DeclLone (x, r) => fold_rel_expr F (Var x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   417
  | DeclOne (x, r) => fold_rel_expr F (Var x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   418
  | DeclSome (x, r) => fold_rel_expr F (Var x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   419
  | DeclSet (x, r) => fold_rel_expr F (Var x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   420
and fold_expr_assign F assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   421
  case assign of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   422
    AssignFormulaReg (x, f) => fold_formula F (FormulaReg x) #> fold_formula F f
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   423
  | AssignRelReg (x, r) => fold_rel_expr F (RelReg x) #> fold_rel_expr F r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   424
  | AssignIntReg (x, i) => fold_int_expr F (IntReg x) #> fold_int_expr F i
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   425
36390
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   426
type 'a fold_tuple_funcs =
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   427
  {tuple_func: tuple -> 'a -> 'a,
eee4ee6a5cbe remove "show_skolems" option and change style of record declarations
blanchet
parents: 36385
diff changeset
   428
   tuple_set_func: tuple_set -> 'a -> 'a}
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   429
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   430
fun fold_tuple (F : 'a fold_tuple_funcs) = #tuple_func F
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   431
fun fold_tuple_set F tuple_set =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   432
  case tuple_set of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   433
    TupleUnion (ts1, ts2) => fold_tuple_set F ts1 #> fold_tuple_set F ts2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   434
  | TupleDifference (ts1, ts2) => fold_tuple_set F ts1 #> fold_tuple_set F ts2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   435
  | TupleIntersect (ts1, ts2) => fold_tuple_set F ts1 #> fold_tuple_set F ts2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   436
  | TupleProduct (ts1, ts2) => fold_tuple_set F ts1 #> fold_tuple_set F ts2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   437
  | TupleProject (ts, _) => fold_tuple_set F ts
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   438
  | TupleSet ts => fold (fold_tuple F) ts
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   439
  | TupleRange (t1, t2) => fold_tuple F t1 #> fold_tuple F t2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   440
  | TupleArea (t1, t2) => fold_tuple F t1 #> fold_tuple F t2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   441
  | TupleAtomSeq _ => #tuple_set_func F tuple_set
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   442
  | TupleSetReg _ => #tuple_set_func F tuple_set
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   443
fun fold_tuple_assign F assign =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   444
  case assign of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   445
    AssignTuple (x, t) => fold_tuple F (TupleReg x) #> fold_tuple F t
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   446
  | AssignTupleSet (x, ts) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   447
    fold_tuple_set F (TupleSetReg x) #> fold_tuple_set F ts
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   448
fun fold_bound expr_F tuple_F (zs, tss) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   449
  fold (fold_rel_expr expr_F) (map (Rel o fst) zs)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   450
  #> fold (fold_tuple_set tuple_F) tss
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   451
fun fold_int_bound F (_, tss) = fold (fold_tuple_set F) tss
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   452
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   453
fun max_arity univ_card = floor (Math.ln 2147483647.0
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   454
                                 / Math.ln (Real.fromInt univ_card))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   455
fun arity_of_rel_expr (RelLet (_, r)) = arity_of_rel_expr r
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   456
  | arity_of_rel_expr (RelIf (_, r1, _)) = arity_of_rel_expr r1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   457
  | arity_of_rel_expr (Union (r1, _)) = arity_of_rel_expr r1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   458
  | arity_of_rel_expr (Difference (r1, _)) = arity_of_rel_expr r1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   459
  | arity_of_rel_expr (Override (r1, _)) = arity_of_rel_expr r1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   460
  | arity_of_rel_expr (Intersect (r1, _)) = arity_of_rel_expr r1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   461
  | arity_of_rel_expr (Product (r1, r2)) = sum_arities_of_rel_exprs r1 r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   462
  | arity_of_rel_expr (IfNo (r1, _)) = arity_of_rel_expr r1
35280
54ab4921f826 fixed a few bugs in Nitpick and removed unreferenced variables
blanchet
parents: 35187
diff changeset
   463
  | arity_of_rel_expr (Project (_, is)) = length is
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   464
  | arity_of_rel_expr (Join (r1, r2)) = sum_arities_of_rel_exprs r1 r2 - 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   465
  | arity_of_rel_expr (Closure _) = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   466
  | arity_of_rel_expr (ReflexiveClosure _) = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   467
  | arity_of_rel_expr (Transpose _) = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   468
  | arity_of_rel_expr (Comprehension (ds, _)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   469
    fold (curry op + o arity_of_decl) ds 0
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   470
  | arity_of_rel_expr (Bits _) = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   471
  | arity_of_rel_expr (Int _) = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   472
  | arity_of_rel_expr Iden = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   473
  | arity_of_rel_expr Ints = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   474
  | arity_of_rel_expr None = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   475
  | arity_of_rel_expr Univ = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   476
  | arity_of_rel_expr (Atom _) = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   477
  | arity_of_rel_expr (AtomSeq _) = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   478
  | arity_of_rel_expr (Rel (n, _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   479
  | arity_of_rel_expr (Var (n, _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   480
  | arity_of_rel_expr (RelReg (n, _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   481
and sum_arities_of_rel_exprs r1 r2 = arity_of_rel_expr r1 + arity_of_rel_expr r2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   482
and arity_of_decl (DeclNo ((n, _), _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   483
  | arity_of_decl (DeclLone ((n, _), _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   484
  | arity_of_decl (DeclOne ((n, _), _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   485
  | arity_of_decl (DeclSome ((n, _), _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   486
  | arity_of_decl (DeclSet ((n, _), _)) = n
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   487
35185
9b8f351cced6 added yet another hint to Nitpick's output, this time warning about problems for which nothing was effectively tested
blanchet
parents: 35079
diff changeset
   488
fun is_problem_trivially_false ({formula = False, ...} : problem) = true
9b8f351cced6 added yet another hint to Nitpick's output, this time warning about problems for which nothing was effectively tested
blanchet
parents: 35079
diff changeset
   489
  | is_problem_trivially_false _ = false
9b8f351cced6 added yet another hint to Nitpick's output, this time warning about problems for which nothing was effectively tested
blanchet
parents: 35079
diff changeset
   490
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   491
val chop_solver = take 2 o space_explode ","
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   492
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   493
fun settings_equivalent ([], []) = true
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   494
  | settings_equivalent ((key1, value1) :: settings1,
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   495
                         (key2, value2) :: settings2) =
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   496
    key1 = key2 andalso
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   497
    (value1 = value2 orelse key1 = "delay" orelse
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   498
     (key1 = "solver" andalso chop_solver value1 = chop_solver value2)) andalso
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   499
    settings_equivalent (settings1, settings2)
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   500
  | settings_equivalent _ = false
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   501
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   502
fun problems_equivalent (p1 : problem, p2 : problem) =
34936
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   503
  #univ_card p1 = #univ_card p2 andalso
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   504
  #formula p1 = #formula p2 andalso
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   505
  #bounds p1 = #bounds p2 andalso
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   506
  #expr_assigns p1 = #expr_assigns p2 andalso
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   507
  #tuple_assigns p1 = #tuple_assigns p2 andalso
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   508
  #int_bounds p1 = #int_bounds p2 andalso
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   509
  settings_equivalent (#settings p1, #settings p2)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   510
35718
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   511
(** Serialization of problem **)
34998
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
   512
34124
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   513
fun base_name j =
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   514
  if j < 0 then string_of_int (~j - 1) ^ "'" else string_of_int j
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   515
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   516
fun n_ary_name (1, j) prefix _ _ = prefix ^ base_name j
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   517
  | n_ary_name (2, j) _ prefix _ = prefix ^ base_name j
34124
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   518
  | n_ary_name (n, j) _ _ prefix = prefix ^ string_of_int n ^ "_" ^ base_name j
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   519
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   520
fun atom_name j = "A" ^ base_name j
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   521
fun atom_seq_name (k, 0) = "u" ^ base_name k
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   522
  | atom_seq_name (k, j0) = "u" ^ base_name k ^ "@" ^ base_name j0
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   523
fun formula_reg_name j = "$f" ^ base_name j
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   524
fun rel_reg_name j = "$e" ^ base_name j
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   525
fun int_reg_name j = "$i" ^ base_name j
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   526
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   527
fun tuple_name x = n_ary_name x "A" "P" "T"
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   528
fun rel_name new_kodkodi (n, j) =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   529
  n_ary_name (n, if new_kodkodi then j
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   530
                 else if j >= 0 then 2 * j
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   531
                 else 2 * ~j - 1) "s" "r" "m"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   532
fun var_name x = n_ary_name x "S" "R" "M"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   533
fun tuple_reg_name x = n_ary_name x "$A" "$P" "$T"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   534
fun tuple_set_reg_name x = n_ary_name x "$a" "$p" "$t"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   535
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   536
fun inline_comment "" = ""
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   537
  | inline_comment comment =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   538
    " /* " ^ translate_string (fn "\n" => " " | "*" => "* " | s => s) comment ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   539
    " */"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   540
fun block_comment "" = ""
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   541
  | block_comment comment = prefix_lines "// " comment ^ "\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   542
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   543
fun commented_rel_name new_kodkodi (x, s) =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   544
  rel_name new_kodkodi x ^ inline_comment s
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   545
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   546
fun string_for_tuple (Tuple js) = "[" ^ commas (map atom_name js) ^ "]"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   547
  | string_for_tuple (TupleIndex x) = tuple_name x
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   548
  | string_for_tuple (TupleReg x) = tuple_reg_name x
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   549
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   550
val no_prec = 100
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   551
val prec_TupleUnion = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   552
val prec_TupleIntersect = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   553
val prec_TupleProduct = 3
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   554
val prec_TupleProject = 4
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   555
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   556
fun precedence_ts (TupleUnion _) = prec_TupleUnion
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   557
  | precedence_ts (TupleDifference _) = prec_TupleUnion
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   558
  | precedence_ts (TupleIntersect _) = prec_TupleIntersect
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   559
  | precedence_ts (TupleProduct _) = prec_TupleProduct
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   560
  | precedence_ts (TupleProject _) = prec_TupleProject
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   561
  | precedence_ts _ = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   562
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   563
fun string_for_tuple_set tuple_set =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   564
  let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   565
    fun sub tuple_set outer_prec =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   566
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   567
        val prec = precedence_ts tuple_set
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   568
        val need_parens = (prec < outer_prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   569
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   570
        (if need_parens then "(" else "") ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   571
        (case tuple_set of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   572
           TupleUnion (ts1, ts2) => sub ts1 prec ^ " + " ^ sub ts2 (prec + 1)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   573
         | TupleDifference (ts1, ts2) =>
35280
54ab4921f826 fixed a few bugs in Nitpick and removed unreferenced variables
blanchet
parents: 35187
diff changeset
   574
           sub ts1 prec ^ " - " ^ sub ts2 (prec + 1)
54ab4921f826 fixed a few bugs in Nitpick and removed unreferenced variables
blanchet
parents: 35187
diff changeset
   575
         | TupleIntersect (ts1, ts2) => sub ts1 prec ^ " & " ^ sub ts2 prec
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   576
         | TupleProduct (ts1, ts2) => sub ts1 prec ^ "->" ^ sub ts2 prec
34124
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   577
         | TupleProject (ts, c) => sub ts prec ^ "[" ^ string_of_int c ^ "]"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   578
         | TupleSet ts => "{" ^ commas (map string_for_tuple ts) ^ "}"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   579
         | TupleRange (t1, t2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   580
           "{" ^ string_for_tuple t1 ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   581
           (if t1 = t2 then "" else " .. " ^ string_for_tuple t2) ^ "}"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   582
         | TupleArea (t1, t2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   583
           "{" ^ string_for_tuple t1 ^ " # " ^ string_for_tuple t2 ^ "}"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   584
         | TupleAtomSeq x => atom_seq_name x
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   585
         | TupleSetReg x => tuple_set_reg_name x) ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   586
        (if need_parens then ")" else "")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   587
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   588
  in sub tuple_set 0 end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   589
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   590
fun string_for_tuple_assign (AssignTuple (x, t)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   591
    tuple_reg_name x ^ " := " ^ string_for_tuple t ^ "\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   592
  | string_for_tuple_assign (AssignTupleSet (x, ts)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   593
    tuple_set_reg_name x ^ " := " ^ string_for_tuple_set ts ^ "\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   594
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   595
fun string_for_bound new_kodkodi (zs, tss) =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   596
  "bounds " ^ commas (map (commented_rel_name new_kodkodi) zs) ^ ": " ^
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   597
  (if length tss = 1 then "" else "[") ^ commas (map string_for_tuple_set tss) ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   598
  (if length tss = 1 then "" else "]") ^ "\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   599
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   600
fun int_string_for_bound (opt_n, tss) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   601
  (case opt_n of
34124
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   602
     SOME n => signed_string_of_int n ^ ": "
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   603
   | NONE => "") ^ "[" ^ commas (map string_for_tuple_set tss) ^ "]"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   604
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   605
val prec_All = 1
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   606
val prec_Or = 2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   607
val prec_Iff = 3
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   608
val prec_Implies = 4
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   609
val prec_And = 5
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   610
val prec_Not = 6
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   611
val prec_Eq = 7
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   612
val prec_Some = 8
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   613
val prec_SHL = 9
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   614
val prec_Add = 10
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   615
val prec_Mult = 11
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   616
val prec_Override = 12
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   617
val prec_Intersect = 13
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   618
val prec_Product = 14
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   619
val prec_IfNo = 15
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   620
val prec_Project = 17
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   621
val prec_Join = 18
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   622
val prec_BitNot = 19
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   623
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   624
fun precedence_f (All _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   625
  | precedence_f (Exist _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   626
  | precedence_f (FormulaLet _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   627
  | precedence_f (FormulaIf _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   628
  | precedence_f (Or _) = prec_Or
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   629
  | precedence_f (Iff _) = prec_Iff
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   630
  | precedence_f (Implies _) = prec_Implies
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   631
  | precedence_f (And _) = prec_And
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   632
  | precedence_f (Not _) = prec_Not
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   633
  | precedence_f (Acyclic _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   634
  | precedence_f (Function _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   635
  | precedence_f (Functional _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   636
  | precedence_f (TotalOrdering _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   637
  | precedence_f (Subset _) = prec_Eq
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   638
  | precedence_f (RelEq _) = prec_Eq
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   639
  | precedence_f (IntEq _) = prec_Eq
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   640
  | precedence_f (LT _) = prec_Eq
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   641
  | precedence_f (LE _) = prec_Eq
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   642
  | precedence_f (No _) = prec_Some
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   643
  | precedence_f (Lone _) = prec_Some
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   644
  | precedence_f (One _) = prec_Some
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   645
  | precedence_f (Some _) = prec_Some
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   646
  | precedence_f False = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   647
  | precedence_f True = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   648
  | precedence_f (FormulaReg _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   649
and precedence_r (RelLet _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   650
  | precedence_r (RelIf _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   651
  | precedence_r (Union _) = prec_Add
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   652
  | precedence_r (Difference _) = prec_Add
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   653
  | precedence_r (Override _) = prec_Override
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   654
  | precedence_r (Intersect _) = prec_Intersect
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   655
  | precedence_r (Product _) = prec_Product
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   656
  | precedence_r (IfNo _) = prec_IfNo
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   657
  | precedence_r (Project _) = prec_Project
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   658
  | precedence_r (Join _) = prec_Join
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   659
  | precedence_r (Closure _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   660
  | precedence_r (ReflexiveClosure _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   661
  | precedence_r (Transpose _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   662
  | precedence_r (Comprehension _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   663
  | precedence_r (Bits _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   664
  | precedence_r (Int _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   665
  | precedence_r Iden = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   666
  | precedence_r Ints = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   667
  | precedence_r None = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   668
  | precedence_r Univ = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   669
  | precedence_r (Atom _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   670
  | precedence_r (AtomSeq _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   671
  | precedence_r (Rel _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   672
  | precedence_r (Var _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   673
  | precedence_r (RelReg _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   674
and precedence_i (Sum _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   675
  | precedence_i (IntLet _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   676
  | precedence_i (IntIf _) = prec_All
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   677
  | precedence_i (SHL _) = prec_SHL
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   678
  | precedence_i (SHA _) = prec_SHL
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   679
  | precedence_i (SHR _) = prec_SHL
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   680
  | precedence_i (Add _) = prec_Add
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   681
  | precedence_i (Sub _) = prec_Add
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   682
  | precedence_i (Mult _) = prec_Mult
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   683
  | precedence_i (Div _) = prec_Mult
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   684
  | precedence_i (Mod _) = prec_Mult
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   685
  | precedence_i (Cardinality _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   686
  | precedence_i (SetSum _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   687
  | precedence_i (BitOr _) = prec_Intersect
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   688
  | precedence_i (BitXor _) = prec_Intersect
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   689
  | precedence_i (BitAnd _) = prec_Intersect
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   690
  | precedence_i (BitNot _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   691
  | precedence_i (Neg _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   692
  | precedence_i (Absolute _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   693
  | precedence_i (Signum _) = prec_BitNot
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   694
  | precedence_i (Num _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   695
  | precedence_i (IntReg _) = no_prec
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   696
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   697
fun write_problem_file out problems =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   698
  let
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   699
    val new_kodkodi = is_new_kodkodi_version ()
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   700
    val rel_name = rel_name new_kodkodi
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   701
    fun out_outmost_f (And (f1, f2)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   702
        (out_outmost_f f1; out "\n   && "; out_outmost_f f2)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   703
      | out_outmost_f f = out_f f prec_And
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   704
    and out_f formula outer_prec =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   705
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   706
        val prec = precedence_f formula
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   707
        val need_parens = (prec < outer_prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   708
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   709
        (if need_parens then out "(" else ());
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   710
        (case formula of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   711
           All (ds, f) => (out "all ["; out_decls ds; out "] | "; out_f f prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   712
         | Exist (ds, f) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   713
           (out "some ["; out_decls ds; out "] | "; out_f f prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   714
         | FormulaLet (bs, f) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   715
           (out "let ["; out_assigns bs; out "] | "; out_f f prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   716
         | FormulaIf (f, f1, f2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   717
           (out "if "; out_f f prec; out " then "; out_f f1 prec; out " else ";
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   718
            out_f f2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   719
         | Or (f1, f2) => (out_f f1 prec; out " || "; out_f f2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   720
         | Iff (f1, f2) => (out_f f1 prec; out " <=> "; out_f f2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   721
         | Implies (f1, f2) => (out_f f1 (prec + 1); out " => "; out_f f2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   722
         | And (f1, f2) => (out_f f1 prec; out " && "; out_f f2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   723
         | Not f => (out "! "; out_f f prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   724
         | Acyclic x => out ("ACYCLIC(" ^ rel_name x ^ ")")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   725
         | Function (x, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   726
           (out ("FUNCTION(" ^ rel_name x ^ ", "); out_r r1 0; out " -> one ";
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   727
            out_r r2 0; out ")")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   728
         | Functional (x, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   729
           (out ("FUNCTION(" ^ rel_name x ^ ", "); out_r r1 0; out " -> lone ";
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   730
            out_r r2 0; out ")")
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   731
         | TotalOrdering (x, r1, r2, r3) =>
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   732
           (out ("TOTAL_ORDERING(" ^ rel_name x ^ ", "); out_r r1 0; out ", ";
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   733
            out_r r2 0; out ", "; out_r r3 0; out ")")
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   734
         | Subset (r1, r2) => (out_r r1 prec; out " in "; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   735
         | RelEq (r1, r2) => (out_r r1 prec; out " = "; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   736
         | IntEq (i1, i2) => (out_i i1 prec; out " = "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   737
         | LT (i1, i2) => (out_i i1 prec; out " < "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   738
         | LE (i1, i2) => (out_i i1 prec; out " <= "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   739
         | No r => (out "no "; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   740
         | Lone r => (out "lone "; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   741
         | One r => (out "one "; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   742
         | Some r => (out "some "; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   743
         | False => out "false"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   744
         | True => out "true"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   745
         | FormulaReg j => out (formula_reg_name j));
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   746
        (if need_parens then out ")" else ())
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   747
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   748
    and out_r rel_expr outer_prec =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   749
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   750
        val prec = precedence_r rel_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   751
        val need_parens = (prec < outer_prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   752
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   753
        (if need_parens then out "(" else ());
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   754
        (case rel_expr of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   755
           RelLet (bs, r) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   756
           (out "let ["; out_assigns bs; out "] | "; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   757
         | RelIf (f, r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   758
           (out "if "; out_f f prec; out " then "; out_r r1 prec;
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   759
            out " else "; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   760
         | Union (r1, r2) => (out_r r1 prec; out " + "; out_r r2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   761
         | Difference (r1, r2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   762
           (out_r r1 prec; out " - "; out_r r2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   763
         | Override (r1, r2) => (out_r r1 prec; out " ++ "; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   764
         | Intersect (r1, r2) => (out_r r1 prec; out " & "; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   765
         | Product (r1, r2) => (out_r r1 prec; out "->"; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   766
         | IfNo (r1, r2) => (out_r r1 prec; out "\\"; out_r r2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   767
         | Project (r1, is) => (out_r r1 prec; out "["; out_columns is; out "]")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   768
         | Join (r1, r2) => (out_r r1 prec; out "."; out_r r2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   769
         | Closure r => (out "^"; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   770
         | ReflexiveClosure r => (out "*"; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   771
         | Transpose r => (out "~"; out_r r prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   772
         | Comprehension (ds, f) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   773
           (out "{["; out_decls ds; out "] | "; out_f f 0; out "}")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   774
         | Bits i => (out "Bits["; out_i i 0; out "]")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   775
         | Int i => (out "Int["; out_i i 0; out "]")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   776
         | Iden => out "iden"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   777
         | Ints => out "ints"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   778
         | None => out "none"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   779
         | Univ => out "univ"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   780
         | Atom j => out (atom_name j)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   781
         | AtomSeq x => out (atom_seq_name x)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   782
         | Rel x => out (rel_name x)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   783
         | Var x => out (var_name x)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   784
         | RelReg (_, j) => out (rel_reg_name j));
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   785
        (if need_parens then out ")" else ())
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   786
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   787
    and out_i int_expr outer_prec =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   788
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   789
        val prec = precedence_i int_expr
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   790
        val need_parens = (prec < outer_prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   791
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   792
        (if need_parens then out "(" else ());
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   793
        (case int_expr of
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   794
           Sum (ds, i) => (out "sum ["; out_decls ds; out "] | "; out_i i prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   795
         | IntLet (bs, i) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   796
           (out "let ["; out_assigns bs; out "] | "; out_i i prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   797
         | IntIf (f, i1, i2) =>
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   798
           (out "if "; out_f f prec; out " then "; out_i i1 prec;
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   799
            out " else "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   800
         | SHL (i1, i2) => (out_i i1 prec; out " << "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   801
         | SHA (i1, i2) => (out_i i1 prec; out " >> "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   802
         | SHR (i1, i2) => (out_i i1 prec; out " >>> "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   803
         | Add (i1, i2) => (out_i i1 prec; out " + "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   804
         | Sub (i1, i2) => (out_i i1 prec; out " - "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   805
         | Mult (i1, i2) => (out_i i1 prec; out " * "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   806
         | Div (i1, i2) => (out_i i1 prec; out " / "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   807
         | Mod (i1, i2) => (out_i i1 prec; out " % "; out_i i2 (prec + 1))
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   808
         | Cardinality r => (out "#("; out_r r 0; out ")")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   809
         | SetSum r => (out "sum("; out_r r 0; out ")")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   810
         | BitOr (i1, i2) => (out_i i1 prec; out " | "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   811
         | BitXor (i1, i2) => (out_i i1 prec; out " ^ "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   812
         | BitAnd (i1, i2) => (out_i i1 prec; out " & "; out_i i2 prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   813
         | BitNot i => (out "~"; out_i i prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   814
         | Neg i => (out "-"; out_i i prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   815
         | Absolute i => (out "abs "; out_i i prec)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   816
         | Signum i => (out "sgn "; out_i i prec)
34124
c4628a1dcf75 added support for binary nat/int representation to Nitpick
blanchet
parents: 34121
diff changeset
   817
         | Num k => out (signed_string_of_int k)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   818
         | IntReg j => out (int_reg_name j));
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   819
        (if need_parens then out ")" else ())
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   820
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   821
    and out_decls [] = ()
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   822
      | out_decls [d] = out_decl d
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   823
      | out_decls (d :: ds) = (out_decl d; out ", "; out_decls ds)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   824
    and out_decl (DeclNo (x, r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   825
        (out (var_name x); out " : no "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   826
      | out_decl (DeclLone (x, r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   827
        (out (var_name x); out " : lone "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   828
      | out_decl (DeclOne (x, r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   829
        (out (var_name x); out " : one "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   830
      | out_decl (DeclSome (x, r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   831
        (out (var_name x); out " : some "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   832
      | out_decl (DeclSet (x, r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   833
        (out (var_name x); out " : set "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   834
    and out_assigns [] = ()
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   835
      | out_assigns [b] = out_assign b
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   836
      | out_assigns (b :: bs) = (out_assign b; out ", "; out_assigns bs)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   837
    and out_assign (AssignFormulaReg (j, f)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   838
        (out (formula_reg_name j); out " := "; out_f f 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   839
      | out_assign (AssignRelReg ((_, j), r)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   840
        (out (rel_reg_name j); out " := "; out_r r 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   841
      | out_assign (AssignIntReg (j, i)) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   842
        (out (int_reg_name j); out " := "; out_i i 0)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   843
    and out_columns [] = ()
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   844
      | out_columns [i] = out_i i 0
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   845
      | out_columns (i :: is) = (out_i i 0; out ", "; out_columns is)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   846
    and out_problem {comment, settings, univ_card, tuple_assigns, bounds,
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   847
                     int_bounds, expr_assigns, formula} =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   848
        (out ("\n" ^ block_comment comment ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   849
              implode (map (fn (key, value) => key ^ ": " ^ value ^ "\n")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   850
                            settings) ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   851
              "univ: " ^ atom_seq_name (univ_card, 0) ^ "\n" ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   852
              implode (map string_for_tuple_assign tuple_assigns) ^
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   853
              implode (map (string_for_bound new_kodkodi) bounds) ^
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   854
              (if int_bounds = [] then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   855
                 ""
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   856
               else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   857
                 "int_bounds: " ^
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   858
                 commas (map int_string_for_bound int_bounds) ^ "\n"));
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   859
         map (fn b => (out_assign b; out ";")) expr_assigns;
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   860
         out "solve "; out_outmost_f formula; out ";\n")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   861
  in
35695
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
   862
    out ("// This file was generated by Isabelle (most likely Nitpick)\n" ^
38019
e207a64e1e0b complete renaming of "Sledgehammer_TPTP_Format" to "ATP_Problem"
blanchet
parents: 36914
diff changeset
   863
         "// " ^ ATP_Problem.timestamp () ^ "\n");
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   864
    map out_problem problems
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   865
  end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   866
35718
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   867
(** Parsing of solution **)
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   868
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   869
fun is_ident_char s =
34936
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   870
  Symbol.is_ascii_letter s orelse Symbol.is_ascii_digit s orelse
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   871
  s = "_" orelse s = "'" orelse s = "$"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   872
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   873
fun strip_blanks [] = []
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   874
  | strip_blanks (" " :: ss) = strip_blanks ss
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   875
  | strip_blanks [s1, " "] = [s1]
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   876
  | strip_blanks (s1 :: " " :: s2 :: ss) =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   877
    if is_ident_char s1 andalso is_ident_char s2 then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   878
      s1 :: " " :: strip_blanks (s2 :: ss)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   879
    else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   880
      strip_blanks (s1 :: s2 :: ss)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   881
  | strip_blanks (s :: ss) = s :: strip_blanks ss
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   882
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   883
val scan_nat =
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   884
  Scan.repeat1 (Scan.one Symbol.is_ascii_digit)
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   885
  >> (the o Int.fromString o space_implode "")
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   886
fun scan_rel_name new_kodkodi =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   887
  ($$ "s" |-- scan_nat >> pair 1
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   888
   || $$ "r" |-- scan_nat >> pair 2
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   889
   || ($$ "m" |-- scan_nat --| $$ "_") -- scan_nat) -- Scan.option ($$ "'")
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   890
  >> (fn ((n, j), SOME _) => (n, ~j - 1)
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   891
       | ((n, j), NONE) => (n, if new_kodkodi then j
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   892
                               else if j mod 2 = 0 then j div 2
38130
faa18bf13b9b fix bug with Kodkodi < 1.2.14
blanchet
parents: 38126
diff changeset
   893
                               else ~(j + 1) div 2))
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   894
val scan_atom = $$ "A" |-- scan_nat
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   895
fun parse_non_empty_list scan = scan ::: Scan.repeat ($$ "," |-- scan)
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   896
fun parse_list scan = parse_non_empty_list scan || Scan.succeed []
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   897
val parse_tuple = $$ "[" |-- parse_list scan_atom --| $$ "]"
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   898
val parse_tuple_set = $$ "[" |-- parse_list parse_tuple --| $$ "]"
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   899
fun parse_assignment new_kodkodi =
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   900
  (scan_rel_name new_kodkodi --| $$ "=") -- parse_tuple_set
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   901
fun parse_instance new_kodkodi =
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   902
  Scan.this_string "relations:"
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   903
  |-- $$ "{" |-- parse_list (parse_assignment new_kodkodi) --| $$ "}"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   904
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   905
fun extract_instance new_kodkodi =
35336
ef3eba82465f cosmetics
blanchet
parents: 35333
diff changeset
   906
  fst o Scan.finite Symbol.stopper
ef3eba82465f cosmetics
blanchet
parents: 35333
diff changeset
   907
            (Scan.error (!! (fn _ =>
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   908
                                raise SYNTAX ("Kodkod.extract_instance",
35336
ef3eba82465f cosmetics
blanchet
parents: 35333
diff changeset
   909
                                              "ill-formed Kodkodi output"))
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   910
                            (parse_instance new_kodkodi)))
40627
becf5d5187cc renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents: 40411
diff changeset
   911
  o strip_blanks o raw_explode
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   912
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   913
val problem_marker = "*** PROBLEM "
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   914
val outcome_marker = "---OUTCOME---\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   915
val instance_marker = "---INSTANCE---\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   916
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   917
fun read_section_body marker =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   918
  Substring.string o fst o Substring.position "\n\n"
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   919
  o Substring.triml (size marker)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   920
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   921
fun read_next_instance new_kodkodi s =
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   922
  let val s = Substring.position instance_marker s |> snd in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   923
    if Substring.isEmpty s then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   924
      raise SYNTAX ("Kodkod.read_next_instance", "expected \"INSTANCE\" marker")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   925
    else
38198
e26905526f7f rename internal functions
blanchet
parents: 38189
diff changeset
   926
      read_section_body instance_marker s |> extract_instance new_kodkodi
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   927
  end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   928
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   929
fun read_next_outcomes new_kodkodi j (s, ps, js) =
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   930
  let val (s1, s2) = Substring.position outcome_marker s in
34936
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   931
    if Substring.isEmpty s2 orelse
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   932
       not (Substring.isEmpty (Substring.position problem_marker s1
c4f04bee79f3 some work on Nitpick's support for quotient types;
blanchet
parents: 34124
diff changeset
   933
                               |> snd)) then
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   934
      (s, ps, js)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   935
    else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   936
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   937
        val outcome = read_section_body outcome_marker s2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   938
        val s = Substring.triml (size outcome_marker) s2
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   939
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   940
        if String.isSuffix "UNSATISFIABLE" outcome then
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   941
          read_next_outcomes new_kodkodi j (s, ps, j :: js)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   942
        else if String.isSuffix "SATISFIABLE" outcome then
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   943
          read_next_outcomes new_kodkodi j
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   944
                           (s, (j, read_next_instance new_kodkodi s2) :: ps, js)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   945
        else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   946
          raise SYNTAX ("Kodkod.read_next_outcomes",
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   947
                        "unknown outcome " ^ quote outcome)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   948
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   949
  end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   950
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   951
fun read_next_problems new_kodkodi (s, ps, js) =
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   952
  let val s = Substring.position problem_marker s |> snd in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   953
    if Substring.isEmpty s then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   954
      (ps, js)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   955
    else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   956
      let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   957
        val s = Substring.triml (size problem_marker) s
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   958
        val j_plus_1 = s |> Substring.takel (not_equal #" ") |> Substring.string
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   959
                         |> Int.fromString |> the
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   960
        val j = j_plus_1 - 1
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   961
      in
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   962
        read_next_problems new_kodkodi
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   963
                           (read_next_outcomes new_kodkodi j (s, ps, js))
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   964
      end
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   965
  end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   966
  handle Option.Option => raise SYNTAX ("Kodkod.read_next_problems",
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   967
                                        "expected number after \"PROBLEM\"")
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   968
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   969
fun read_output_file new_kodkodi path =
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   970
  (false,
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   971
   read_next_problems new_kodkodi (Substring.full (File.read path), [], [])
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
   972
   |>> rev ||> rev)
35309
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
   973
  handle IO.Io _ => (true, ([], [])) | OS.SysErr _ => (true, ([], []))
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
   974
35718
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   975
(** Main Kodkod entry point **)
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   976
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   977
val created_temp_dir = Unsynchronized.ref false
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   978
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   979
fun serial_string_and_temporary_dir_for_overlord overlord =
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   980
  if overlord then
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   981
    ("", getenv "ISABELLE_HOME_USER")
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   982
  else
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   983
    let
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   984
      val dir = getenv "ISABELLE_TMP"
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   985
      val _ = if !created_temp_dir then ()
40743
b07a0dbc8a38 more explicit Isabelle_System operations;
wenzelm
parents: 40627
diff changeset
   986
              else (created_temp_dir := true; Isabelle_System.mkdirs (Path.explode dir))
35718
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   987
    in (serial_string (), dir) end
eee1a5e0d334 moved some Nitpick code around
blanchet
parents: 35696
diff changeset
   988
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   989
(* The fudge term below is to account for Kodkodi's slow start-up time, which
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   990
   is partly due to the JVM and partly due to the ML "bash" function. *)
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   991
val fudge_ms = 250
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   992
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   993
fun milliseconds_until_deadline deadline =
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   994
  case deadline of
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   995
    NONE => ~1
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   996
  | SOME time =>
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   997
    Int.max (0, Time.toMilliseconds (Time.- (time, Time.now ())) - fudge_ms)
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   998
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
   999
fun uncached_solve_any_problem overlord deadline max_threads max_solutions
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1000
                               problems =
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1001
  let
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
  1002
    val new_kodkodi = is_new_kodkodi_version ()
34121
5e831d805118 get rid of polymorphic equality in Nitpick's code + a few minor cleanups
blanchet
parents: 33982
diff changeset
  1003
    val j = find_index (curry (op =) True o #formula) problems
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1004
    val indexed_problems = if j >= 0 then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1005
                             [(j, nth problems j)]
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1006
                           else
35187
3acab6c90d4a don't destroy "Suc" in Nitpick and fix logic of Kodkod filtering (accidentally flipped in previous change)
blanchet
parents: 35185
diff changeset
  1007
                             filter_out (is_problem_trivially_false o snd)
3acab6c90d4a don't destroy "Suc" in Nitpick and fix logic of Kodkod filtering (accidentally flipped in previous change)
blanchet
parents: 35185
diff changeset
  1008
                                        (0 upto length problems - 1 ~~ problems)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1009
    val triv_js = filter_out (AList.defined (op =) indexed_problems)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1010
                             (0 upto length problems - 1)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1011
    val reindex = fst o nth indexed_problems
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1012
  in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1013
    if null indexed_problems then
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
  1014
      Normal ([], triv_js, "")
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1015
    else
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1016
      let
34998
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1017
        val (serial_str, temp_dir) =
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1018
          serial_string_and_temporary_dir_for_overlord overlord
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1019
        fun path_for suf =
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1020
          Path.explode (temp_dir ^ "/kodkodi" ^ serial_str ^ "." ^ suf)
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1021
        val in_path = path_for "kki"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1022
        val in_buf = Unsynchronized.ref Buffer.empty
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1023
        fun out s = Unsynchronized.change in_buf (Buffer.add s)
34998
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1024
        val out_path = path_for "out"
5e492a862b34 four changes to Nitpick:
blanchet
parents: 34982
diff changeset
  1025
        val err_path = path_for "err"
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1026
        val _ = write_problem_file out (map snd indexed_problems)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1027
        val _ = File.write_buffer in_path (!in_buf)
33575
118517551c12 try very hard to remove temporary files generated by Nitpick in case of interruption
blanchet
parents: 33233
diff changeset
  1028
        fun remove_temporary_files () =
118517551c12 try very hard to remove temporary files generated by Nitpick in case of interruption
blanchet
parents: 33233
diff changeset
  1029
          if overlord then ()
35309
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
  1030
          else List.app (K () o try File.rm) [in_path, out_path, err_path]
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1031
      in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1032
        let
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1033
          val ms = milliseconds_until_deadline deadline
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1034
          val outcome =
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1035
            let
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1036
              val code =
40265
ee578bc82cbc no need for setting up the kodkodi environment since Kodkodi 1.2.9
blanchet
parents: 39456
diff changeset
  1037
                bash ("cd " ^ File.shell_quote temp_dir ^ ";\n\
35079
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1038
                      \\"$KODKODI\"/bin/kodkodi" ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1039
                      (if ms >= 0 then " -max-msecs " ^ string_of_int ms
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1040
                       else "") ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1041
                      (if max_solutions > 1 then " -solve-all" else "") ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1042
                      " -max-solutions " ^ string_of_int max_solutions ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1043
                      (if max_threads > 0 then
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1044
                         " -max-threads " ^ string_of_int max_threads
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1045
                       else
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1046
                         "") ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1047
                      " < " ^ File.shell_path in_path ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1048
                      " > " ^ File.shell_path out_path ^
592edca1dfb3 merged (manual for "nitpick_hol.ML" and "kodkod.ML")
blanchet
parents: 35011 35074
diff changeset
  1049
                      " 2> " ^ File.shell_path err_path)
35309
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
  1050
              val (io_error, (ps, nontriv_js)) =
38126
8031d099379a added manual symmetry breaking for datatypes
blanchet
parents: 38019
diff changeset
  1051
                read_output_file new_kodkodi out_path
35309
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
  1052
                ||> apfst (map (apfst reindex)) ||> apsnd (map reindex)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1053
              val js = triv_js @ nontriv_js
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1054
              val first_error =
35695
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1055
                (File.fold_lines (fn line => fn "" => line | s => s) err_path ""
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1056
                 handle IO.Io _ => "" | OS.SysErr _ => "")
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1057
                |> perhaps (try (unsuffix "\r"))
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1058
                |> perhaps (try (unsuffix "."))
36914
1806aa69bd62 recognize new Kodkod error message syntax
blanchet
parents: 36390
diff changeset
  1059
                |> perhaps (try (unprefix "Solve error: "))
35695
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1060
                |> perhaps (try (unprefix "Error: "))
38516
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1061
              fun has_error s =
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1062
                first_error |> Substring.full |> Substring.position s |> snd
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1063
                            |> Substring.isEmpty |> not
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1064
            in
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1065
              if null ps then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1066
                if code = 2 then
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1067
                  TimedOut js
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
  1068
                else if code = 0 then
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
  1069
                  Normal ([], js, first_error)
38516
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1070
                else if has_error "exec: java" then
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
  1071
                  JavaNotInstalled
38516
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1072
                else if has_error "UnsupportedClassVersionError" then
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1073
                  JavaTooOld
307669429dc1 gracefully handle the case where the JVM is too old in Nitpick
blanchet
parents: 38198
diff changeset
  1074
                else if has_error "NoClassDefFoundError" then
35696
17ae461d6133 show nice error message in Nitpick when "java" is not available
blanchet
parents: 35695
diff changeset
  1075
                  KodkodiNotInstalled
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1076
                else if first_error <> "" then
35695
80b2c22f8f00 fixed soundness bug in Nitpick
blanchet
parents: 35336
diff changeset
  1077
                  Error (first_error, js)
35309
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
  1078
                else if io_error then
997aa3a3e4bb catch IO errors in Nitpick's "kodkodi" invocation + shorten execution time of "Manual_Nits" example
blanchet
parents: 35280
diff changeset
  1079
                  Error ("I/O error", js)
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
  1080
                else
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1081
                  Error ("Unknown error", js)
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1082
              else
35333
f61de25f71f9 distinguish between Kodkodi warnings and errors in Nitpick;
blanchet
parents: 35309
diff changeset
  1083
                Normal (ps, js, first_error)
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1084
            end
33575
118517551c12 try very hard to remove temporary files generated by Nitpick in case of interruption
blanchet
parents: 33233
diff changeset
  1085
        in remove_temporary_files (); outcome end
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1086
      end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1087
  end
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1088
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1089
val cached_outcome =
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1090
  Synchronized.var "Kodkod.cached_outcome"
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1091
                   (NONE : ((int * problem list) * outcome) option)
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1092
41793
c7a2669ae75d tweaked Nitpick based on C++ memory model example
blanchet
parents: 40743
diff changeset
  1093
fun solve_any_problem debug overlord deadline max_threads max_solutions
c7a2669ae75d tweaked Nitpick based on C++ memory model example
blanchet
parents: 40743
diff changeset
  1094
                      problems =
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1095
  let
38189
blanchet
parents: 38130
diff changeset
  1096
    fun do_solve () =
blanchet
parents: 38130
diff changeset
  1097
      uncached_solve_any_problem overlord deadline max_threads max_solutions
blanchet
parents: 38130
diff changeset
  1098
                                 problems
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1099
  in
41793
c7a2669ae75d tweaked Nitpick based on C++ memory model example
blanchet
parents: 40743
diff changeset
  1100
    if debug orelse overlord then
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1101
      do_solve ()
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1102
    else
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1103
      case AList.lookup (fn ((max1, ps1), (max2, ps2)) =>
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1104
                            max1 = max2 andalso length ps1 = length ps2 andalso
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1105
                            forall problems_equivalent (ps1 ~~ ps2))
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1106
                        (the_list (Synchronized.value cached_outcome))
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1107
                        (max_solutions, problems) of
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1108
        SOME outcome => outcome
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1109
      | NONE =>
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1110
        let val outcome = do_solve () in
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1111
          (case outcome of
39326
blanchet
parents: 38516
diff changeset
  1112
             Normal (_, _, "") =>
35814
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1113
             Synchronized.change cached_outcome
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1114
                                 (K (SOME ((max_solutions, problems), outcome)))
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1115
           | _ => ());
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1116
          outcome
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1117
        end
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1118
  end
234eaa508359 added one-entry cache around Kodkod invocation
blanchet
parents: 35718
diff changeset
  1119
33192
08a39a957ed7 added Nitpick's theory and ML files to Isabelle/HOL;
blanchet
parents:
diff changeset
  1120
end;