1 (* Title: All tests on isac (some outcommented since Isabelle2002-->2009-2)
2 Author: Walther Neuper 101001
3 (c) copyright due to license terms.
5 Isac's tests are organised parallel to sources:
6 $ISABELLE_ISAC_TEST has same directory structure as $ISABELLE_ISAC
8 $ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS
9 $ISABELLE_ISAC_TEST/Tools/isac/Minisubpbl: the Lucas-Interpreter's core functionality
11 Note, that only the first error in a file is shown here.
14 section \<open>Notes on running tests\<close>
15 subsection \<open>Switch between running tests and updating code\<close>
17 Isac encapsulates code as much as possible in structures without open.
18 This policy conflicts with those tests, which go into functions to details
19 not declared in the signatures.
21 subsection \<open>Decide between running Test_Isac_Short.thy and Test_Isac.thy\<close>
23 Some tests raise exception Size raised (line 171 of "./basis/LibrarySupport.sml")
24 if run in x86_64_32 mode of Poly/ML 5.8 (which is set as default).
25 This exception can be avoided by ML_system_64 = "true" in ~/.isabelle/isabisac/etc/preferences.
26 A model is in the repository at ~~/etc/preferences.
27 These preferences have drawbacks, however:
28 * they claim more memory such that Isabelle instances canNOT run in parallel.
29 * they do NOT reach Build_Isac.thy hanging in Build_Thydata.thy, see there.
31 So default for Build_Isac.thy and for general testing is Test_Isac_Short.thy is x86_64_32 mode.
32 From time to time full testing in Test_Isac.thy is recommended. For that purpose
33 * set ML_system_64 = "true" in ~/.isabelle/isabisac/etc/preferences.
35 \\******************* don't forget to re-set defaults BEFORE updating code *******************//
37 Note that Isabelle/jEdit re-generates the preferences file on shutdown, thus always use
38 ***************** $ gedit ~/.isabelle/isabisac/etc/preferences &
41 section \<open>Run the tests\<close>
43 * say "OK" to the popup asking for theories to be loaded
44 * watch the <Theories> window for errors in the "imports" below
47 theory Test_Isac_Short
48 imports Isac.Build_Isac (* note that imports are WITHOUT open struct ..*)
49 (* in case of ERROR Bad theory import "Draft.Thy_All"..., open each theory one by one
50 and find out, which ML_file or *.thy causes an error (might be ONLY one).
51 Also backup files (#* ) recognised by jEdit cause this trouble *)
52 (*/---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------\*)
53 (* "$ISABELLE_ISAC_TEST/ADDTESTS/accumulate-val/Thy_All"(*but ok in editor*)*)
54 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/accumulate-val/Lucas_Interpreter"
55 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/Ctxt"
56 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/test-depend/Build_Test"
57 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/All_Ctxt"
58 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/Test_Units"
59 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/course/phst11/T1_Basics"
60 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/course/phst11/T2_Rewriting"
61 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/course/phst11/T3_MathEngine"
62 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/file-depend/BuildC_Test"
63 (**)"$ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS/session-get_theory/Foo"
64 (*"ADDTESTS/course/SignalProcess/Build_Inverse_Z_Transform"
65 ADDTESTS/------------------------------------------- see end of tests *)
66 (*/~~~ these work directly from Pure, but create problems here ..
67 "$ISABELLE_ISAC_TEST/Pure/Isar/Keyword_ISAC.thy" (* Malformed theory import, "keywords" ?!? *)
68 "$ISABELLE_ISAC_TEST/Pure/Isar/Test_Parse_Isac.thy" (* Malformed theory import, "keywords" ?!? *)
69 "$ISABELLE_ISAC_TEST/Pure/Isar/Test_Parsers_Cookbook.thy" (* Malformed theory import ?!? *)
70 "$ISABELLE_ISAC_TEST/Pure/Isar/Theory_Commands" (* Duplicate outer syntax command "ISAC" *)
71 "$ISABELLE_ISAC_TEST/Pure/Isar/Downto_Synchronized" (* re-defines / breaks structures !!! *)
72 \~~~ .. these work independently, but create problems here *)
73 (**)"$ISABELLE_ISAC_TEST/Pure/Isar/Test_Parsers"
74 (**)"$ISABELLE_ISAC_TEST/HOL/Tools/Sledgehammer/Try_Sledgehammer"
75 (*/---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------\*)
76 "$ISABELLE_ISAC_TEST/Tools/isac/Specify/refine" (* setup for refine.sml *)
77 "$ISABELLE_ISAC_TEST/Tools/isac/ProgLang/calculate" (* setup for evaluate.sml *)
78 "$ISABELLE_ISAC_TEST/Tools/isac/Knowledge/integrate" (* setup for integrate.sml*)
80 (*\---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------/*)
81 (*"$ISABELLE_ISAC/Knowledge/GCD_Poly_OLD" (*not imported by Isac.thy*) Test_Isac_Short*)
82 (*"$ISABELLE_ISAC/Knowledge/GCD_Poly_FP" (*not imported by Isac.thy*) Test_Isac_Short*)
83 (*\---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------/*)
85 "$ISABELLE_ISAC_TEST/Tools/isac/BridgeJEdit/Test_VSCode_Example"
89 declare [[ML_print_depth = 20]]
91 ML \<open>open ML_System\<close>
95 open Test_Code; Test_Code.init_calc @{context};
96 open LItool; arguments_from_model;
104 open Error_Pattern_Def;
106 open Ctree; append_problem;
112 open Auto_Prog; rule2stac;
119 open Solve; (* NONE *)
120 open ContextC; transfer_asms_from_to;
121 open Tactic; (* NONE *)
124 open P_Model; (* NONE *)
129 open Rule_Set; Sequence;
137 Know_Store.set_ref_last_thy @{theory};
138 (*otherwise ERRORs in pbl-met-hierarchy.sml, refine.sml, evaluate.sml*)
142 "~~~~~ fun xxx , args:"; val () = ();
143 "~~~~~ and xxx , args:"; val () = ();
144 "~~~~~ from fun xxx \<longrightarrow>fun yyy \<longrightarrow>fun zzz , return:"; val () = ();
145 "~~~~~ continue fun xxx"; val () = ();
146 (*if*) (*then*); (*else*); (*case*) (*of*); (*return value*); (*in*) (*end*);
148 ^ "xxx" (*+*) (*+++*) (*keep for continuing YYYYY*) (*isa*) (*isa2*) (**)
149 \<close> ML \<open> (*//----------- adhoc inserted n ----------------------------------------------------\\*)
150 (*//----------------- adhoc inserted n ----------------------------------------------------\\*)
151 (*\\------------------ adhoc inserted n ----------------------------------------------------//*)
152 \<close> ML \<open> (*\\----------- adhoc inserted n ----------------------------------------------------//*)
154 \<close> ML \<open> (*//----------- step into XXXXX -----------------------------------------------------\\*)
155 (*//------------------ step into XXXXX -----------------------------------------------------\\*)
156 (*keep for continuing YYYYY*)
157 \<close> ML \<open> (*------------- continuing XXXXX ------------------------------------------------------*)
158 (*-------------------- continuing XXXXX ------------------------------------------------------*)
159 (*kept for continuing XXXXX*)
160 (*-------------------- stop step into XXXXX --------------------------------------------------*)
161 \<close> ML \<open> (*------------- stop step into XXXXX --------------------------------------------------*)
162 (*\\------------------ step into XXXXX -----------------------------------------------------//*)
163 \<close> ML \<open> (*\\----------- step into XXXXX -----------------------------------------------------//*)
165 (*/------------------- check entry to XXXXX -------------------------------------------------\*)
166 (*\------------------- check entry to XXXXX -------------------------------------------------/*)
167 (*/------------------- check within XXXXX ---------------------------------------------------\*)
168 (*\------------------- check within XXXXX ---------------------------------------------------/*)
169 (*/------------------- check result of XXXXX ------------------------------------------------\*)
170 (*\------------------- check result of XXXXX ------------------------------------------------/*)
171 (* final test ... ----------------------------------------------------------------------------*)
173 \<close> ML \<open> (*//----------- inserted hidden code ------------------------------------------------\\*)
174 (*//------------------ inserted hidden code ------------------------------------------------\\*)
175 (*\\------------------ inserted hidden code ------------------------------------------------//*)
176 \<close> ML \<open> (*\\----------- inserted hidden code ------------------------------------------------//*)
178 \<close> ML \<open> (*//----------- build new fun XXXXX -------------------------------------------------\\*)
179 (*//------------------ build new fun XXXXX -------------------------------------------------\\*)
180 (*\\------------------ build new fun XXXXX -------------------------------------------------//*)
181 \<close> ML \<open> (*\\----------- build new fun XXXXX -------------------------------------------------//*)
191 (*fun autoCalculate' cI auto = autoCalculate cI auto (*|> Future.join*)*);
194 section \<open>trials with Isabelle's functions\<close>
195 ML \<open>"%%%%%%%%%%%%%%%%% start Isabelle %%%%%%%%%%%%%%%%%%%%%%%";\<close>
196 ML_file "$ISABELLE_ISAC_TEST/Pure/General/alist.ML"
197 ML_file "$ISABELLE_ISAC_TEST/Pure/General/basics.ML"
198 ML_file "$ISABELLE_ISAC_TEST/Pure/General/scan.ML"
199 ML_file "$ISABELLE_ISAC_TEST/Pure/PIDE/xml.ML"
200 ML \<open>"%%%%%%%%%%%%%%%%% end Isabelle %%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
202 section \<open>test ML Code of isac\<close>
203 subsection \<open>basic code first\<close>
204 ML \<open>"%%%%%%%%%%%%%%%%% start ProgLang.thy %%%%%%%%%%%%%%%%%%%";\<close>
205 ML_file "BaseDefinitions/base-definitions.sml"
206 ML_file "BaseDefinitions/libraryC.sml"
207 ML_file "BaseDefinitions/rule-def.sml"
208 ML_file "BaseDefinitions/eval-def.sml"
209 ML_file "BaseDefinitions/rewrite-order.sml"
210 ML_file "BaseDefinitions/theoryC.sml"
211 ML_file "BaseDefinitions/rule.sml"
212 ML_file "BaseDefinitions/thmC-def.sml"
213 ML_file "BaseDefinitions/model-pattern.sml"
214 ML_file "BaseDefinitions/error-fill-def.sml"
215 ML_file "BaseDefinitions/rule-set.sml"
216 ML_file "BaseDefinitions/check-unique.sml"
217 (*called by Know_Store..*)
218 ML_file "BaseDefinitions/calcelems.sml"
219 ML_file "BaseDefinitions/termC.sml"
220 ML_file "BaseDefinitions/substitution.sml"
221 ML_file "BaseDefinitions/contextC.sml"(*sometimes needs separation into ML blocks for evaluation*)
222 ML_file "BaseDefinitions/environment.sml"
223 (**)ML_file "BaseDefinitions/kestore.sml"(*setup in ADDTEST/accumulate-val/lucas_interpreter.sml*)
224 (*---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------
225 ---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------*)
227 ML_file "ProgLang/calculate.sml"
228 ML_file "ProgLang/evaluate.sml" (* requires setup from calculate.thy *)
229 ML_file "ProgLang/listC.sml"
230 ML_file "ProgLang/prog_expr.sml"
231 ML_file "ProgLang/program.sml"
232 ML_file "ProgLang/prog_tac.sml"
233 ML_file "ProgLang/tactical.sml"
234 ML_file "ProgLang/auto_prog.sml"
235 (*---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------
236 ---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------*)
238 subsection \<open>basic functionality on simple example first\<close>
239 ML_file "Minisubpbl/000-comments.sml"
240 ML_file "Minisubpbl/100-init-rootpbl.sml"
241 ML_file "Minisubpbl/150a-add-given-Maximum.sml"
242 ML_file "Minisubpbl/150-add-given-Equation.sml"
243 ML_file "Minisubpbl/200-start-method-NEXT_STEP.sml"
244 ML_file "Minisubpbl/200-start-method.sml"
245 ML_file "Minisubpbl/250-Rewrite_Set-from-method.sml"
246 ML_file "Minisubpbl/300-init-subpbl-NEXT_STEP.sml"
247 ML_file "Minisubpbl/300-init-subpbl.sml"
248 ML_file "Minisubpbl/400-start-meth-subpbl.sml"
249 ML_file "Minisubpbl/450-Rewrite_Set_Inst.sml"
250 ML_file "Minisubpbl/470-Check_elementwise-NEXT_STEP.sml"
251 ML_file "Minisubpbl/490-nxt-Check_Postcond.sml"
252 ML_file "Minisubpbl/500-met-sub-to-root.sml"
253 ML_file "Minisubpbl/530-error-Check_Elementwise.sml"
254 ML_file "Minisubpbl/600-postcond-NEXT_STEP.sml"
255 ML_file "Minisubpbl/600-postcond.sml"
256 ML_file "Minisubpbl/700-interSteps.sml"
257 ML_file "Minisubpbl/710-interSteps-short.sml"
258 ML_file "Minisubpbl/790-complete-NEXT_STEP.sml"
259 ML_file "Minisubpbl/790-complete.sml"
260 ML_file "Minisubpbl/800-append-on-Frm.sml"
262 subsection \<open>further functionality alongside batch build sequence\<close>
263 ML_file "MathEngBasic/thmC.sml"
264 ML_file "MathEngBasic/problem.sml"
265 ML_file "MathEngBasic/rewrite.sml"
266 ML_file "MathEngBasic/tactic.sml"
267 ML_file "MathEngBasic/ctree.sml" (*if red, get the file into a text buffer -- this might clear*)
268 ML_file "MathEngBasic/calculation.sml"
270 ML_file "Specify/formalise.sml"
271 ML_file "Specify/o-model.sml"
272 ML_file "Specify/i-model.sml"
273 ML_file "Specify/pre-conditions.sml"
274 ML_file "Specify/p-model.sml"
275 ML_file "Specify/m-match.sml"
276 ML_file "Specify/refine.sml" (* requires setup from refine.thy *)
277 ML_file "Specify/test-out.sml"
278 ML_file "Specify/specify-step.sml"
279 ML_file "Specify/specification.sml"
280 ML_file "Specify/cas-command.sml"
281 ML_file "Specify/p-spec.sml"
282 ML_file "Specify/specify.sml"
283 ML_file "Specify/sub-problem.sml"
284 ML_file "Specify/step-specify.sml"
286 ML_file "Interpret/istate.sml"
287 ML_file "Interpret/error-pattern.sml"
288 ML_file "Interpret/li-tool.sml"
289 ML_file "Interpret/lucas-interpreter.sml"
290 ML_file "Interpret/step-solve.sml"
292 ML_file "MathEngine/me-misc.sml"
293 ML_file "MathEngine/fetch-tactics.sml"
294 ML_file "MathEngine/solve.sml"
295 ML_file "MathEngine/step.sml"
296 ML_file "MathEngine/mathengine-stateless.sml"
297 ML_file "MathEngine/messages.sml"
298 ML_file "MathEngine/states.sml"
300 ML_file "BridgeLibisabelle/thy-present.sml"
301 ML_file "BridgeLibisabelle/mathml.sml" (*part.*)
302 ML_file "BridgeLibisabelle/pbl-met-hierarchy.sml"
303 ML_file "BridgeLibisabelle/thy-hierarchy.sml"
304 ML_file "BridgeLibisabelle/interface-xml.sml" (*TODO after 2009-2*)
305 ML_file "BridgeLibisabelle/interface.sml"
307 ML_file "BridgeJEdit/parseC.sml"
308 ML_file "BridgeJEdit/preliminary.sml"
309 ML_file "BridgeJEdit/vscode-example.sml"
311 ML_file "Knowledge/delete.sml"
312 ML_file "Knowledge/descript.sml"
313 ML_file "Knowledge/simplify.sml"
314 ML_file "Knowledge/poly-1.sml"
315 (*ML_file "Knowledge/poly-2.sml" Test_Isac_Short*)
316 ML_file "Knowledge/gcd_poly_ml.sml"
317 ML_file "Knowledge/rational-1.sml"
318 (*ML_file "Knowledge/rational-2.sml" Test_Isac_Short*)
319 ML_file "Knowledge/equation.sml"
320 ML_file "Knowledge/root.sml"
321 ML_file "Knowledge/lineq.sml"
322 (*ML_file "Knowledge/rooteq.sml" some complicated equations not recovered from 2002 *)
323 (*ML_file "Knowledge/rateq.sml" some complicated equations not recovered----Test_Isac_Short*)
324 ML_file "Knowledge/rootrat.sml"
325 ML_file "Knowledge/rootrateq.sml"(*ome complicated equations not recovered from 2002 *)
326 (*ML_file "Knowledge/partial_fractions.sml" hangs with ML_system_64 = "true"---Test_Isac_Short*)
327 ML_file "Knowledge/polyeq-1.sml"
328 (*ML_file "Knowledge/polyeq-2.sml" Test_Isac_Short*)
329 (*ML_file "Knowledge/rlang.sml" much to clean up, similar tests in other files *)
330 ML_file "Knowledge/calculus.sml"
331 ML_file "Knowledge/trig.sml"
332 (*ML_file "Knowledge/logexp.sml" not included as stuff for presentation of authoring*)
333 ML_file "Knowledge/diff.sml"
334 ML_file "Knowledge/integrate.sml"
335 ML_file "Knowledge/eqsystem-1.sml"
336 ML_file "Knowledge/eqsystem-1a.sml"
337 ML_file "Knowledge/eqsystem-2.sml"
338 ML_file "Knowledge/test.sml"
339 ML_file "Knowledge/polyminus.sml"
340 ML_file "Knowledge/vect.sml"
341 ML_file "Knowledge/diff-app.sml" (* postponed to dev. specification | TP-prog. *)
342 ML_file "Knowledge/biegelinie-1.sml"
343 (*ML_file "Knowledge/biegelinie-2.sml" Test_Isac_Short*)
344 (*ML_file "Knowledge/biegelinie-3.sml" Test_Isac_Short*)
345 ML_file "Knowledge/biegelinie-4.sml"
346 ML_file "Knowledge/algein.sml"
347 ML_file "Knowledge/diophanteq.sml"
348 (*ML_file "Knowledge/inverse_z_transform.sml"hangs with ML_system_64 = "true"---Test_Isac_Short*)
349 ML_file "Knowledge/inssort.sml"
350 ML_file "Knowledge/isac.sml"
351 ML_file "Knowledge/build_thydata.sml"
353 ML_file "Test_Code/test-code.sml"
355 section \<open>further tests additional to src/.. files\<close>
356 ML_file "BridgeLibisabelle/use-cases.sml"
358 ML \<open>"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
359 ML \<open>"%%%%%%%%%%%%%%%%% end Test_Isac %%%%%%%%%%%%%%%%%%%%%%%%";\<close>
360 ML \<open>"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
368 section \<open>history of tests\<close>
370 Systematic regression tests have been introduced to isac development in 2003.
371 Sanity of the regression tests suffers from updates following Isabelle development,
372 which mostly exceeded the resources available in isac's development.
374 The survey below shall support to efficiently use the tests for isac
375 on different Isabelle versions. Conclusion in most cases will be:
377 !!! Use most recent tests or go back to the old notebook
378 with isac on Isabelle2002. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
382 subsection \<open>isac on Isabelle2017\<close>
383 subsubsection \<open>Summary of development\<close>
385 * Add further signatures, separate structures and cleanup respective files.
386 * Show feasibility of moving Isac programs to partial_function, i.e. to the function package.
387 * Clean theory dependencies.
388 * Start preparing shift from isac-java to Isabelle/jEdit.
390 subsubsection \<open>State of tests: unchanged\<close>
391 subsubsection \<open>Changesets of begin and end\<close>
393 last changeset with Test_Isac 925fef0f4c81
394 first changeset with Test_Isac bbb414976dfe
397 subsection \<open>isac on Isabelle2015\<close>
398 subsubsection \<open>Summary of development\<close>
400 * Add signatures from top of thy-hierarchy down to Interpret (not ProgLang).
401 This complicates Test_Isac, see "Prepare running tests" above.
402 * Remove TTY interface.
403 * Re-activate insertion sort.
405 subsubsection \<open>State of tests: unchanged\<close>
406 subsubsection \<open>Changesets of begin and end\<close>
408 last changeset with Test_Isac 2f1b2854927a
409 first changeset with Test_Isac ???
412 subsection \<open>isac on Isabelle2014\<close>
413 subsubsection \<open>Summary of development\<close>
415 migration from "isabelle tty" --> libisabelle
418 subsection \<open>isac on Isabelle2013-2\<close>
419 subsubsection \<open>Summary of development\<close>
421 reactivated context_thy
423 subsubsection \<open>State of tests\<close>
427 subsubsection \<open>Changesets of begin and end\<close>
431 : isac on Isablle2013-2
433 Changeset: 55318 (03826ceb24da) merged
434 User: Walther Neuper <neuper@ist.tugraz.at>
435 Date: 2013-12-12 14:27:37 +0100 (7 minutes)
438 subsection \<open>isac on Isabelle2013-1\<close>
439 subsubsection \<open>Summary of development\<close>
441 Isabelle2013-1 was replaced within a few weeks due to problems with the document model;
442 no significant development steps for ISAC.
444 subsubsection \<open>State of tests\<close>
446 See points in subsection "isac on Isabelle2011", "State of tests".
448 subsubsection \<open>Changesets of begin and end\<close>
450 Changeset: 55283 (d6e9a34e7142) notes for resuming work on Polynomial.thy
451 User: Walther Neuper <neuper@ist.tugraz.at>
452 Date: 2013-12-03 18:13:31 +0100 (8 days)
454 : isac on Isablle2013-1
456 Changeset: 55279 (130688f277ba) Isabelle2013 --> 2013-1: Test_Isac perfect
457 User: Walther Neuper <neuper@ist.tugraz.at>
458 Date: 2013-11-21 18:12:17 +0100 (2 weeks)
462 subsection \<open>isac on Isabelle2013\<close>
463 subsubsection \<open>Summary of development\<close>
465 # Oct.13: replaced "axioms" by "axiomatization"
466 # Oct.13: Mathias Lehnfeld started removing Unsynchornized.ref
467 # Sep.13: integrated gcd_poly (functional, without Unsychronized.ref) into
468 simplification of multivariate rationals (without improving the rulesets involved).
470 subsubsection \<open>Run tests\<close>
472 Is standard now; this subsection will be discontinued under Isabelle2013-1
474 subsubsection \<open>State of tests\<close>
476 See points in subsection "isac on Isabelle2011", "State of tests".
477 # re-activated listC.sml
479 subsubsection \<open>Changesets of begin and end\<close>
481 changeset 52174:8b055b17bd84 --- removed all code concerned with "castab = Unsynchronized.ref"
482 User: Mathias Lehnfeld <s1210629013@students.fh-hagenberg.at>
483 Date: Tue Nov 19 22:23:30 2013 +0000
485 : isac on Isablle2013
487 Changeset: 52061 (4ecea2fcdc2c) --- Build_Isac.thy runs on Isabelle2013
488 User: Walther Neuper <neuper@ist.tugraz.at>
489 Date: 2013-07-15 08:28:50 +0200 (4 weeks)
492 subsection \<open>isac on Isabelle2012\<close>
493 subsubsection \<open>Summary of development\<close>
495 isac on Isabelle2012 is considered just a transitional stage
496 within the update from Isabelle2011 to Isabelle2013; thus no further development of isac;
497 For considerations on the transition see
498 $ISABELLE_ISAC/Knowledge/Build_Thydata/thy, section "updating isac..".
500 subsubsection \<open>Run tests\<close>
502 $ cd /usr/local/isabisac12/
503 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
504 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
506 subsubsection \<open>State of tests\<close>
508 At least the tests from isac on Isabelle2011 run again.
509 However, Test_Isac.thy shows erratic behaviour; no errors are obtained when scrolling
510 in parallel with evaluation.
512 Counting "error in kernel" for Frontend/interface.sml (the tests considered most significant)
513 yields 69 hits, some of which were already present before Isabelle2002-->2009-2
514 (i.e. on the old notebook from 2002).
516 Now many tests with (*...=== inhibit exn ...*) give a reason or at least the origin:
517 # === inhibit exn WN1130621 Isabelle2012-->13 !thehier! === ...see Build_Thydata.thy
518 # === inhibit exn AK110726 === ...reliable work by Alexander Kargl, most likely go back to 2002
519 # === inhibit exn WN1130701 broken at Isabelle2002 --> 2009-2 === , most likely go back to 2002
520 Reasons for outcommented tests are also found in Test_Isac.thy near the respective file.sml.
522 Some tests have been re-activated (e.g. error patterns, fill patterns).
524 subsubsection \<open>Changesets of begin and end\<close>
526 Changeset: 52051 (35751d90365e) end of improving tests for isac on Isabelle2012
527 User: Walther Neuper <neuper@ist.tugraz.at>
528 Date: 2013-07-11 16:58:31 +0200 (4 weeks)
530 : isac on Isablle2012
532 Changeset: 48757 (74eb3dfc33cc) updated src from Isabelle2011 to Isabelle2012
533 User: Walther Neuper <neuper@ist.tugraz.at>
534 Date: 2012-09-24 18:35:13 +0200 (8 months)
535 ------------------------------------------------------------------------------
536 Changeset: 48756 (7443906996a8) merged
537 User: Walther Neuper <neuper@ist.tugraz.at>
538 Date: 2012-09-24 18:15:49 +0200 (8 months)
541 subsection \<open>isac on Isabelle2011\<close>
542 subsubsection \<open>Summary of development\<close>
544 isac's mathematics engine has been extended by two developments:
545 (1) Isabelle's contexts were introduced by Mathias Lehnfeld
546 (2) Z_Transform was introduced by Jan Rocnik, which revealed
547 further errors introduced by (1).
548 (3) "error patterns" were introduced by Gabriella Daroczy
549 Regressions tests have been added for all of these.
551 subsubsection \<open>Run tests\<close>
553 $ cd /usr/local/isabisac11/
554 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
555 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
557 subsubsection \<open>State of tests\<close>
559 Systematic efforts outcommented less significant tests by (*...=== inhibit exn ...*)
560 and sometimes give reasons for failing tests.
561 (*...=== inhibit exn AK...*) was done by Alexander Kargl; this is reliable
562 work, some of which couldn't be revised (and renamed) by WN and thus survived some time.
564 The most signification tests (in particular Frontend/interface.sml) run,
565 however, many "error in kernel" are not caught by an exception.
566 ------------------------------------------------------------------------------
567 After the changeset below Test_Isac worked with check_unsynchronized_ref ():
568 ------------------------------------------------------------------------------
569 Changeset: 42457 (ca691a84b81a) PROVISIONALLY MADE TESTS RUN with Unsynchronized.ref
570 User: Walther Neuper <neuper@ist.tugraz.at>
571 Date: 2012-08-06 10:38:11 +0200 (11 months)
574 The list below records TODOs while producing an ISAC kernel for
575 gdaroczy and jrocnik, wich could NOT be done before all tests are RUNNING
576 (so to be resumed with Isabelle2013-1):
577 ############## WNxxxxxx.TODO can be found in sources ##############
578 --------------------------------------------------------------------------------
579 WN111013.TODO: lots of cleanup/removal in test/../Test.thy
580 --------------------------------------------------------------------------------
581 WN111013.TODO: remove concept around "fun implicit_take", lots of troubles with
582 this special case (see) --- why not nxt = Model_Problem here ? ---
583 --------------------------------------------------------------------------------
584 WN111014.TODO calculate_Poly < calculate_Rational < calculate_RootRat, see test/
586 # simplify_* , *_simp_*
588 # calc_* , calculate_* ... require iteration over all rls ...
589 ... see --- val rls = calculate_RootRat > calculate_Rational --- CONTINUE !
590 --------------------------------------------------------------------------------
591 WN111014.TODO fun prep_rls | !!!use this function in ruleset' := !!!
592 --------------------------------------------------------------------------------
593 WN120314 changeset a393bb9f5e9f drops root equations.
594 see test/Tools/isac/Knowledge/rootrateq.sml
595 --------------------------------------------------------------------------------
596 WN120317.TODO changeset 977788dfed26 dropped rateq:
597 # test --- repair NO asms from rls RatEq_eliminate --- shows error from 2002
598 # test --- solve (1/x = 5, x) by me --- and --- x / (x ^ 2 - 6 * x + 9) - ...:
599 investigation Check_elementwise stopped due to too much effort finding out,
600 why Check_elementwise worked in 2002 in spite of the error.
601 --------------------------------------------------------------------------------
602 WN120317.TODO postponed test/../ratinal,ratinal2.sml to joint work with dmeindl
603 --------------------------------------------------------------------------------
604 WN120317.TODO found by test --- interSteps for Schalk 299a --- that
605 NO test with 'interSteps' is checked properly (with exn on changed behaviour)
606 --------------------------------------------------------------------------------
607 WN120317.TODO test --- Matthias Goldgruber 2003 rewrite orders --- has
608 a newly outcommented test where rewrite_set_ make_polynomial --> NONE
609 --------------------------------------------------------------------------------
610 WN120320.TODO check-improve rlsthmsNOTisac:
611 DONE make test --- old compute rlsthmsNOTisac by eq_thmI'
612 DONE compare rlsthmsNOTisac in thms-survey-Isa02-Isa09-2.sml .. Isac.thy
613 FOUND 120321: Theory.axioms_of doesnt find LENGTH_CONS etc, thus are in Isab
614 # mark twice thms (in isac + (later) in Isabelle) in Isac.thy
615 --------------------------------------------------------------------------------
616 WN120320.TODO rlsthmsNOTisac: replace twice thms ^
617 --------------------------------------------------------------------------------
618 WN120320.TODO rlsthmsNOTisac: reconsider design of sym_* thms, see test
619 --- OLD compute rlsthmsNOTisac by eq_thmID ---: some are in isab, some in isac.
620 --------------------------------------------------------------------------------
621 WN120321.TODO rearrange theories:
625 ///Input_Descript.thy --> ProgLang
626 Delete.thy <--- first_Knowledge_thy (*mv to Prog_Expr.thy*)
627 ProgLang: restructure Build_Isac.thy such that no xmlsrc.thy, ProgLang.thy
628 Interpret.thy are generated (simplifies xml structure for theories)
631 ListC.thy <--- first_Proglang_thy
632 --------------------------------------------------------------------------------
633 WN120321.TODO reanimate test/../simplify.sml: CAS-command Simplify
634 EXN "simplify.sml: diff.behav. CAScmd: Simplify (2*a + 3*a)"
635 broken during work on thy-hierarchy
636 --------------------------------------------------------------------------------
637 WN120321.TODO LAST in IsacScripts + in IsacKnowledge, see
638 test --- the_hier (get_thes ()) (collect_thydata ())---
639 --------------------------------------------------------------------------------
640 WN120405a.TODO src/../pbl-met-hierarchy.sml: fun pbl2term--> Isac' instead Isac_
641 !!add mutual crossreferences to ?fun headline??? where the same has to be done:
642 !!OR BETTER: use only 2 functions for adding/removing "'" to/from thy!!
643 --------------------------------------------------------------------------------
644 WN120411 scanning html representation of newly generated knowledge:
646 ** Theorems: only "Proof of the theorem" (correct!)
647 and "(c) isac-team (math-autor)"
648 ** Rulesets: only "Identifier:///"
649 and "(c) isac-team (math-autor)"
650 ** IsacKnowledge: link to dependency graph (which needs to be created first)
651 ** IsacScripts --> ProgramLanguage
652 *** Tools: Theorems: arity_type_cp, arity_type_nam, ... wegnehmen
657 ** Z-Transform is missing !!!
658 ** type-constraints !!!
659 --------------------------------------------------------------------------------
660 WN120417: merging xmldata revealed:
661 ..............NEWLY generated:........................................
663 <GUH> thy_isab_Fun-thm-o_apply </GUH>
665 <STRING> Isabelle </STRING>
666 <STRING> Fun </STRING>
667 <STRING> Theorems </STRING>
668 <STRING> o_apply </STRING>
671 <ISA> (?f o ?g) ?x = ?f (?g ?x) </ISA>
674 <TEXT> Proof of the theorem </TEXT>
675 <URL> http://www.ist.tugraz.at/projects/isac/www/kbase/thy/browser_info/HOL/HOL-Real/Isac/Fun.html </URL>
678 <EXPLANATIONS> </EXPLANATIONS>
680 <STRING> Isabelle team, TU Munich </STRING>
685 ..............OLD FORMAT:.............................................
687 <GUH> thy_isab_Fun-thm-o_apply </GUH>
689 <STRING> Isabelle </STRING>
690 <STRING> Fun </STRING>
691 <STRING> Theorems </STRING>
692 <STRING> o_apply </STRING>
697 <ISA> (?f o ?g) ?x = ?f (?g ?x) </ISA>
702 <TEXT> Proof of the theorem </TEXT>
703 <URL> http://www.ist.tugraz.at/projects/isac/www/kbase/thy/browser_info/HOL/HOL-Real/Isac/Fun.html </URL>
706 <EXPLANATIONS> </EXPLANATIONS>
708 <STRING> Isabelle team, TU Munich </STRING>
713 --------------------------------------------------------------------------------
715 subsubsection \<open>Changesets of begin and end\<close>
717 isac development was done between these changesets:
718 ------------------------------------------------------------------------------
719 Changeset: 42519 (1f3b4270363e) meeting dmeindl: added missing files
720 User: Walther Neuper <neuper@ist.tugraz.at>
721 Date: 2012-09-24 16:39:30 +0200 (8 months)
723 : isac on Isablle2011
725 Changeset:41897 (355be7f60389) merged isabisac with Isabelle2011
726 Branch: decompose-isar
727 User: Walther Neuper <neuper@ist.tugraz.at>
728 Date: 2011-02-25 13:04:56 +0100 (2011-02-25)
729 ------------------------------------------------------------------------------
732 subsection \<open>isac on Isabelle2009-2\<close>
733 subsubsection \<open>Summary of development\<close>
735 In 2009 the update of isac from Isabelle2002 started with switching from CVS to hg.
736 The update was painful (bridging 7 years of Isabelle development) and cut short
737 due to the start of introducing Isabelle's contexts (Mathias Lehnfeld) and
738 going on to Isabelle2011 although most of the tests did not run.
740 subsubsection \<open>Run tests\<close>
742 WN131021 this is broken by installation of Isabelle2011/12/13,
743 because all these write their binaries to ~/.isabelle/heaps/..
745 $ cd /usr/local/isabisac09-2/
746 $ ./bin/isabelle emacs -l HOL src/Tools/isac/Build_Isac.thy
747 $ ./bin/isabelle emacs -l Isac src/Tools/isac/Test_Isac.thy
748 NOT THE RIGHT VERSION..... test/Tools/isac/Test_Isac.thy !!!
750 subsubsection \<open>State of tests\<close>
752 Most tests are broken by the update from Isabelle2002 to Isabelle2009-2.
754 subsubsection \<open>Changesets of begin and end\<close>
756 isac development was done between these changesets:
757 ------------------------------------------------------------------------------
758 Changeset: 38115 (940a5feea094) Little improvements of isac-plugin
759 Branch: decompose-isar
760 User: Marco Steger <m.steger@student.tugraz.at>
761 Date: 2011-02-06 18:30:28 +0100 (2011-02-06)
763 : isac on Isablle2009-2
765 Changeset: 37870 (5100a9c3abf8) created branch isac-from-Isabelle2009-2
766 Branch: isac-from-Isabelle2009-2
767 User: Walther Neuper <neuper@ist.tugraz.at>
768 Date: 2010-07-21 09:59:35 +0200 (2010-07-21)
769 ------------------------------------------------------------------------------
772 subsection \<open>isac on Isabelle2002\<close>
773 subsubsection \<open>Summary of development\<close>
775 From 1999 to 2010 all the basic functionality (except "ctxt" and "error pattern")
776 of isac's mathematics engine has been implemented.
778 subsubsection \<open>Run tests\<close>
779 subsubsection \<open>State of tests\<close>
781 All tests work on an old notebook (the right PolyML coudn't be upgraded to more
782 recent Linux versions)
784 subsubsection \<open>Changesets of begin and end\<close>
786 Up to the above Mercurial changeset 5100a9c3abf8 isac used CVS;
787 see https://intra.ist.tugraz.at/hg/isac containing a conversion to Mercurial.
791 (*========== inhibit exn 130719 Isabelle2013 ===================================
792 ============ inhibit exn 130719 Isabelle2013 =================================*)
794 (*-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.
795 -.-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.*)