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