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