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