test/Tools/isac/Test_Isac.thy
author wneuper <Walther.Neuper@jku.at>
Sat, 18 Jun 2022 12:34:29 +0200
changeset 60458 af7735fd252f
parent 60424 c3acf9c442ac
child 60465 51ed5cb9c1c1
permissions -rw-r--r--
adapth thy to Demo_Example
     1 (* Title:  All tests on isac (some outcommented since Isabelle2002-->2009-2)
     2    Author: Walther Neuper 101001
     3    (c) copyright due to license terms.
     4 
     5    Isac's tests are organised parallel to sources: 
     6      $ISABELLE_ISAC_TEST has same directory structure as $ISABELLE_ISAC
     7    plus
     8      $ISABELLE_ISAC_TEST/Tools/isac/ADDTESTS
     9      $ISABELLE_ISAC_TEST/Tools/isac/Minisubpbl: the Lucas-Interpreter's core functionality
    10 
    11 Note, that only the first error in a file is shown here.
    12 *)
    13 
    14 section \<open>Notes on running tests\<close>
    15 subsection \<open>Switch between running tests and updating code\<close>
    16 text \<open>
    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.
    20 \<close>
    21 subsection \<open>Decide between running Test_Isac_Short.thy and Test_Isac.thy\<close>
    22 text \<open>
    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.
    30 
    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.
    34 
    35 \\******************* don't forget to re-set defaults BEFORE updating code *******************//
    36 
    37     Note that Isabelle/jEdit re-generates the preferences file on shutdown, thus always use
    38     ***************** $ gedit ~/.isabelle/isabisac/etc/preferences &
    39 \<close>
    40 
    41 section \<open>Run the tests\<close>
    42 text \<open>
    43 * say "OK" to the popup asking for theories to be loaded
    44 * watch the <Theories> window for errors in the "imports" below
    45 \<close>
    46 
    47 theory Test_Isac
    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*)
    79 (**) 
    80 (*\---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------/*)
    81   "$ISABELLE_ISAC/Knowledge/GCD_Poly_OLD" (*not imported by Isac.thy*)
    82   "$ISABELLE_ISAC/Knowledge/GCD_Poly_FP"  (*not imported by Isac.thy*)
    83 (*\---------------------- do Minisubpbl before ADDTESTS/All_Ctxt ------------------------------/*)
    84 (**)
    85 
    86 begin
    87 
    88 declare [[ML_print_depth = 20]]
    89 
    90 ML \<open>open ML_System\<close>
    91 ML \<open>
    92   open Kernel;
    93   open Math_Engine;
    94   open Test_Code;              CalcTreeTEST;
    95   open LItool;                 arguments_from_model;
    96   open Sub_Problem;
    97   open Fetch_Tacs;
    98   open Step
    99   open Env;
   100   open LI;                     scan_dn;
   101   open Istate;
   102   open Error_Pattern;
   103   open Error_Pattern_Def;
   104   open Specification;
   105   open Ctree;                  append_problem;
   106   open Pos;
   107   open Program;
   108   open Prog_Tac;
   109   open Tactical;
   110   open Prog_Expr;
   111   open Auto_Prog;              rule2stac;
   112   open Input_Descript;
   113   open Specify;
   114   open Specify;
   115   open Step_Specify;
   116   open Step_Solve;
   117   open Step;
   118   open Solve;                  (* NONE *)
   119   open ContextC;               transfer_asms_from_to;
   120   open Tactic;                 (* NONE *)
   121   open I_Model;
   122   open O_Model;
   123   open P_Model;                (* NONE *)
   124   open Rewrite;
   125   open Eval;                   get_pair;
   126   open TermC;                  atomt;
   127   open Rule;
   128   open Rule_Set;               Sequence;
   129   open Eval_Def
   130   open ThyC
   131   open ThmC_Def
   132   open ThmC
   133   open Rewrite_Ord
   134   open UnparseC
   135 \<close>
   136 
   137 ML \<open>
   138 "~~~~~ fun xxx , args:"; val () = ();
   139 "~~~~~ and xxx , args:"; val () = ();
   140 "~~~~~ from fun xxx \<longrightarrow>fun yyy \<longrightarrow>fun zzz , return:"; val () = ();
   141 (*if*) (*then*); (*else*);   (*case*) (*of*);  (*return value*); (*in*) (*end*);
   142 "xx"
   143 ^ "xxx"   (*+*) (*+++*) (*!for return!*) (*isa*) (*REP*) (**)
   144 \<close> ML \<open> (*//---------------- adhoc inserted ------------------------------------------------\\*)
   145 \<close> ML \<open>
   146 \<close> ML \<open> (*\\---------------- adhoc inserted ------------------------------------------------//*)
   147 Rewrite.trace_on := false;
   148 \<close>
   149 ML \<open>
   150 \<close> ML \<open>
   151 \<close> ML \<open>
   152 \<close> ML \<open>
   153 \<close> ML \<open>
   154 \<close> ML \<open>
   155 \<close> ML \<open>
   156 \<close> ML \<open>
   157 \<close> ML \<open>
   158 \<close> ML \<open>
   159 \<close> ML \<open>
   160 \<close>
   161 
   162 ML \<open>
   163   KEStore_Elems.set_ref_thy @{theory};
   164   (*fun autoCalculate' cI auto = autoCalculate cI auto (*|> Future.join*)*);
   165 \<close>
   166 
   167 section \<open>trials with Isabelle's functions\<close>
   168   ML \<open>"%%%%%%%%%%%%%%%%% start Isabelle %%%%%%%%%%%%%%%%%%%%%%%";\<close>
   169   ML_file "$ISABELLE_ISAC_TEST/Pure/General/alist.ML"
   170   ML_file "$ISABELLE_ISAC_TEST/Pure/General/basics.ML"
   171   ML_file "$ISABELLE_ISAC_TEST/Pure/General/scan.ML"
   172   ML_file "$ISABELLE_ISAC_TEST/Pure/PIDE/xml.ML"
   173   ML \<open>"%%%%%%%%%%%%%%%%% end Isabelle %%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
   174 
   175 section \<open>test ML Code of isac\<close>
   176 subsection \<open>basic code first\<close>
   177   ML \<open>"%%%%%%%%%%%%%%%%% start ProgLang.thy %%%%%%%%%%%%%%%%%%%";\<close>
   178   ML_file "BaseDefinitions/base-definitions.sml"
   179   ML_file "BaseDefinitions/libraryC.sml"
   180   ML_file "BaseDefinitions/rule-def.sml"
   181   ML_file "BaseDefinitions/eval-def.sml"
   182   ML_file "BaseDefinitions/rewrite-order.sml"
   183   ML_file "BaseDefinitions/theoryC.sml"
   184   ML_file "BaseDefinitions/rule.sml"
   185   ML_file "BaseDefinitions/thmC-def.sml"
   186   ML_file "BaseDefinitions/error-fill-def.sml"
   187   ML_file "BaseDefinitions/rule-set.sml"
   188   ML_file "BaseDefinitions/check-unique.sml"
   189 (*called by Know_Store..*)
   190   ML_file "BaseDefinitions/calcelems.sml"
   191   ML_file "BaseDefinitions/termC.sml"
   192   ML_file "BaseDefinitions/substitution.sml"
   193   ML_file "BaseDefinitions/contextC.sml" (*!!!!! sometimes evaluates if separated into ML blocks*)
   194   ML_file "BaseDefinitions/environment.sml"
   195 (** )ML_file "BaseDefinitions/kestore.sml"( *setup in ADDTEST/accumulate-val/lucas_interpreter.sml*)
   196 (*---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------
   197   ---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------*)
   198 
   199   ML_file "ProgLang/evaluate.sml"       (* requires setup from calculate.thy                    *)
   200   ML_file "ProgLang/listC.sml"
   201   ML_file "ProgLang/prog_expr.sml"
   202   ML_file "ProgLang/program.sml"
   203   ML_file "ProgLang/prog_tac.sml"
   204   ML_file "ProgLang/tactical.sml"
   205   ML_file "ProgLang/auto_prog.sml"
   206 (*---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------
   207   ---------------------- do Minisubpbl before ADDTESTS/All_Ctxt --------------------------------*)
   208 
   209 subsection \<open>basic functionality on simple example first\<close>
   210   ML_file "Minisubpbl/000-comments.sml"
   211   ML_file "Minisubpbl/100-init-rootpbl.sml"
   212   ML_file "Minisubpbl/150-add-given.sml"
   213   ML_file "Minisubpbl/200-start-method-NEXT_STEP.sml"
   214   ML_file "Minisubpbl/200-start-method.sml"
   215   ML_file "Minisubpbl/250-Rewrite_Set-from-method.sml"
   216   ML_file "Minisubpbl/300-init-subpbl-NEXT_STEP.sml"
   217   ML_file "Minisubpbl/300-init-subpbl.sml"
   218   ML_file "Minisubpbl/400-start-meth-subpbl.sml"
   219   ML_file "Minisubpbl/450-Rewrite_Set_Inst.sml"
   220   ML_file "Minisubpbl/470-Check_elementwise-NEXT_STEP.sml"
   221   ML_file "Minisubpbl/490-nxt-Check_Postcond.sml"
   222   ML_file "Minisubpbl/500-met-sub-to-root.sml"
   223   ML_file "Minisubpbl/530-error-Check_Elementwise.sml"
   224   ML_file "Minisubpbl/600-postcond-NEXT_STEP.sml"
   225   ML_file "Minisubpbl/600-postcond.sml"
   226   ML_file "Minisubpbl/700-interSteps.sml"
   227   ML_file "Minisubpbl/710-interSteps-short.sml"
   228   ML_file "Minisubpbl/790-complete-NEXT_STEP.sml"
   229   ML_file "Minisubpbl/790-complete.sml"
   230   ML_file "Minisubpbl/800-append-on-Frm.sml"
   231 
   232 subsection \<open>further functionality alongside batch build sequence\<close>
   233   ML_file "MathEngBasic/thmC.sml"
   234   ML_file "MathEngBasic/rewrite.sml"
   235   ML_file "MathEngBasic/tactic.sml"
   236   ML_file "MathEngBasic/ctree.sml" (*if red, get the file into a text buffer -- this might clear*)
   237   ML_file "MathEngBasic/calculation.sml"
   238 
   239   ML_file "Specify/formalise.sml"
   240   ML_file "Specify/o-model.sml"
   241   ML_file "Specify/i-model.sml"
   242   ML_file "Specify/pre-conditions.sml"
   243   ML_file "Specify/p-model.sml"
   244   ML_file "Specify/m-match.sml"
   245   ML_file "Specify/refine.sml"        (* requires setup from refine.thy *)
   246   ML_file "Specify/test-out.sml"
   247   ML_file "Specify/specify-step.sml"
   248   ML_file "Specify/specification.sml"
   249   ML_file "Specify/cas-command.sml"
   250   ML_file "Specify/p-spec.sml"
   251   ML_file "Specify/specify.sml"
   252   ML_file "Specify/step-specify.sml"
   253 
   254   ML_file "Interpret/istate.sml"
   255   ML_file "Interpret/sub-problem.sml"
   256   ML_file "Interpret/error-pattern.sml"
   257   ML_file "Interpret/li-tool.sml"
   258   ML_file "Interpret/lucas-interpreter.sml"
   259   ML_file "Interpret/step-solve.sml"
   260 
   261   ML_file "MathEngine/me-misc.sml"
   262   ML_file "MathEngine/fetch-tactics.sml"
   263   ML_file "MathEngine/solve.sml"
   264   ML_file "MathEngine/step.sml"
   265   ML_file "MathEngine/mathengine-stateless.sml"    (*!part. WN130804: +check Interpret/me.sml*)
   266   ML_file "MathEngine/messages.sml"
   267   ML_file "MathEngine/states.sml"
   268 
   269   ML_file "BridgeLibisabelle/thy-present.sml"
   270   ML_file "BridgeLibisabelle/mathml.sml"           (*part.*)
   271   ML_file "BridgeLibisabelle/thy-hierarchy.sml"
   272   ML_file "BridgeLibisabelle/interface-xml.sml"     (*TODO after 2009-2*)
   273   ML_file "BridgeLibisabelle/interface.sml"
   274 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
   275   ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
   276 
   277   ML_file "BridgeJEdit/parseC.sml"
   278 
   279   ML_file "Knowledge/delete.sml"
   280   ML_file "Knowledge/descript.sml"
   281   ML_file "Knowledge/simplify.sml"
   282   ML_file "Knowledge/gcd_poly_ml.sml"
   283   ML_file "Knowledge/rational-1.sml"
   284   ML_file "Knowledge/rational-2.sml"                                          (*Test_Isac_Short*)
   285   ML_file "Knowledge/equation.sml"
   286   ML_file "Knowledge/root.sml"
   287   ML_file "Knowledge/lineq.sml"
   288 (*ML_file "Knowledge/rooteq.sml"    some complicated equations not recovered from 2002 *)
   289   ML_file "Knowledge/rateq.sml"   (*some complicated equations not recovered----Test_Isac_Short*)
   290   ML_file "Knowledge/rootrat.sml"
   291   ML_file "Knowledge/rootrateq.sml"(*ome complicated equations not recovered from 2002 *)
   292 (*ML_file "Knowledge/partial_fractions.sml"  hangs with ML_system_64 = "true"---Test_Isac_Short*)
   293   ML_file "Knowledge/polyeq-1.sml"
   294   ML_file "Knowledge/polyeq-2.sml"                                            (*Test_Isac_Short*)
   295 (*ML_file "Knowledge/rlang.sml"     much to clean up, similar tests in other files     *)
   296   ML_file "Knowledge/calculus.sml"
   297   ML_file "Knowledge/trig.sml"
   298 (*ML_file "Knowledge/logexp.sml"    not included as stuff for presentation of authoring*) 
   299   ML_file "Knowledge/diff.sml"
   300   ML_file "Knowledge/integrate.sml"
   301   ML_file "Knowledge/eqsystem-1.sml"
   302   ML_file "Knowledge/eqsystem-2.sml"
   303   ML_file "Knowledge/test.sml"
   304   ML_file "Knowledge/polyminus.sml"
   305   ML_file "Knowledge/vect.sml"
   306   ML_file "Knowledge/diff-app.sml"        (* postponed to dev. specification | TP-prog. *)
   307   ML_file "Knowledge/biegelinie-1.sml"
   308   ML_file "Knowledge/biegelinie-2.sml"                                        (*Test_Isac_Short*)
   309   ML_file "Knowledge/biegelinie-3.sml"                                        (*Test_Isac_Short*)
   310   ML_file "Knowledge/biegelinie-4.sml"
   311   ML_file "Knowledge/algein.sml"
   312   ML_file "Knowledge/diophanteq.sml"
   313 (*ML_file "Knowledge/inverse_z_transform.sml"hangs with ML_system_64 = "true"---Test_Isac_Short*)
   314   ML_file "Knowledge/inssort.sml"
   315   ML_file "Knowledge/isac.sml"
   316   ML_file "Knowledge/build_thydata.sml"
   317 
   318   ML_file "Test_Code/test-code.sml"
   319 
   320 section \<open>further tests additional to src/.. files\<close>
   321   ML_file "BridgeLibisabelle/use-cases.sml"
   322 
   323   ML \<open>"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
   324   ML \<open>"%%%%%%%%%%%%%%%%% end Test_Isac %%%%%%%%%%%%%%%%%%%%%%%%";\<close>
   325   ML \<open>"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";\<close>
   326 ML \<open>
   327 \<close> ML \<open>
   328 \<close> ML \<open>
   329 \<close> ML \<open>
   330 \<close> ML \<open>
   331 \<close> ML \<open>
   332 \<close> ML \<open>
   333 \<close> ML \<open>
   334 \<close> ML \<open>
   335 \<close> ML \<open>
   336 \<close> ML \<open>
   337 \<close>
   338 
   339 section \<open>history of tests\<close>
   340 text \<open>
   341   Systematic regression tests have been introduced to isac development in 2003.
   342   Sanity of the regression tests suffers from updates following Isabelle development,
   343   which mostly exceeded the resources available in isac's development.
   344 
   345   The survey below shall support to efficiently use the tests for isac 
   346   on different Isabelle versions. Conclusion in most cases will be: 
   347 
   348   !!! Use most recent tests or go back to the old notebook
   349       with isac on Isabelle2002. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   350 \<close>
   351 
   352 
   353 subsection \<open>isac on Isabelle2017\<close>
   354 subsubsection \<open>Summary of development\<close>
   355 text \<open>
   356   * Add further signatures, separate structures and cleanup respective files.
   357   * Show feasibility of moving Isac programs to partial_function, i.e. to the function package.
   358   * Clean theory dependencies.
   359   * Start preparing shift from isac-java to Isabelle/jEdit.
   360 \<close>
   361 subsubsection \<open>State of tests: unchanged\<close>
   362 subsubsection \<open>Changesets of begin and end\<close>
   363 text \<open>
   364   last changeset with Test_Isac 925fef0f4c81
   365   first changeset with Test_Isac bbb414976dfe
   366 \<close>
   367 
   368 subsection \<open>isac on Isabelle2015\<close>
   369 subsubsection \<open>Summary of development\<close>
   370 text \<open>
   371   * Add signatures from top of thy-hierarchy down to Interpret (not ProgLang).
   372     This complicates Test_Isac, see "Prepare running tests" above.
   373   * Remove TTY interface.
   374   * Re-activate insertion sort.
   375 \<close>
   376 subsubsection \<open>State of tests: unchanged\<close>
   377 subsubsection \<open>Changesets of begin and end\<close>
   378 text \<open>
   379   last changeset with Test_Isac 2f1b2854927a
   380   first changeset with Test_Isac ???
   381 \<close>
   382 
   383 subsection \<open>isac on Isabelle2014\<close>
   384 subsubsection \<open>Summary of development\<close>
   385 text \<open>
   386   migration from "isabelle tty" --> libisabelle
   387 \<close>
   388 
   389 subsection \<open>isac on Isabelle2013-2\<close>
   390 subsubsection \<open>Summary of development\<close>
   391 text \<open>
   392   reactivated context_thy
   393 \<close>
   394 subsubsection \<open>State of tests\<close>
   395 text \<open>
   396   TODO
   397 \<close>
   398 subsubsection \<open>Changesets of begin and end\<close>
   399 text \<open>
   400   TODO
   401   :
   402   : isac on Isablle2013-2
   403   :
   404   Changeset: 55318 (03826ceb24da) merged
   405   User: Walther Neuper <neuper@ist.tugraz.at>
   406   Date: 2013-12-12 14:27:37 +0100 (7 minutes)
   407 \<close>
   408 
   409 subsection \<open>isac on Isabelle2013-1\<close>
   410 subsubsection \<open>Summary of development\<close>
   411 text \<open>
   412   Isabelle2013-1 was replaced within a few weeks due to problems with the document model;
   413   no significant development steps for ISAC.
   414 \<close>
   415 subsubsection \<open>State of tests\<close>
   416 text \<open>
   417   See points in subsection "isac on Isabelle2011", "State of tests".
   418 \<close>
   419 subsubsection \<open>Changesets of begin and end\<close>
   420 text \<open>
   421   Changeset: 55283 (d6e9a34e7142) notes for resuming work on Polynomial.thy
   422   User: Walther Neuper <neuper@ist.tugraz.at>
   423   Date: 2013-12-03 18:13:31 +0100 (8 days)
   424   :
   425   : isac on Isablle2013-1
   426   :
   427   Changeset: 55279 (130688f277ba) Isabelle2013 --> 2013-1: Test_Isac perfect
   428   User: Walther Neuper <neuper@ist.tugraz.at>
   429   Date: 2013-11-21 18:12:17 +0100 (2 weeks)
   430 
   431 \<close>
   432 
   433 subsection \<open>isac on Isabelle2013\<close>
   434 subsubsection \<open>Summary of development\<close>
   435 text \<open>
   436   # Oct.13: replaced "axioms" by "axiomatization"
   437   # Oct.13: Mathias Lehnfeld started removing Unsynchornized.ref
   438   # Sep.13: integrated gcd_poly (functional, without Unsychronized.ref) into
   439     simplification of multivariate rationals (without improving the rulesets involved).
   440 \<close>
   441 subsubsection \<open>Run tests\<close>
   442 text \<open>
   443   Is standard now; this subsection will be discontinued under Isabelle2013-1
   444 \<close>
   445 subsubsection \<open>State of tests\<close>
   446 text \<open>
   447   See points in subsection "isac on Isabelle2011", "State of tests".
   448   # re-activated listC.sml
   449 \<close>
   450 subsubsection \<open>Changesets of begin and end\<close>
   451 text \<open>
   452   changeset 52174:8b055b17bd84 --- removed all code concerned with "castab = Unsynchronized.ref"
   453   User: Mathias Lehnfeld <s1210629013@students.fh-hagenberg.at>
   454   Date: Tue Nov 19 22:23:30 2013 +0000
   455   :
   456   : isac on Isablle2013 
   457   :
   458   Changeset: 52061 (4ecea2fcdc2c) --- Build_Isac.thy runs on Isabelle2013
   459   User: Walther Neuper <neuper@ist.tugraz.at>
   460   Date: 2013-07-15 08:28:50 +0200 (4 weeks)
   461 \<close>
   462 
   463 subsection \<open>isac on Isabelle2012\<close>
   464 subsubsection \<open>Summary of development\<close>
   465 text \<open>
   466   isac on Isabelle2012 is considered just a transitional stage
   467   within the update from Isabelle2011 to Isabelle2013; thus no further development of isac;
   468   For considerations on the transition see 
   469   $ISABELLE_ISAC/Knowledge/Build_Thydata/thy, section "updating isac..".
   470 \<close>
   471 subsubsection \<open>Run tests\<close>
   472 text \<open>
   473 $ cd /usr/local/isabisac12/
   474 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
   475 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
   476 \<close>
   477 subsubsection \<open>State of tests\<close>
   478 text \<open>
   479   At least the tests from isac on Isabelle2011 run again.
   480   However, Test_Isac.thy shows erratic behaviour; no errors are obtained when scrolling 
   481   in parallel with evaluation.
   482 
   483   Counting "error in kernel" for Frontend/interface.sml (the tests considered most significant)
   484   yields 69 hits, some of which were already present before Isabelle2002-->2009-2
   485   (i.e. on the old notebook from 2002).
   486 
   487   Now many tests with (*...=== inhibit exn ...*) give a reason or at least the origin:
   488   # === inhibit exn WN1130621 Isabelle2012-->13 !thehier! === ...see Build_Thydata.thy
   489   # === inhibit exn AK110726 === ...reliable work by Alexander Kargl, most likely go back to 2002
   490   # === inhibit exn WN1130701 broken at Isabelle2002 --> 2009-2 === , most likely go back to 2002
   491   Reasons for outcommented tests are also found in Test_Isac.thy near the respective file.sml.
   492 
   493   Some tests have been re-activated (e.g. error patterns, fill patterns).
   494 \<close>
   495 subsubsection \<open>Changesets of begin and end\<close>
   496 text \<open>
   497   Changeset: 52051 (35751d90365e) end of improving tests for isac on Isabelle2012
   498   User: Walther Neuper <neuper@ist.tugraz.at>
   499   Date: 2013-07-11 16:58:31 +0200 (4 weeks)
   500   :
   501   : isac on Isablle2012 
   502   :
   503   Changeset: 48757 (74eb3dfc33cc) updated src from Isabelle2011 to Isabelle2012
   504   User: Walther Neuper <neuper@ist.tugraz.at>
   505   Date: 2012-09-24 18:35:13 +0200 (8 months)
   506   ------------------------------------------------------------------------------
   507   Changeset: 48756 (7443906996a8) merged
   508   User: Walther Neuper <neuper@ist.tugraz.at>
   509   Date: 2012-09-24 18:15:49 +0200 (8 months)
   510 \<close>
   511 
   512 subsection \<open>isac on Isabelle2011\<close>
   513 subsubsection \<open>Summary of development\<close>
   514 text \<open>
   515   isac's mathematics engine has been extended by two developments:
   516   (1) Isabelle's contexts were introduced by Mathias Lehnfeld
   517   (2) Z_Transform was introduced by Jan Rocnik, which revealed
   518     further errors introduced by (1).
   519   (3) "error patterns" were introduced by Gabriella Daroczy
   520   Regressions tests have been added for all of these.
   521 \<close>
   522 subsubsection \<open>Run tests\<close>
   523 text \<open>
   524   $ cd /usr/local/isabisac11/
   525   $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
   526   $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
   527 \<close>
   528 subsubsection \<open>State of tests\<close>
   529 text \<open>
   530   Systematic efforts outcommented less significant tests by (*...=== inhibit exn ...*) 
   531   and sometimes give reasons for failing tests.
   532   (*...=== inhibit exn AK...*) was done by Alexander Kargl; this is reliable
   533   work, some of which couldn't be revised (and renamed) by WN and thus survived some time.
   534 
   535   The most signification tests (in particular Frontend/interface.sml) run,
   536   however, many "error in kernel" are not caught by an exception.
   537   ------------------------------------------------------------------------------
   538   After the changeset below Test_Isac worked with check_unsynchronized_ref ():
   539   ------------------------------------------------------------------------------
   540   Changeset: 42457 (ca691a84b81a) PROVISIONALLY MADE TESTS RUN with Unsynchronized.ref
   541   User: Walther Neuper <neuper@ist.tugraz.at>
   542   Date: 2012-08-06 10:38:11 +0200 (11 months)
   543 
   544 
   545   The list below records TODOs while producing an ISAC kernel for 
   546   gdaroczy and jrocnik, wich could NOT be done before all tests are RUNNING
   547   (so to be resumed with Isabelle2013-1):
   548   ############## WNxxxxxx.TODO can be found in sources ##############
   549   --------------------------------------------------------------------------------
   550   WN111013.TODO: lots of cleanup/removal in test/../Test.thy
   551   --------------------------------------------------------------------------------
   552   WN111013.TODO: remove concept around "fun implicit_take", lots of troubles with 
   553   this special case (see) --- why not nxt = Model_Problem here ? ---
   554   --------------------------------------------------------------------------------
   555   WN111014.TODO calculate_Poly < calculate_Rational < calculate_RootRat, see test/
   556   ... FIRST redesign 
   557   # simplify_* , *_simp_* 
   558   # norm_* 
   559   # calc_* , calculate_*  ... require iteration over all rls ...
   560   ... see --- val rls = calculate_RootRat > calculate_Rational --- CONTINUE !
   561   --------------------------------------------------------------------------------
   562   WN111014.TODO fun prep_rls | !!!use this function in ruleset' := !!!
   563   --------------------------------------------------------------------------------
   564   WN120314 changeset a393bb9f5e9f drops root equations.
   565   see test/Tools/isac/Knowledge/rootrateq.sml 
   566   --------------------------------------------------------------------------------
   567   WN120317.TODO changeset 977788dfed26 dropped rateq:
   568   # test --- repair NO asms from rls RatEq_eliminate --- shows error from 2002
   569   # test --- solve (1/x = 5, x) by me --- and --- x / (x ^ 2 - 6 * x + 9) - ...:    
   570     investigation Check_elementwise stopped due to too much effort finding out,
   571     why Check_elementwise worked in 2002 in spite of the error.
   572   --------------------------------------------------------------------------------
   573   WN120317.TODO postponed test/../ratinal,ratinal2.sml to joint work with dmeindl 
   574   --------------------------------------------------------------------------------
   575   WN120317.TODO found by test --- interSteps for Schalk 299a --- that 
   576     NO test with 'interSteps' is checked properly (with exn on changed behaviour)
   577   --------------------------------------------------------------------------------
   578   WN120317.TODO test --- Matthias Goldgruber 2003 rewrite orders --- has
   579     a newly outcommented test where rewrite_set_ make_polynomial --> NONE
   580   --------------------------------------------------------------------------------
   581   WN120320.TODO check-improve rlsthmsNOTisac:
   582   DONE make test --- old compute rlsthmsNOTisac by eq_thmI'
   583   DONE compare rlsthmsNOTisac in thms-survey-Isa02-Isa09-2.sml .. Isac.thy 
   584   FOUND 120321: Theory.axioms_of doesnt find LENGTH_CONS etc, thus are in Isab
   585   # mark twice thms (in isac + (later) in Isabelle) in Isac.thy
   586   --------------------------------------------------------------------------------
   587   WN120320.TODO rlsthmsNOTisac: replace twice thms ^
   588   --------------------------------------------------------------------------------
   589   WN120320.TODO rlsthmsNOTisac: reconsider design of sym_* thms, see test
   590   --- OLD compute rlsthmsNOTisac by eq_thmID ---: some are in isab, some in isac.
   591   --------------------------------------------------------------------------------
   592   WN120321.TODO rearrange theories:
   593     Knowledge
   594       :
   595       Prog_Expr.thy
   596       ///Input_Descript.thy --> ProgLang
   597       Delete.thy   <--- first_Knowledge_thy (*mv to Prog_Expr.thy*)
   598     ProgLang: restructure Build_Isac.thy such that no xmlsrc.thy, ProgLang.thy
   599           Interpret.thy are generated (simplifies xml structure for theories)
   600       Program.thy
   601       Tools.thy
   602       ListC.thy    <--- first_Proglang_thy
   603   --------------------------------------------------------------------------------
   604   WN120321.TODO reanimate test/../simplify.sml: CAS-command Simplify
   605       EXN "simplify.sml: diff.behav. CAScmd: Simplify (2*a + 3*a)"
   606   broken during work on thy-hierarchy
   607   --------------------------------------------------------------------------------
   608   WN120321.TODO LAST in IsacScripts + in IsacKnowledge, see
   609   test --- the_hier (get_thes ()) (collect_thydata ())---
   610   --------------------------------------------------------------------------------
   611   WN120405a.TODO src/../pbl-met-hierarchy.sml: fun pbl2term--> Isac' instead Isac_
   612   !!add mutual crossreferences to ?fun headline??? where the same has to be done:
   613   !!OR BETTER: use only 2 functions for adding/removing "'" to/from thy!!
   614   --------------------------------------------------------------------------------
   615   WN120411 scanning html representation of newly generated knowledge:
   616   * thy:
   617   ** Theorems: only "Proof of the theorem" (correct!)
   618                and "(c) isac-team (math-autor)"
   619   ** Rulesets: only "Identifier:///"
   620                and "(c) isac-team (math-autor)"
   621   ** IsacKnowledge: link to dependency graph (which needs to be created first)
   622   ** IsacScripts --> ProgramLanguage
   623   *** Tools: Theorems: arity_type_cp, arity_type_nam, ... wegnehmen
   624   
   625   * pbl: OK !?!
   626   * met: OK !?!
   627   * exp: 
   628   ** Z-Transform is missing !!!
   629   ** type-constraints !!!
   630   --------------------------------------------------------------------------------
   631   WN120417: merging xmldata revealed:
   632   ..............NEWLY generated:........................................
   633   <THEOREMDATA>
   634     <GUH> thy_isab_Fun-thm-o_apply </GUH>
   635     <STRINGLIST>
   636       <STRING> Isabelle </STRING>
   637       <STRING> Fun </STRING>
   638       <STRING> Theorems </STRING>
   639       <STRING> o_apply </STRING>
   640     </STRINGLIST>
   641       <MATHML>
   642         <ISA> (?f o ?g) ?x = ?f (?g ?x) </ISA>
   643       </MATHML>  <PROOF>
   644       <EXTREF>
   645         <TEXT> Proof of the theorem </TEXT>
   646         <URL> http://www.ist.tugraz.at/projects/isac/www/kbase/thy/browser_info/HOL/HOL-Real/Isac/Fun.html </URL>
   647       </EXTREF>
   648     </PROOF>
   649     <EXPLANATIONS> </EXPLANATIONS>
   650     <MATHAUTHORS>
   651       <STRING> Isabelle team, TU Munich </STRING>
   652     </MATHAUTHORS>
   653     <COURSEDESIGNS>
   654     </COURSEDESIGNS>
   655   </THEOREMDATA>
   656   ..............OLD FORMAT:.............................................
   657   <THEOREMDATA>
   658     <GUH> thy_isab_Fun-thm-o_apply </GUH>
   659     <STRINGLIST>
   660       <STRING> Isabelle </STRING>
   661       <STRING> Fun </STRING>
   662       <STRING> Theorems </STRING>
   663       <STRING> o_apply </STRING>
   664     </STRINGLIST>
   665     <THEOREM>
   666       <ID> o_apply </ID>
   667       <MATHML>
   668         <ISA> (?f o ?g) ?x = ?f (?g ?x) </ISA>
   669       </MATHML>
   670     </THEOREM>
   671     <PROOF>
   672       <EXTREF>
   673         <TEXT> Proof of the theorem </TEXT>
   674         <URL> http://www.ist.tugraz.at/projects/isac/www/kbase/thy/browser_info/HOL/HOL-Real/Isac/Fun.html </URL>
   675       </EXTREF>
   676     </PROOF>
   677     <EXPLANATIONS> </EXPLANATIONS>
   678     <MATHAUTHORS>
   679       <STRING> Isabelle team, TU Munich </STRING>
   680     </MATHAUTHORS>
   681     <COURSEDESIGNS>
   682     </COURSEDESIGNS>
   683   </THEOREMDATA>
   684   --------------------------------------------------------------------------------
   685 \<close>
   686 subsubsection \<open>Changesets of begin and end\<close>
   687 text \<open>
   688   isac development was done between these changesets:
   689   ------------------------------------------------------------------------------
   690   Changeset: 42519 (1f3b4270363e) meeting dmeindl: added missing files
   691   User: Walther Neuper <neuper@ist.tugraz.at>
   692   Date: 2012-09-24 16:39:30 +0200 (8 months)
   693   :
   694   : isac on Isablle2011
   695   :
   696   Changeset:41897 (355be7f60389) merged isabisac with Isabelle2011
   697   Branch: decompose-isar 
   698   User: Walther Neuper <neuper@ist.tugraz.at>
   699   Date: 2011-02-25 13:04:56 +0100 (2011-02-25)
   700   ------------------------------------------------------------------------------
   701 \<close>
   702 
   703 subsection \<open>isac on Isabelle2009-2\<close>
   704 subsubsection \<open>Summary of development\<close>
   705 text \<open>
   706   In 2009 the update of isac from Isabelle2002 started with switching from CVS to hg.
   707   The update was painful (bridging 7 years of Isabelle development) and cut short 
   708   due to the start of introducing Isabelle's contexts (Mathias Lehnfeld) and
   709   going on to Isabelle2011 although most of the tests did not run.
   710 \<close>
   711 subsubsection \<open>Run tests\<close>
   712 text \<open>
   713   WN131021 this is broken by installation of Isabelle2011/12/13,
   714   because all these write their binaries to ~/.isabelle/heaps/..
   715 
   716   $ cd /usr/local/isabisac09-2/
   717   $ ./bin/isabelle emacs -l HOL src/Tools/isac/Build_Isac.thy
   718   $ ./bin/isabelle emacs -l Isac src/Tools/isac/Test_Isac.thy
   719   NOT THE RIGHT VERSION.....    test/Tools/isac/Test_Isac.thy !!!
   720 \<close>
   721 subsubsection \<open>State of tests\<close>
   722 text \<open>
   723   Most tests are broken by the update from Isabelle2002 to Isabelle2009-2.
   724 \<close>
   725 subsubsection \<open>Changesets of begin and end\<close>
   726 text \<open>
   727   isac development was done between these changesets:
   728   ------------------------------------------------------------------------------
   729   Changeset: 38115 (940a5feea094) Little improvements of isac-plugin
   730   Branch: decompose-isar 
   731   User: Marco Steger <m.steger@student.tugraz.at>
   732   Date: 2011-02-06 18:30:28 +0100 (2011-02-06)
   733   :
   734   : isac on Isablle2009-2
   735   :
   736   Changeset: 37870 (5100a9c3abf8) created branch isac-from-Isabelle2009-2
   737   Branch: isac-from-Isabelle2009-2 
   738   User: Walther Neuper <neuper@ist.tugraz.at>
   739   Date: 2010-07-21 09:59:35 +0200 (2010-07-21)
   740   ------------------------------------------------------------------------------
   741 \<close>
   742 
   743 subsection \<open>isac on Isabelle2002\<close>
   744 subsubsection \<open>Summary of development\<close>
   745 text \<open>
   746   From 1999 to 2010 all the basic functionality (except "ctxt" and "error pattern")
   747   of isac's mathematics engine has been implemented.
   748 \<close>
   749 subsubsection \<open>Run tests\<close>
   750 subsubsection \<open>State of tests\<close>
   751 text \<open>
   752   All tests work on an old notebook (the right PolyML coudn't be upgraded to more
   753   recent Linux versions)
   754 \<close>
   755 subsubsection \<open>Changesets of begin and end\<close>
   756 text \<open>
   757   Up to the above Mercurial changeset 5100a9c3abf8 isac used CVS;
   758   see https://intra.ist.tugraz.at/hg/isac containing a conversion to Mercurial.
   759 \<close>
   760 
   761 end
   762 (*========== inhibit exn 130719 Isabelle2013 ===================================
   763 ============ inhibit exn 130719 Isabelle2013 =================================*)
   764 
   765 (*-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.
   766   -.-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.*)
   767