-
Notifications
You must be signed in to change notification settings - Fork 85
/
Copy pathinvertedPendulumProgCompScript.sml
73 lines (65 loc) · 1.91 KB
/
invertedPendulumProgCompScript.sml
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
(**
Icing benchmark input file
Use this file to run a CakeML AST through the Icing optimizer
**)
(* INCLUDES, do not change those *)
open exampleLib;
val _ = new_theory "invertedPendulumProgComp";
val _ = translation_extends "cfSupport";
(** Precondition **)
Definition theAST_pre_def:
theAST_pre =
λ (x:(string, string) id).
if x = Short "s1"
then ((-50/1, 50/1):real#real)
else if x = Short "s2"
then (-10/1, 10/1)
else if x = Short "s3"
then (-785/1000, 785/1000)
else if x = Short "s4"
then (-785/1000, 785/1000)
else (0,0)
End
(**
Define the CakeML source AST as a polyML/HOL4 declaration
**)
Definition theAST_def:
theAST =
[Dlet unknown_loc (Pvar "invertedPendulum")
(Fun "s1" (Fun "s2" (Fun "s3" (Fun "s4"
(FpOptimise Opt
(App (FP_bop FP_Add)
[
(App (FP_bop FP_Add)
[
(App (FP_bop FP_Add)
[
(App (FP_bop FP_Mul)
[
(App FpFromWord [Lit (Word64 (4607182418800017408w:word64))]);
Var (Short "s1")
]);
(App (FP_bop FP_Mul)
[
(App FpFromWord [Lit (Word64 (4610139932675311613w:word64))]);
Var (Short "s2")
])
]);
(App (FP_bop FP_Mul)
[
(App FpFromWord [Lit (Word64 (-4597419346642817620w:word64))]);
Var (Short "s3")
])
]);
(App (FP_bop FP_Mul)
[
(App FpFromWord [Lit (Word64 (-4608399741779295653w:word64))]);
Var (Short "s4")
])
]))))))]
End
Definition theErrBound_def:
theErrBound = inv (2 pow (5))
End
val x = define_benchmark theAST_def theAST_pre_def true;
val _ = export_theory();