summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSon Ho2022-02-10 10:00:15 +0100
committerSon Ho2022-02-10 10:00:15 +0100
commit1c7c1bb9fac25dda0fb0412b33227299ccfdd3f0 (patch)
tree6b93450a2f569a70aeb0624935dbba7b4227273d /src
parent95e5e17b1e80e36674f6e892b238c41e8cce86c7 (diff)
Add an option to deactivate the invariant checks
Diffstat (limited to '')
-rw-r--r--src/main.ml16
1 files changed, 10 insertions, 6 deletions
diff --git a/src/main.ml b/src/main.ml
index cf854577..4a111a25 100644
--- a/src/main.ml
+++ b/src/main.ml
@@ -33,6 +33,7 @@ let () =
let no_decreases_clauses = ref false in
let template_decreases_clauses = ref false in
let no_split = ref false in
+ let no_check_inv = ref false in
let spec =
[
@@ -63,20 +64,23 @@ let () =
( "-test-trans-units",
Arg.Set test_trans_units,
" Test the translated unit functions with the target theorem\n\
- \ prover's normalizer" );
+ \ prover's normalizer" );
( "-no-decreases-clauses",
Arg.Set no_decreases_clauses,
" Do not add decrease clauses to the recursive definitions" );
( "-template-clauses",
Arg.Set template_decreases_clauses,
" Generate templates for the required decreases clauses, in a\n\
- `\n\
- \ dedicated file. Incompatible with \
+ \ dedicated file. Incompatible with \
-no-decreases-clauses" );
( "-no-split",
Arg.Set no_split,
- " Don't split the definitions between different files for types, \
- functions, etc." );
+ " Don't split the definitions between different files for types,\n\
+ \ functions, etc." );
+ ( "-no-check-inv",
+ Arg.Set no_check_inv,
+ " Deactivate the invariant sanity checks performed at every step of\n\
+ \ evaluation. Dramatically saves speed." );
]
in
(* Sanity check: -template-clauses ==> not -no-decrease-clauses *)
@@ -146,7 +150,7 @@ let () =
(* Some options for the execution *)
let eval_config =
{
- C.check_invariants = true;
+ C.check_invariants = not !no_check_inv;
greedy_expand_symbolics_with_borrows = true;
allow_bottom_below_borrow = true;
}