forked from CakeML/cakeml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
rigidBody1ProgCompScript.sml
60 lines (53 loc) · 1.46 KB
/
rigidBody1ProgCompScript.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
(*
Auto-generated by Daisy (https://gitlab.mpi-sws.org/AVA/daisy
*)
(* INCLUDES, do not change those *)
open exampleLib;
val _ = new_theory "rigidBody1ProgComp";
val _ = translation_extends "cfSupport";
Definition theAST_pre_def:
theAST_pre = \ (x:(string, string) id).
if x = Short "x1" then (((-15)/(1), (15)/(1)):real#real)
else if x = Short "x2" then (((-15)/(1), (15)/(1)):real#real)
else if x = Short "x3" then (((-15)/(1), (15)/(1)):real#real)
else (0,0)
End
Definition theAST_def:
theAST =
[ Dlet unknown_loc (Pvar "rigidBody1")
(Fun "x1"(Fun "x2"(Fun "x3"
(FpOptimise Opt
(App (FP_bop FP_Sub)
[
(App (FP_bop FP_Sub)
[
(App (FP_bop FP_Sub)
[
(App (FP_uop FP_Neg)
[
(App (FP_bop FP_Mul)
[
Var (Short "x1");
Var (Short "x2")
])
]);
(App (FP_bop FP_Mul)
[
(App (FP_bop FP_Mul)
[
(App FpFromWord [Lit (Word64 (4611686018427387904w:word64))]);
Var (Short "x2")
]);
Var (Short "x3")
])
]);
Var (Short "x1")
]);
Var (Short "x3")
])))))]
End
Definition theErrBound_def:
theErrBound = inv (2 pow (5))
End
val x = define_benchmark theAST_def theAST_pre_def true;
val _ = export_theory()