test/Tools/isac/Test_Isac_Short.thy
author wneuper <Walther.Neuper@jku.at>
Fri, 01 Dec 2023 06:08:22 +0100
changeset 60771 1b072aab8f4e
parent 60769 0df0759fed26
child 60781 344eee0d80f7
permissions -rw-r--r--
PIDE turn 13: rename ALL(?) code already handling Position.T from *_TEST to *_POS

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