-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathoptions.ml
78 lines (67 loc) · 2.4 KB
/
options.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
(* --- Options for DEVOID --- *)
(*
* Prove the coherence property of the algebraic promotion isomorphism
* (disabled by default)
*)
let opt_search_coh = ref (false)
let _ = Goptions.declare_bool_option {
Goptions.optdepr = false;
Goptions.optname = "Generate a proof of coherence in search for DEVOID";
Goptions.optkey = ["DEVOID"; "search"; "prove"; "coherence"];
Goptions.optread = (fun () -> !opt_search_coh);
Goptions.optwrite = (fun b -> opt_search_coh := b);
}
let is_search_coh () = !opt_search_coh
(*
* Prove section and retraction
* (disabled by default)
*)
let opt_search_equiv = ref (false)
let _ = Goptions.declare_bool_option {
Goptions.optdepr = false;
Goptions.optname = "Generate proof of equivalence in search for DEVOID";
Goptions.optkey = ["DEVOID"; "search"; "prove"; "equivalence"];
Goptions.optread = (fun () -> !opt_search_equiv);
Goptions.optwrite = (fun b -> opt_search_equiv := b);
}
let is_search_equiv () = !opt_search_equiv
(*
* Generate useful eliminators in addition to the discovered equivalence
* (disabled by default)
*)
let opt_smart_elim = ref (false)
let _ = Goptions.declare_bool_option {
Goptions.optdepr = false;
Goptions.optname = "Generate useful eliminators for DEVOID";
Goptions.optkey = ["DEVOID"; "search"; "smart"; "eliminators"];
Goptions.optread = (fun () -> !opt_smart_elim);
Goptions.optwrite = (fun b -> opt_smart_elim := b);
}
let is_smart_elim () = !opt_smart_elim
(*
* Lift the type as well, rather than using the automatically inferred type
* (disabled by default)
*)
let opt_lift_type = ref (false)
let _ = Goptions.declare_bool_option {
Goptions.optdepr = false;
Goptions.optname = "Use lifted rather than inferred types in DEVOID";
Goptions.optkey = ["DEVOID"; "lift"; "type"];
Goptions.optread = (fun () -> !opt_lift_type);
Goptions.optwrite = (fun b -> opt_lift_type := b);
}
let is_lift_type () = !opt_lift_type
(*
* If lifting a constant across an ornament does not change
* the term, add that term to the global cache for later
* (enabled by default)
*)
let opt_smart_cache = ref (true)
let _ = Goptions.declare_bool_option {
Goptions.optdepr = false;
Goptions.optname = "Automatically cache unchanged lifted constants";
Goptions.optkey = ["DEVOID"; "smart"; "cache"];
Goptions.optread = (fun () -> !opt_smart_cache);
Goptions.optwrite = (fun b -> opt_smart_cache := b);
}
let is_smart_cache () = !opt_smart_cache