test/Tools/isac/Test_Isac_Short.thy
author wneuper <Walther.Neuper@jku.at>
Thu, 24 Nov 2022 18:07:17 +0100
changeset 60603 eec3b6fd6c7a
parent 60592 777d05447375
child 60608 5dabcc1c9235
permissions -rw-r--r--
follow-up Makarius #3: reorganise parse for proper error-reporting in problem/method

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