1 (* Title: build the Isac-Kernel: MathEngine & Knowledge
2 Author: Walther Neuper, TU Graz, 100808
3 (c) due to copyright terms
5 For creating a heap image of isac see ~~/ROOT.
6 For debugging see text at begin below, e.g. theory dependencies:
7 ~$ evince file:///home/wneuper/.isabelle/isabisac/browser_info/Unsorted/Isac/session_graph.pdf &
9 ATTENTION: no errors in this theory do not mean that there are no errors in Isac ..
10 .. open theories collecting files from folders: BaseDefinitions.thy, ProgLang.thy etc.
11 Errors are rigorously detected by isabelle build.
16 (* theory Know_Store imports Complex_Main
20 ML_file "rule-def.sml"
21 ML_file "thmC-def.sml"
22 ML_file "eval-def.sml"
23 ML_file "rewrite-order.sml"
25 ML_file "error-pattern-def.sml"
26 ML_file "rule-set.sml"
29 ML_file "check-unique.sml"
30 ML_file "specification.sml"
31 ML_file "model-pattern.sml"
32 ML_file "problem-def.sml"
33 ML_file "method-def.sml"
35 ML_file "thy-write.sml"
36 theory BaseDefinitions imports Know_Store
38 ML_file substitution.sml
40 ML_file environment.sml
41 ( ** ) "BaseDefinitions/BaseDefinitions"( **)
43 (* theory Calculate imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
46 theory ListC imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
47 theory Prog_Expr imports Calculate ListC
48 theory Program imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
49 theory Prog_Tac imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
50 theory Tactical imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
51 theory Auto_Prog imports Program Prog_Tac Tactical begin
52 theory ProgLang imports Prog_Expr Auto_Prog
53 ( ** ) "ProgLang/ProgLang"( **)
55 theory MathEngBasic imports
56 "~~/src/Tools/isac/ProgLang/ProgLang" "~~/src/Tools/isac/Specify/Input_Descript"
60 ML_file "cas-command.sml"
64 ML_file "model-def.sml"
65 ML_file "istate-def.sml"
66 ML_file "calc-tree-elem.sml"
67 ML_file "pre-conds-def.sml"
70 ML_file applicable.sml
73 ML_file "ctree-basic.sml"
74 ML_file "ctree-access.sml"
75 ML_file "ctree-navi.sml"
78 ML_file "state-steps.sml"
79 ML_file calculation.sml
80 ( ** ) "MathEngBasic/MathEngBasic"( **)
82 theory Input_Descript imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
83 theory Specify imports "~~/src/Tools/isac/ProgLang/ProgLang" Input_Descript
89 ML_file "pre-conditions.sml"
91 ML_file "mstools.sml" (*..TODO review*)
92 ML_file ptyps.sml (*..TODO review*)
93 ML_file "test-out.sml"
94 ML_file "specify-step.sml"
95 ML_file calchead.sml (*..TODO review*)
96 ML_file "input-calchead.sml"
97 ML_file "step-specify.sml"
99 ( ** ) "Specify/Specify"( **)
101 theory Interpret imports "~~/src/Tools/isac/Specify/Specify"
103 ML_file "sub-problem.sml"
104 ML_file "thy-read.sml"
105 ML_file "solve-step.sml"
106 ML_file "error-pattern.sml"
108 ML_file "li-tool.sml"
109 ML_file "lucas-interpreter.sml"
110 ML_file "step-solve.sml"
111 ( ** ) "Interpret/Interpret"( **)
113 theory MathEngine imports Interpret.Interpret
114 ML_file "fetch-tactics.sml"
117 ML_file "detail-step.sml"
118 ML_file "mathengine-stateless.sml"
121 ( ** ) "MathEngine/MathEngine"( **)
123 theory Test_Code imports "~~/src/Tools/isac/MathEngine/MathEngine"
124 ML_file "test-code.sml"
125 ( ** ) "Test_Code/Test_Code"( **)
127 theory BridgeLibisabelle imports "~~/src/Tools/isac/MathEngine/MathEngine"
128 ML_file "thy-present.sml"
130 ML_file datatypes.sml
131 ML_file "pbl-met-hierarchy.sml"
132 ML_file "thy-hierarchy.sml"
133 ML_file "interface-xml.sml"
134 ML_file interface.sml
135 ( ** ) "BridgeLibisabelle/BridgeLibisabelle"( **)
137 theory Isac imports "~~/src/Tools/isac/MathEngine/MathEngine"
139 theory BridgeJEdit imports Isac
140 ( **) "BridgeJEdit/BridgeJEdit" (*DEactivate after devel.of BridgeJEdit*)
142 "Knowledge/Build_Thydata" (*imports Isac.thy etc*)
144 (*//-----------------------------------------------------------------------------------------\\*)
145 (*\\-----------------------------------------------------------------------------------------//*)
149 show theory dependencies using the graph browser,
150 open "browser_info/HOL/Isac/session.graph"
151 and proceed from the ancestors towards the siblings.
154 section \<open>check presence of definitions from directories\<close>
156 (*declare [[ML_print_depth = 999]]*)
161 ML \<open>Eval.adhoc_thm; (*from "ProgLang/evaluate.sml" *)\<close>
162 ML \<open>Rewrite.rewrite_; (*from "ProgLang/rewrite.sml" *)\<close>
163 ML \<open>Input_Descript.for_real_list; (*from "Input_Descript.thy" *)\<close>
164 ML \<open>Test_Code.me;\<close>
165 text \<open>contextthyOK2xml; (*"xmlsrc/interface-xml.sml"*)\<close>
166 ML \<open>prog_expr\<close>
168 ML \<open>Prog_Expr.eval_occurs_in\<close>
169 ML \<open>@{thm last_thmI}\<close>
170 (** )ML \<open>@{thm Querkraft_Belastung}\<close>( *exception FAIL NONE raised (line 161 of "General/scan.ML")*)
172 ML \<open>Check_Unique.on := false;\<close>
173 ML \<open>writeln "**** isac kernel = math-engine + Knowledge complete ******"\<close>
174 ML \<open>@{theory "Isac_Knowledge"}\<close>
175 ML \<open>(*get_the ["IsacKnowledge", "Diff", "Theorems", "diff_sin_chain"]
176 ERROR: app_py: not found: ["IsacKnowledge", "Diff", "Theorems", "diff_sin_chain"]*)\<close>
178 section \<open>State of approaching Isabelle by Isac\<close>
180 Mathias Lehnfeld gives the following list in his thesis in section
181 4.2.3 Relation to Ongoing Isabelle Development.
183 subsection \<open>(0) Survey on remaining Unsynchronized.ref\<close>
185 REPLACE BY Know_Store... (has been overlooked)
186 calcelems.sml:val rew_ord' = Unsynchronized.ref ...
188 rewrite.sml:val Rewrite.trace_on = Unsynchronized.ref false;
189 rewrite.sml:val depth = Unsynchronized.ref 99999;
190 rewrite.sml:val lim_rewrite = Unsynchronized.ref 99999;
191 rewrite.sml:val lim_deriv = Unsynchronized.ref 100;
192 Interpret/rewtools.sml:val LItool.trace = Unsynchronized.ref false;
193 KEEP FOR EASIER DEVELOPMENT
194 calcelems.sml:val check_guhs_unique = Unsynchronized.ref true;
196 Knowledge/GCD_Poly_ML.thy: val trace_div = Unsynchronized.ref true;
197 Knowledge/GCD_Poly_ML.thy: val trace_div_invariant = Unsynchronized.ref false;
198 Knowledge/GCD_Poly_ML.thy: val trace_Euclid = Unsynchronized.ref true;
200 subsection \<open>(1) Exploit parallelism for concurrent session management\<close>
201 subsection \<open>(2) Make Isac’s programming language usable\<close>
202 subsection \<open>(3) Adopt Isabelle’s numeral computation for Isac\<close>
204 In 2002 isac already strived for floating point numbers. Since that time
205 isac represents numerals as "Free", see below (*1*). These experiments are
206 unsatisfactory with respect to logical soundness.
207 Since Isabelle now has started to care about floating point numbers, it is high
208 time to adopt these together with the other numerals. Isabelle2012/13's numerals
209 are different from Isabelle2011, see "test/Tools/isac/ProgLang/termC.sml".
211 The transition from "Free" to standard numerals is a task to be scheduled for
212 several weeks. The urgency of this task follows from the experience,
213 that (1.2) for "thehier" is very hard, because "num_str" seems to destroy
214 some of the long identifiers of theorems which would tremendously simplify
215 building a hierarchy of theorems according to (1.2), see (*2*) below.
217 ML \<open>(*1*) Free ("123.456", HOLogic.realT)\<close>
219 subsection \<open>(4) Improve the efficiency of Isac’s rewrite-engine\<close>
220 subsection \<open>(5) Adopt Isabelle/jEdit for Isac\<close>