Test_Isac works again, almost ..
4 files raise errors:
# Interpret/solve.sml: "solve.sml: interSteps on norm_Rational 2"
# Interpret/inform.sml: "inform.sml: [rational,simplification] 2"
# Knowledge/partial_fractions.sml: "autoCalculate for met_partial_fraction changed: final result"
# Knowledge/eqsystem.sml: "eqsystem.sml: exp 7.70 normalize 4x4 by rewrite changed"
The chunk of changes is due to the fact, that Isac's code still is unstable.
The changes are accumulated since e8f46493af82.
1 (* Title: All tests on isac (some outcommented since Isabelle2002-->2009-2)
2 Author: Walther Neuper 101001
3 (c) copyright due to lincense terms.
5 Isac's tests are organised parallel to sources:
6 "~~/test/Tools/isac" has same directory structure as "~~/src/Tools/isac"
8 ~~/test/Tools/isac/ADDTESTS
9 ~~/test/Tools/isac/Minisubpbl: the Lucas-Interpreter's core functionality
11 $ cd /usr/local/isabisac/
12 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy &
15 (* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! *)
16 (* !!!!! wait a minute until Isac and the theories below are loaded !!!!! *)
17 (* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! *)
19 theory Test_Isac imports Isac
21 "ADDTESTS/test-depend/Build_Test"
23 "ADDTESTS/course/phst11/T1_Basics"
24 "ADDTESTS/course/phst11/T2_Rewriting"
25 "ADDTESTS/course/phst11/T3_MathEngine"
26 "ADDTESTS/file-depend/BuildC_Test"
27 (*"ADDTESTS/course/SignalProcess/Build_Inverse_Z_Transform"*)
28 "~~/test/Pure/Isar/Test_Parsers"
29 (*"~~/test/Pure/Isar/Pure/Isar/Struct_Deriv" lost at update 2009-2-->2011*)
30 "~~/test/Pure/Isar/Test_Parse_Term"
31 "~~/test/HOL/Library/Test_Polynomial"
33 "~~/src/Tools/isac/Knowledge/GCD_Poly" (*not imported by Isac.thy*)
34 "~~/src/Tools/isac/Knowledge/GCD_Poly_FP" (*not imported by Isac.thy*)
37 section {* test ML Code of isac *}
38 ML {*"%%%%%%%%%%%%%%%%% start ProgLang.thy %%%%%%%%%%%%%%%%%%%";*}
40 ML_file "calcelems.sml"
41 ML_file "ProgLang/termC.sml"
42 ML_file "ProgLang/calculate.sml"
43 ML_file "ProgLang/rewrite.sml"
44 (*ML_file "ProgLang/listC.sml" 2002*)
45 ML_file "ProgLang/scrtools.sml"
46 ML_file "ProgLang/tools.sml"
47 ML {*"%%%%%%%%%%%%%%%%% end ProgLang.thy %%%%%%%%%%%%%%%%%%%%%";*}
48 ML {*"%%%%%%%%%%%%%%%%% start Minisubpbl %%%%%%%%%%%%%%%%%%%%%";*}
49 ML_file "Minisubpbl/000-comments.sml"
50 ML_file "Minisubpbl/100-init-rootpbl.sml"
51 ML_file "Minisubpbl/150-add-given.sml"
52 ML_file "Minisubpbl/200-start-method.sml"
53 ML_file "Minisubpbl/300-init-subpbl.sml"
54 ML_file "Minisubpbl/400-start-meth-subpbl.sml"
55 ML_file "Minisubpbl/490-nxt-Check_Postcond.sml"
56 ML_file "Minisubpbl/500-met-sub-to-root.sml"
57 ML_file "Minisubpbl/530-error-Check_Elementwise.sml"
58 ML_file "Minisubpbl/600-postcond.sml"
59 ML {*"%%%%%%%%%%%%%%%%% end Minisubpbl.thy %%%%%%%%%%%%%%%%%%%%%%%";*}
60 ML {*"%%%%%%%%%%%%%%%%% start Interpret.thy %%%%%%%%%%%%%%%%%%";*}
61 ML_file "Interpret/mstools.sml"
62 ML_file "Interpret/ctree.sml" (*!...!see(25)*)
63 ML_file "Interpret/ptyps.sml"
64 ML {* (*check_unsynchronized_ref (); ==== trick on error: CUT AND PASTE THIS LINE =========*) *}
65 (*TRICK DOESN'T WORK: get_pbt not found: ["IsacKnowledge","Diff","Theorems","diff_sin_chain"]*)
66 ML_file "Interpret/generate.sml"
67 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
68 ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
69 ML_file "Interpret/calchead.sml"
70 ML_file "Interpret/appl.sml" (*complete "WEGEN INTERMED TESTCODE" *)
71 ML_file "Interpret/rewtools.sml" (*complete, isac's Context broken at 2009-2 --> 2011, thehier!*)
72 ML_file "Interpret/script.sml"
73 ML_file "Interpret/solve.sml"
74 ML_file "Interpret/inform.sml"
75 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
76 ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
77 ML_file "Interpret/mathengine.sml" (*!part.*)
78 ML {*"%%%%%%%%%%%%%%%%% end Interpret.thy %%%%%%%%%%%%%%%%%%%%";*}
79 ML {*"%%%%%%%%%%%%%%%%% start xmlsrc.thy %%%%%%%%%%%%%%%%%%%%%";*}
80 ML_file "xmlsrc/mathml.sml" (*part.*)
81 ML_file "xmlsrc/datatypes.sml" (*TODO/part.*)
82 ML_file "xmlsrc/pbl-met-hierarchy.sml"(*TODO after 2009-2/part.*)
83 (*ML_file "xmlsrc/thy-hierarchy.sml" TODO after 2009-2/part | Isabelle2012-->13 !thehier! *)
84 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
85 val it = "----------- ### thes2file ... Exception- Match raised -----------": string
87 val it = "~~~~~ fun thes2file, args:": string
88 val p = "../../tmp/": path
90 exception Bind raised (line 359 of "~~/test/Tools/isac/xmlsrc/thy-hierarchy.sml")
91 ...CONCERNED WITH thehier
93 ML_file "xmlsrc/interface-xml.sml" (*TODO after 2009-2*)
94 ML {*"%%%%%%%%%%%%%%%%% end xmlsrc.thy %%%%%%%%%%%%%%%%%%%%%%%";*}
95 ML {*"%%%%%%%%%%%%%%%%% start Frontend.thy %%%%%%%%%%%%%%%%%%%";*}
96 ML_file "Frontend/messages.sml"
97 ML_file "Frontend/states.sml"
98 ML_file "Frontend/interface.sml"
99 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
100 ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
101 ML_file "print_exn_G.sml"
102 ML {*"%%%%%%%%%%%%%%%%% end Frontend.thy %%%%%%%%%%%%%%%%%%%%%";*}
103 ML {*"%%%%%%%%%%%%%%%%% start Knowledge %%%%%%%%%%%%%%%%%%%%%%";*}
104 ML_file "Knowledge/delete.sml"
105 ML_file "Knowledge/descript.sml"
106 ML_file "Knowledge/atools.sml"
107 ML_file "Knowledge/simplify.sml"
108 ML_file "Knowledge/poly.sml"
109 ML_file "Knowledge/gcd_poly_ml.sml"
110 ML_file "Knowledge/gcd_poly_winkler.sml" (*must be after gcd_poly_ml.sml: redefines functions*)
111 ML_file "Knowledge/rational.sml"
112 ML_file "Knowledge/equation.sml"
113 ML_file "Knowledge/root.sml"
114 ML_file "Knowledge/lineq.sml"
115 (*ML_file "Knowledge/rooteq.sml" some complicated equations not recovered from 2002 *)
116 ML_file "Knowledge/rateq.sml" (*some complicated equations not recovered from 2002 *)
117 ML_file "Knowledge/rootrat.sml"
118 ML_file "Knowledge/rootrateq.sml"(*ome complicated equations not recovered from 2002 *)
119 ML_file "Knowledge/partial_fractions.sml"
120 ML_file "Knowledge/polyeq.sml" (*-----------------works if cut into parts !!!!!!!!!!!*)
121 (*ML_file "Knowledge/rlang.sml" much to clean up, not urgent due to similar tests *)
122 ML_file "Knowledge/calculus.sml"
123 ML_file "Knowledge/trig.sml"
124 (*ML_file "Knowledge/logexp.sml" not included as stuff for presentation of authoring*)
125 ML_file "Knowledge/diff.sml"
126 ML_file "Knowledge/integrate.sml"
127 ML_file "Knowledge/eqsystem.sml"
128 ML_file "Knowledge/test.sml"
129 ML_file "Knowledge/polyminus.sml"
130 ML_file "Knowledge/vect.sml"
131 ML_file "Knowledge/diffapp.sml" (* postponed to dev. specification | TP-prog. *)
132 ML_file "Knowledge/biegelinie.sml"
133 ML_file "Knowledge/algein.sml"
134 ML_file "Knowledge/diophanteq.sml"
135 ML_file "Knowledge/Inverse_Z_Transform/inverse_z_transform.sml"
136 ML_file "Knowledge/isac.sml"
137 ML_file "Knowledge/build_thydata.sml"
138 ML {*"%%%%%%%%%%%%%%%%% end Knowledge %%%%%%%%%%%%%%%%%%%%%%%%";*}
139 ML {*"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";*}
140 ML {*"%%%%%%%%%%%%%%%%% all tests successful %%%%%%%%%%%%%%%%%";*}
141 ML {*"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";*}
143 section {* history of tests *}
145 Systematic regression tests have been introduced to isac development in 2003.
146 Sanity of the regression test suffered from updates following Isabelle development,
147 which mostly exceeded the resources available in isac's development.
149 The survey below shall support to efficiently use the tests for isac
150 on different Isabelle versions. Conclusion in most cases will be:
152 !!! Use most recent tests or go back to the old notebook
153 with isac on Isabelle2002. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
156 subsection {* isac on Isabelle2013 *}
157 subsubsection {* Summary of development *}
160 subsubsection {* Run tests *}
163 subsubsection {* State of tests *}
166 subsubsection {* Changesets of begin and end *}
170 : isac on Isablle2013
172 Changeset: 52061 (4ecea2fcdc2c) --- Build_Isac.thy runs on Isabelle2013
173 User: Walther Neuper <neuper@ist.tugraz.at>
174 Date: 2013-07-15 08:28:50 +0200 (4 weeks)
177 subsection {* isac on Isabelle2012 *}
178 subsubsection {* Summary of development *}
180 isac on Isabelle2012 is considered just a transitional stage
181 within the update from Isabelle2011 to Isabelle2013; thus no further development of isac;
182 For considerations on the transition see
183 ~~/src/Tools/isac/Knowledge/Build_Thydata/thy, section "updating isac..".
185 subsubsection {* Run tests *}
187 $ cd /usr/local/isabisac12/
188 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
189 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
191 subsubsection {* State of tests *}
193 At least the tests from isac on Isabelle2011 run again.
194 However, Test_Isac.thy shows erratic behaviour; no errors are obtained when scrolling
195 in parallel with evaluation.
197 Counting "error in kernel" for Frontend/interface.sml (the tests considered most significant)
198 yields 69 hits, some of which were already present before Isabelle2002-->2009-2
199 (i.e. on the old notebook from 2002).
201 Now many tests with (*...=== inhibit exn ...*) give a reason or at least the origin:
202 # === inhibit exn WN1130621 Isabelle2012-->13 !thehier! === ...see Build_Thydata.thy
203 # === inhibit exn AK110726 === ...reliable work by Alexander Kargl, most likely go back to 2002
204 # === inhibit exn WN1130701 broken at Isabelle2002 --> 2009-2 === , most likely go back to 2002
205 Reasons for outcommented tests are also found in Test_Isac.thy near the respective file.sml.
207 Some tests have been re-activated (e.g. error patterns, fill patterns).
209 subsubsection {* Changesets of begin and end *}
211 Changeset: 52051 (35751d90365e) end of improving tests for isac on Isabelle2012
212 User: Walther Neuper <neuper@ist.tugraz.at>
213 Date: 2013-07-11 16:58:31 +0200 (4 weeks)
215 : isac on Isablle2012
217 Changeset: 48757 (74eb3dfc33cc) updated src from Isabelle2011 to Isabelle2012
218 User: Walther Neuper <neuper@ist.tugraz.at>
219 Date: 2012-09-24 18:35:13 +0200 (8 months)
220 ------------------------------------------------------------------------------
221 Changeset: 48756 (7443906996a8) merged
222 User: Walther Neuper <neuper@ist.tugraz.at>
223 Date: 2012-09-24 18:15:49 +0200 (8 months)
226 subsection {* isac on Isabelle2011 *}
227 subsubsection {* Summary of development *}
229 isac's mathematics engine has been extended by two developments:
230 (1) Isabelle's contexts were introduced by Mathias Lehnfeld
231 (2) "error patterns" were introduced by Gabriella Daroczy
232 Regressions tests have been added for both.
234 subsubsection {* Run tests *}
236 $ cd /usr/local/isabisac11/
237 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
238 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
240 subsubsection {* State of tests *}
242 Systematic efforts outcommented less significant tests by (*...=== inhibit exn ...*)
243 and sometimes give reasons for failing tests.
244 (*...=== inhibit exn AK...*) was done by Alexander Kargl; this is reliable
245 work, some of which couldn't be revised (and renamed) by WN and thus survived some time.
247 Tests with functions decomposed for single-stepping are marked with
248 "~~~~~ fun , args:"; val
250 The most signification tests (in particular Frontend/interface.sml) run,
251 however, many "error in kernel" are not caught by an exception.
252 ------------------------------------------------------------------------------
253 After the changeset below Test_Isac worked with check_unsynchronized_ref ():
254 ------------------------------------------------------------------------------
255 Changeset: 42457 (ca691a84b81a) PROVISIONALLY MADE TESTS RUN with Unsynchronized.ref
256 User: Walther Neuper <neuper@ist.tugraz.at>
257 Date: 2012-08-06 10:38:11 +0200 (11 months)
259 subsubsection {* Changesets of begin and end *}
261 isac development was done between these changesets:
262 ------------------------------------------------------------------------------
263 Changeset: 42519 (1f3b4270363e) meeting dmeindl: added missing files
264 User: Walther Neuper <neuper@ist.tugraz.at>
265 Date: 2012-09-24 16:39:30 +0200 (8 months)
267 : isac on Isablle2011
269 Changeset:41897 (355be7f60389) merged isabisac with Isabelle2011
270 Branch: decompose-isar
271 User: Walther Neuper <neuper@ist.tugraz.at>
272 Date: 2011-02-25 13:04:56 +0100 (2011-02-25)
273 ------------------------------------------------------------------------------
276 subsection {* isac on Isabelle2009-2 *}
277 subsubsection {* Summary of development *}
279 In 2009 the update of isac from Isabelle2002 started with switching from CVS to hg.
280 The update was painful (bridging 7 years of Isabelle development) and cut short
281 due to the start of introducing Isabelle's contexts (Mathias Lehnfeld) and
282 going on to Isabelle2011 although most of the tests did not run.
284 subsubsection {* Run tests *}
286 $ cd /usr/local/isabisac09-2/
287 $ ./bin/isabelle emacs -l HOL src/Tools/isac/Build_Isac.thy
288 $ ./bin/isabelle emacs -l Isac src/Tools/isac/Test_Isac.thy
289 NOT THE RIGHT VERSION..... test/Tools/isac/Test_Isac.thy !!!
291 subsubsection {* State of tests *}
293 Most tests are broken by the update from Isabelle2002 to Isabelle2009-2.
294 If really necessary, go back to the old notebook with Isabelle2002.
296 subsubsection {* Changesets of begin and end *}
298 isac development was done between these changesets:
299 ------------------------------------------------------------------------------
300 Changeset: 38115 (940a5feea094) Little improvements of isac-plugin
301 Branch: decompose-isar
302 User: Marco Steger <m.steger@student.tugraz.at>
303 Date: 2011-02-06 18:30:28 +0100 (2011-02-06)
305 : isac on Isablle2009-2
307 Changeset: 37870 (5100a9c3abf8) created branch isac-from-Isabelle2009-2
308 Branch: isac-from-Isabelle2009-2
309 User: Walther Neuper <neuper@ist.tugraz.at>
310 Date: 2010-07-21 09:59:35 +0200 (2010-07-21)
311 ------------------------------------------------------------------------------
314 subsection {* isac on Isabelle2002 *}
315 subsubsection {* Summary of development *}
317 From 1999 to 2010 all the basic functionality (except "ctxt" and "error pattern")
318 of isac's mathematics engine has been implemented.
320 subsubsection {* Run tests *}
321 subsubsection {* State of tests *}
323 All tests work on an old notebook (the right PolyML coudn't be upgraded to more
324 recent Linux versions)
326 subsubsection {* Changesets of begin and end *}
328 Up to the above Mercurial changeset 5100a9c3abf8 isac used CVS;
329 see https://intra.ist.tugraz.at/hg/isac containing a conversion to Mercurial.
333 (*========== inhibit exn 130719 Isabelle2013 ===================================
334 ============ inhibit exn 130719 Isabelle2013 =================================*)
336 (*-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.
337 -.-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.*)