pvs-common.gen 5.08 KB
Newer Older
1 2 3 4 5 6 7 8

valid 0
unknown "Error: \\(.*\\)$" "\\1"
fail "Syntax error: \\(.*\\)$" "\\1"
time "why3cpulimit time : %s s"

transformation "inline_trivial"
transformation "eliminate_builtin"
9 10

(* PVS does not support mutual recursion *)
11
transformation "eliminate_mutual_recursion"
12 13
transformation "simplify_recursive_definition"
(* though we could do better, we only use recursion on one argument *)
14 15
transformation "eliminate_non_struct_recursion"

16
(* PVS only has simple patterns *)
17 18 19 20 21 22 23 24 25 26
transformation "compile_match"

transformation "simplify_formula"

theory BuiltIn
  syntax type   int   "int"
  syntax type   real  "real"
  syntax predicate  (=)   "(%1 = %2)"
end

27 28 29 30 31
theory Tuple0
  syntax type     tuple0 "tuple0"
  syntax function Tuple0 "Tuple0"
end

32 33 34 35 36 37 38 39 40
theory map.Map
  syntax type  map "[%1 -> %2]"

  syntax function get "%1(%2)"
  syntax function set "(%1 WITH [(%2) |-> %3])"

  remove prop Select_eq
  remove prop Select_neq

41 42 43 44 45
  (* %t0 is "map a b"
     %t1 is the type of const's argument, that is "b"
     but we need type "a" instead, i.e. the first type argument

  syntax function const "(LAMBDA (x:%t1): %1)"
46 47 48 49
  remove prop Const
  *)
end

50
theory Bool
51 52 53 54
  syntax type bool   "bool"

  syntax function True  "TRUE"
  syntax function False "FALSE"
55 56 57
end

theory bool.Bool
58 59 60 61 62

  syntax function andb  "(%1 AND %2)"
  syntax function orb   "(%1 OR %2)"
  syntax function xorb  "(%1 XOR %2)"
  syntax function notb  "(NOT %1)"
63
  syntax function implb "(%1 => %2)"
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129

end


theory int.Int

  syntax function zero "0"
  syntax function one  "1"

  syntax function (+)  "(%1 + %2)"
  syntax function (-)  "(%1 - %2)"
  syntax function (*)  "(%1 * %2)"
  syntax function (-_) "(-%1)"

  syntax predicate (<=) "(%1 <= %2)"
  syntax predicate (<)  "(%1 <  %2)"
  syntax predicate (>=) "(%1 >= %2)"
  syntax predicate (>)  "(%1 >  %2)"

  remove prop CommutativeGroup.Comm.Comm
  remove prop CommutativeGroup.Assoc.Assoc
  remove prop CommutativeGroup.Unit_def
  remove prop CommutativeGroup.Inv_def
  remove prop Assoc.Assoc
  remove prop Mul_distr
  remove prop Comm.Comm
  remove prop Unitary
  remove prop Refl
  remove prop Trans
  remove prop Antisymm
  remove prop Total
  remove prop NonTrivialRing
  remove prop CompatOrderAdd
  remove prop CompatOrderMult
  remove prop ZeroLessOne

end

theory int.Abs

  syntax function abs "abs(%1)"

  remove prop Abs_pos

end

theory int.MinMax

  syntax function min "min(%1, %2)"
  syntax function max "max(%1, %2)"

end

theory int.EuclideanDivision

  syntax function div "ndiv(%1, %2)"
  syntax function mod "mod(%1, %2)"

  remove prop Div_mod
  remove prop Div_bound
  remove prop Mod_bound
  remove prop Mod_1
  remove prop Div_1

end

130
(***
131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
theory int.ComputerDivision

  syntax function div "(ZOdiv %1 %2)"
  syntax function mod "(ZOmod %1 %2)"

  remove prop Div_mod
  remove prop Div_bound
  remove prop Mod_bound
  remove prop Div_sign_pos
  remove prop Div_sign_neg
  remove prop Mod_sign_pos
  remove prop Mod_sign_neg
  remove prop Rounds_toward_zero
  remove prop Div_1
  remove prop Mod_1
  remove prop Div_inf
  remove prop Mod_inf
  remove prop Div_mult
  remove prop Mod_mult

end
152
***)
153 154 155

theory real.Real

156 157
  syntax function zero "0"
  syntax function one  "1"
158

159 160 161 162 163 164
  syntax function (+)  "(%1 + %2)"
  syntax function (-)  "(%1 - %2)"
  syntax function (-_) "(-%1)"
  syntax function (*)  "(%1 * %2)"
  syntax function (/)  "(%1 / %2)"
  syntax function inv  "(1 / %1)"
165

166 167 168 169
  syntax predicate (<=) "(%1 <= %2)"
  syntax predicate (<)  "(%1 <  %2)"
  syntax predicate (>=) "(%1 >= %2)"
  syntax predicate (>)  "(%1 >  %2)"
170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195

  remove prop CommutativeGroup.Comm.Comm
  remove prop CommutativeGroup.Assoc.Assoc
  remove prop CommutativeGroup.Unit_def
  remove prop CommutativeGroup.Inv_def
  remove prop Assoc.Assoc
  remove prop Mul_distr
  remove prop Comm.Comm
  remove prop Unitary
  remove prop Inverse
  remove prop NonTrivialRing
  remove prop CompatOrderAdd
  remove prop CompatOrderMult
  remove prop ZeroLessOne
  remove prop Refl
  remove prop Trans
  remove prop Antisymm
  remove prop Total
  remove prop assoc_mul_div
  remove prop assoc_div_mul
  remove prop assoc_div_div

end

theory real.RealInfix

196 197 198 199 200
  syntax function (+.)  "(%1 + %2)"
  syntax function (-.)  "(%1 - %2)"
  syntax function (-._) "(-%1)"
  syntax function ( *.) "(%1 * %2)"
  syntax function (/.)  "(%1 / %2)"
201

202 203 204 205
  syntax predicate (<=.) "(%1 <= %2)"
  syntax predicate (<.)  "(%1 <  %2)"
  syntax predicate (>=.) "(%1 >= %2)"
  syntax predicate (>.)  "(%1 >  %2)"
206 207 208 209 210

end

theory real.Abs

211
  syntax function abs "abs(%1)"
212 213 214 215 216 217 218 219

  remove prop Abs_le
  remove prop Abs_pos

end

theory real.FromInt

220
  syntax function from_int "(%1 :: real)"
221 222 223 224 225 226 227 228 229 230 231 232

  remove prop Zero
  remove prop One
  remove prop Add
  remove prop Sub
  remove prop Mul
  remove prop Neg

end

theory real.Square

233
  syntax function sqrt "SQRT(%1)"
234 235 236 237 238

end

theory real.ExpLog

239 240
  syntax function exp "EXP(%1)"
  syntax function log "LOG(%1)"
241 242 243 244 245

end

theory real.Power

246 247 248 249 250
  syntax function pow "(%1 ^ %2)"

  remove prop Pow_x_zero
  remove prop Pow_x_one
  remove prop Pow_one_y
251 252 253 254 255

end

theory real.Trigonometry

256 257
  syntax function cos "COS(%1)"
  syntax function sin "SIN(%1)"
258 259 260

  syntax function pi "PI"

261
  syntax function tan "TAN(%1)"
262 263

end