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