-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathmaxima.ml
81 lines (70 loc) · 2.76 KB
/
maxima.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
79
80
(* ========================================================================== *)
(* FPTaylor: A Tool for Rigorous Estimation of Round-off Errors *)
(* *)
(* Author: Alexey Solovyev, University of Utah *)
(* *)
(* This file is distributed under the terms of the MIT license *)
(* ========================================================================== *)
(* -------------------------------------------------------------------------- *)
(* Interface to Maxima *)
(* -------------------------------------------------------------------------- *)
open Expr
(* From HOL Light tutorial *)
let maxima cmd =
let tmp = Filename.temp_file "maxima" ".out" in
let s =
"echo 'linel:20000; display2d:false;" ^ cmd ^
";' | maxima | grep '^(%o3)' | sed -e 's/^(%o3) //' > " ^
tmp in
if Sys.command s <> 0 then failwith ("maxima: " ^ cmd) else
let fd = open_in tmp in
let data = input_line fd in
let _ = close_in fd; Sys.remove tmp in
data
let test_maxima () =
try
let _ = maxima "factor(x * x - y * y)" in true
with _ -> false
let maxima_expr task str =
let out = maxima str in
try
Parser.create_env_from_task task;
Parser.parse_expr out
with
| Failure msg ->
Log.error "Cannot parse Maxima output: '%s'" out;
failwith msg
| _ ->
Log.error "Cannot parse Maxima output: '%s'" out;
failwith "parsing error"
let simplify task e =
try
let str = "ratexpand(" ^ ExprOut.Info.print_str e ^ ")" in
maxima_expr task str
with
| Failure msg ->
Log.error "Simplification failed: %s" msg;
e
| _ ->
Log.error "Simplification failed (unknown error)";
e
let diff task v e =
let str = "diff(" ^ ExprOut.Info.print_str e ^ ", " ^ v ^ ")" in
maxima_expr task str
let simplify_diff task v e =
let str = "factor(diff(" ^ ExprOut.Info.print_str e ^ ", " ^ v ^ "))" in
maxima_expr task str
(* Returns the k-th Taylor coefficient in the expansion of e with respect to v around 0 *)
let taylor_coeff v k e =
let str = Format.sprintf "ratcoeff(taylor(%s, %s, 0, %d), %s, %d)"
(ExprOut.Info.print_str e) v k v k in
maxima str
(* Returns a list of linear Taylor coefficients in the expansion of e with respect to vs around 0 *)
let taylor_coeff1 vs e =
let substs = List.map (fun v -> Format.sprintf "%s = 0" v) vs in
let subst = String.concat ", " substs in
let e_str = ExprOut.Info.print_str e in
let coeff v =
let str = Format.sprintf "at (diff(%s, %s), [%s])" e_str v subst in
maxima str in
List.map coeff vs