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