test/Tools/isac/Test_Isac.thy
author Walther Neuper <neuper@ist.tugraz.at>
Mon, 02 Sep 2013 16:16:08 +0200
changeset 52101 c3f399ce32af
parent 52090 9642feb9e96b
child 52102 cd5494eb08fd
permissions -rwxr-xr-x
Test_Isac works again, almost ..

4 files raise errors:
# Interpret/solve.sml: "solve.sml: interSteps on norm_Rational 2"
# Interpret/inform.sml: "inform.sml: [rational,simplification] 2"
# Knowledge/partial_fractions.sml: "autoCalculate for met_partial_fraction changed: final result"
# Knowledge/eqsystem.sml: "eqsystem.sml: exp 7.70 normalize 4x4 by rewrite changed"

The chunk of changes is due to the fact, that Isac's code still is unstable.
The changes are accumulated since e8f46493af82.
     1 (* Title:  All tests on isac (some outcommented since Isabelle2002-->2009-2)
     2    Author: Walther Neuper 101001
     3    (c) copyright due to lincense 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 $ cd /usr/local/isabisac/
    12 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy &
    13 *)
    14 
    15 (* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! *)
    16 (* !!!!! wait a minute until Isac and the theories below are loaded !!!!! *)
    17 (* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! *)
    18 
    19 theory Test_Isac imports Isac
    20   "ADDTESTS/Ctxt"
    21   "ADDTESTS/test-depend/Build_Test"
    22   "ADDTESTS/All_Ctxt"
    23   "ADDTESTS/course/phst11/T1_Basics"
    24   "ADDTESTS/course/phst11/T2_Rewriting"
    25   "ADDTESTS/course/phst11/T3_MathEngine"
    26   "ADDTESTS/file-depend/BuildC_Test"
    27 (*"ADDTESTS/course/SignalProcess/Build_Inverse_Z_Transform"*)
    28   "~~/test/Pure/Isar/Test_Parsers"
    29 (*"~~/test/Pure/Isar/Pure/Isar/Struct_Deriv" lost at update 2009-2-->2011*)
    30   "~~/test/Pure/Isar/Test_Parse_Term"
    31   "~~/test/HOL/Library/Test_Polynomial"
    32 
    33   "~~/src/Tools/isac/Knowledge/GCD_Poly"    (*not imported by Isac.thy*)
    34   "~~/src/Tools/isac/Knowledge/GCD_Poly_FP" (*not imported by Isac.thy*)
    35 
    36 begin
    37 section {* test ML Code of isac *}
    38   ML {*"%%%%%%%%%%%%%%%%% start ProgLang.thy %%%%%%%%%%%%%%%%%%%";*}
    39   ML_file          "library.sml"
    40   ML_file          "calcelems.sml"
    41   ML_file "ProgLang/termC.sml"
    42   ML_file "ProgLang/calculate.sml"
    43   ML_file "ProgLang/rewrite.sml"
    44 (*ML_file "ProgLang/listC.sml"            2002*)
    45   ML_file "ProgLang/scrtools.sml"
    46   ML_file "ProgLang/tools.sml"
    47   ML {*"%%%%%%%%%%%%%%%%% end ProgLang.thy %%%%%%%%%%%%%%%%%%%%%";*}
    48   ML {*"%%%%%%%%%%%%%%%%% start Minisubpbl %%%%%%%%%%%%%%%%%%%%%";*}
    49   ML_file "Minisubpbl/000-comments.sml"
    50   ML_file "Minisubpbl/100-init-rootpbl.sml"
    51   ML_file "Minisubpbl/150-add-given.sml"
    52   ML_file "Minisubpbl/200-start-method.sml"
    53   ML_file "Minisubpbl/300-init-subpbl.sml"
    54   ML_file "Minisubpbl/400-start-meth-subpbl.sml"
    55   ML_file "Minisubpbl/490-nxt-Check_Postcond.sml"
    56   ML_file "Minisubpbl/500-met-sub-to-root.sml"
    57   ML_file "Minisubpbl/530-error-Check_Elementwise.sml"
    58   ML_file "Minisubpbl/600-postcond.sml"
    59   ML {*"%%%%%%%%%%%%%%%%% end Minisubpbl.thy %%%%%%%%%%%%%%%%%%%%%%%";*}
    60   ML {*"%%%%%%%%%%%%%%%%% start Interpret.thy %%%%%%%%%%%%%%%%%%";*}
    61   ML_file "Interpret/mstools.sml"
    62   ML_file "Interpret/ctree.sml"         (*!...!see(25)*)
    63   ML_file "Interpret/ptyps.sml"
    64   ML {* (*check_unsynchronized_ref (); ==== trick on error: CUT AND PASTE THIS LINE =========*) *}
    65 (*TRICK DOESN'T WORK: get_pbt not found: ["IsacKnowledge","Diff","Theorems","diff_sin_chain"]*)
    66   ML_file "Interpret/generate.sml"
    67 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
    68   ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
    69   ML_file "Interpret/calchead.sml"
    70   ML_file "Interpret/appl.sml"          (*complete "WEGEN INTERMED TESTCODE"                          *)
    71   ML_file "Interpret/rewtools.sml"      (*complete, isac's Context broken at 2009-2 --> 2011, thehier!*)
    72   ML_file "Interpret/script.sml"
    73   ML_file "Interpret/solve.sml"
    74   ML_file "Interpret/inform.sml"
    75 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
    76   ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
    77   ML_file "Interpret/mathengine.sml"    (*!part.*)
    78   ML {*"%%%%%%%%%%%%%%%%% end Interpret.thy %%%%%%%%%%%%%%%%%%%%";*}
    79   ML {*"%%%%%%%%%%%%%%%%% start xmlsrc.thy %%%%%%%%%%%%%%%%%%%%%";*}
    80   ML_file "xmlsrc/mathml.sml"           (*part.*)
    81   ML_file "xmlsrc/datatypes.sml"        (*TODO/part.*)
    82   ML_file "xmlsrc/pbl-met-hierarchy.sml"(*TODO after 2009-2/part.*)
    83 (*ML_file "xmlsrc/thy-hierarchy.sml"      TODO after 2009-2/part | Isabelle2012-->13 !thehier! *)
    84 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
    85 val it = "----------- ### thes2file ... Exception- Match raised -----------": string
    86 :
    87 val it = "~~~~~ fun thes2file, args:": string
    88 val p = "../../tmp/": path
    89 val it = (): unit
    90  exception Bind raised (line 359 of "~~/test/Tools/isac/xmlsrc/thy-hierarchy.sml")
    91                                                  ...CONCERNED WITH thehier
    92 *)
    93   ML_file "xmlsrc/interface-xml.sml"     (*TODO after 2009-2*)
    94   ML {*"%%%%%%%%%%%%%%%%% end xmlsrc.thy %%%%%%%%%%%%%%%%%%%%%%%";*}
    95   ML {*"%%%%%%%%%%%%%%%%% start Frontend.thy %%%%%%%%%%%%%%%%%%%";*}
    96   ML_file "Frontend/messages.sml"
    97   ML_file "Frontend/states.sml"
    98   ML_file "Frontend/interface.sml"
    99 (*WITHOUT inhibit exn WN1130621 Isabelle2012-->13 !thehier! THIS ERROR OCCURS:
   100   ... SAME ERROR HERE ON ISABELLE2012 AS IN ISAC ON ISABELLE2011*)
   101   ML_file          "print_exn_G.sml"
   102   ML {*"%%%%%%%%%%%%%%%%% end Frontend.thy %%%%%%%%%%%%%%%%%%%%%";*}
   103   ML {*"%%%%%%%%%%%%%%%%% start Knowledge %%%%%%%%%%%%%%%%%%%%%%";*}
   104   ML_file "Knowledge/delete.sml"
   105   ML_file "Knowledge/descript.sml"
   106   ML_file "Knowledge/atools.sml"
   107   ML_file "Knowledge/simplify.sml"
   108   ML_file "Knowledge/poly.sml"
   109   ML_file "Knowledge/gcd_poly_ml.sml"
   110   ML_file "Knowledge/gcd_poly_winkler.sml" (*must be after gcd_poly_ml.sml: redefines functions*)
   111   ML_file "Knowledge/rational.sml"
   112   ML_file "Knowledge/equation.sml"
   113   ML_file "Knowledge/root.sml"
   114   ML_file "Knowledge/lineq.sml"
   115 (*ML_file "Knowledge/rooteq.sml"    some complicated equations not recovered from 2002 *)
   116   ML_file "Knowledge/rateq.sml"   (*some complicated equations not recovered from 2002 *)
   117   ML_file "Knowledge/rootrat.sml"
   118   ML_file "Knowledge/rootrateq.sml"(*ome complicated equations not recovered from 2002 *)
   119   ML_file "Knowledge/partial_fractions.sml"
   120   ML_file "Knowledge/polyeq.sml" (*-----------------works if cut into parts !!!!!!!!!!!*)
   121 (*ML_file "Knowledge/rlang.sml"     much to clean up, not urgent due to similar tests  *)
   122   ML_file "Knowledge/calculus.sml"
   123   ML_file "Knowledge/trig.sml"
   124 (*ML_file "Knowledge/logexp.sml"    not included as stuff for presentation of authoring*) 
   125   ML_file "Knowledge/diff.sml"
   126   ML_file "Knowledge/integrate.sml"
   127   ML_file "Knowledge/eqsystem.sml"
   128   ML_file "Knowledge/test.sml"
   129   ML_file "Knowledge/polyminus.sml"
   130   ML_file "Knowledge/vect.sml"
   131   ML_file "Knowledge/diffapp.sml"        (* postponed to dev. specification | TP-prog. *)
   132   ML_file "Knowledge/biegelinie.sml"
   133   ML_file "Knowledge/algein.sml"
   134   ML_file "Knowledge/diophanteq.sml"
   135   ML_file "Knowledge/Inverse_Z_Transform/inverse_z_transform.sml"
   136   ML_file "Knowledge/isac.sml"
   137   ML_file "Knowledge/build_thydata.sml"
   138   ML {*"%%%%%%%%%%%%%%%%% end Knowledge %%%%%%%%%%%%%%%%%%%%%%%%";*}
   139   ML {*"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";*}
   140   ML {*"%%%%%%%%%%%%%%%%% all tests successful %%%%%%%%%%%%%%%%%";*}
   141   ML {*"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%";*}
   142 
   143 section {* history of tests *}
   144 text {*
   145   Systematic regression tests have been introduced to isac development in 2003.
   146   Sanity of the regression test suffered from updates following Isabelle development,
   147   which mostly exceeded the resources available in isac's development.
   148 
   149   The survey below shall support to efficiently use the tests for isac 
   150   on different Isabelle versions. Conclusion in most cases will be: 
   151 
   152   !!! Use most recent tests or go back to the old notebook
   153       with isac on Isabelle2002. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
   154 *}
   155 
   156 subsection {* isac on Isabelle2013 *}
   157 subsubsection {* Summary of development *}
   158 text {*
   159 *}
   160 subsubsection {* Run tests *}
   161 text {*
   162 *}
   163 subsubsection {* State of tests *}
   164 text {*
   165 *}
   166 subsubsection {* Changesets of begin and end *}
   167 text {*
   168   TODO
   169   :
   170   : isac on Isablle2013 
   171   :
   172   Changeset: 52061 (4ecea2fcdc2c) --- Build_Isac.thy runs on Isabelle2013
   173   User: Walther Neuper <neuper@ist.tugraz.at>
   174   Date: 2013-07-15 08:28:50 +0200 (4 weeks)
   175 *}
   176 
   177 subsection {* isac on Isabelle2012 *}
   178 subsubsection {* Summary of development *}
   179 text {*
   180   isac on Isabelle2012 is considered just a transitional stage
   181   within the update from Isabelle2011 to Isabelle2013; thus no further development of isac;
   182   For considerations on the transition see 
   183   ~~/src/Tools/isac/Knowledge/Build_Thydata/thy, section "updating isac..".
   184 *}
   185 subsubsection {* Run tests *}
   186 text {*
   187 $ cd /usr/local/isabisac12/
   188 $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
   189 $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
   190 *}
   191 subsubsection {* State of tests *}
   192 text {*
   193   At least the tests from isac on Isabelle2011 run again.
   194   However, Test_Isac.thy shows erratic behaviour; no errors are obtained when scrolling 
   195   in parallel with evaluation.
   196 
   197   Counting "error in kernel" for Frontend/interface.sml (the tests considered most significant)
   198   yields 69 hits, some of which were already present before Isabelle2002-->2009-2
   199   (i.e. on the old notebook from 2002).
   200 
   201   Now many tests with (*...=== inhibit exn ...*) give a reason or at least the origin:
   202   # === inhibit exn WN1130621 Isabelle2012-->13 !thehier! === ...see Build_Thydata.thy
   203   # === inhibit exn AK110726 === ...reliable work by Alexander Kargl, most likely go back to 2002
   204   # === inhibit exn WN1130701 broken at Isabelle2002 --> 2009-2 === , most likely go back to 2002
   205   Reasons for outcommented tests are also found in Test_Isac.thy near the respective file.sml.
   206 
   207   Some tests have been re-activated (e.g. error patterns, fill patterns).
   208 *}
   209 subsubsection {* Changesets of begin and end *}
   210 text {*  
   211   Changeset: 52051 (35751d90365e) end of improving tests for isac on Isabelle2012
   212   User: Walther Neuper <neuper@ist.tugraz.at>
   213   Date: 2013-07-11 16:58:31 +0200 (4 weeks)
   214   :
   215   : isac on Isablle2012 
   216   :
   217   Changeset: 48757 (74eb3dfc33cc) updated src from Isabelle2011 to Isabelle2012
   218   User: Walther Neuper <neuper@ist.tugraz.at>
   219   Date: 2012-09-24 18:35:13 +0200 (8 months)
   220   ------------------------------------------------------------------------------
   221   Changeset: 48756 (7443906996a8) merged
   222   User: Walther Neuper <neuper@ist.tugraz.at>
   223   Date: 2012-09-24 18:15:49 +0200 (8 months)
   224 *}
   225 
   226 subsection {* isac on Isabelle2011 *}
   227 subsubsection {* Summary of development *}
   228 text {*
   229   isac's mathematics engine has been extended by two developments:
   230   (1) Isabelle's contexts were introduced by Mathias Lehnfeld
   231   (2) "error patterns" were introduced by Gabriella Daroczy
   232   Regressions tests have been added for both.
   233 *}
   234 subsubsection {* Run tests *}
   235 text {*
   236   $ cd /usr/local/isabisac11/
   237   $ ./bin/isabelle jedit -l HOL src/Tools/isac/Build_Isac.thy
   238   $ ./bin/isabelle jedit -l Isac test/Tools/isac/Test_Isac.thy
   239 *}
   240 subsubsection {* State of tests *}
   241 text {* 
   242   Systematic efforts outcommented less significant tests by (*...=== inhibit exn ...*) 
   243   and sometimes give reasons for failing tests.
   244   (*...=== inhibit exn AK...*) was done by Alexander Kargl; this is reliable
   245   work, some of which couldn't be revised (and renamed) by WN and thus survived some time.
   246 
   247   Tests with functions decomposed for single-stepping are marked with
   248   "~~~~~ fun , args:"; val 
   249 
   250   The most signification tests (in particular Frontend/interface.sml) run,
   251   however, many "error in kernel" are not caught by an exception.
   252   ------------------------------------------------------------------------------
   253   After the changeset below Test_Isac worked with check_unsynchronized_ref ():
   254   ------------------------------------------------------------------------------
   255   Changeset: 42457 (ca691a84b81a) PROVISIONALLY MADE TESTS RUN with Unsynchronized.ref
   256   User: Walther Neuper <neuper@ist.tugraz.at>
   257   Date: 2012-08-06 10:38:11 +0200 (11 months)
   258 *}
   259 subsubsection {* Changesets of begin and end *}
   260 text {*
   261   isac development was done between these changesets:
   262   ------------------------------------------------------------------------------
   263   Changeset: 42519 (1f3b4270363e) meeting dmeindl: added missing files
   264   User: Walther Neuper <neuper@ist.tugraz.at>
   265   Date: 2012-09-24 16:39:30 +0200 (8 months)
   266   :
   267   : isac on Isablle2011
   268   :
   269   Changeset:41897 (355be7f60389) merged isabisac with Isabelle2011
   270   Branch: decompose-isar 
   271   User: Walther Neuper <neuper@ist.tugraz.at>
   272   Date: 2011-02-25 13:04:56 +0100 (2011-02-25)
   273   ------------------------------------------------------------------------------
   274 *}
   275 
   276 subsection {* isac on Isabelle2009-2 *}
   277 subsubsection {* Summary of development *}
   278 text {*
   279   In 2009 the update of isac from Isabelle2002 started with switching from CVS to hg.
   280   The update was painful (bridging 7 years of Isabelle development) and cut short 
   281   due to the start of introducing Isabelle's contexts (Mathias Lehnfeld) and
   282   going on to Isabelle2011 although most of the tests did not run.
   283 *}
   284 subsubsection {* Run tests *}
   285 text {*
   286   $ cd /usr/local/isabisac09-2/
   287   $ ./bin/isabelle emacs -l HOL src/Tools/isac/Build_Isac.thy
   288   $ ./bin/isabelle emacs -l Isac src/Tools/isac/Test_Isac.thy
   289   NOT THE RIGHT VERSION.....    test/Tools/isac/Test_Isac.thy !!!
   290 *}
   291 subsubsection {* State of tests *}
   292 text {* 
   293   Most tests are broken by the update from Isabelle2002 to Isabelle2009-2.
   294   If really necessary, go back to the old notebook with Isabelle2002.
   295 *}
   296 subsubsection {* Changesets of begin and end *}
   297 text {*
   298   isac development was done between these changesets:
   299   ------------------------------------------------------------------------------
   300   Changeset: 38115 (940a5feea094) Little improvements of isac-plugin
   301   Branch: decompose-isar 
   302   User: Marco Steger <m.steger@student.tugraz.at>
   303   Date: 2011-02-06 18:30:28 +0100 (2011-02-06)
   304   :
   305   : isac on Isablle2009-2
   306   :
   307   Changeset: 37870 (5100a9c3abf8) created branch isac-from-Isabelle2009-2
   308   Branch: isac-from-Isabelle2009-2 
   309   User: Walther Neuper <neuper@ist.tugraz.at>
   310   Date: 2010-07-21 09:59:35 +0200 (2010-07-21)
   311   ------------------------------------------------------------------------------
   312 *}
   313 
   314 subsection {* isac on Isabelle2002 *}
   315 subsubsection {* Summary of development *}
   316 text {*
   317   From 1999 to 2010 all the basic functionality (except "ctxt" and "error pattern")
   318   of isac's mathematics engine has been implemented.
   319 *}
   320 subsubsection {* Run tests *}
   321 subsubsection {* State of tests *}
   322 text {* 
   323   All tests work on an old notebook (the right PolyML coudn't be upgraded to more
   324   recent Linux versions)
   325 *}
   326 subsubsection {* Changesets of begin and end *}
   327 text {*
   328   Up to the above Mercurial changeset 5100a9c3abf8 isac used CVS;
   329   see https://intra.ist.tugraz.at/hg/isac containing a conversion to Mercurial.
   330 *}
   331 
   332 end
   333 (*========== inhibit exn 130719 Isabelle2013 ===================================
   334 ============ inhibit exn 130719 Isabelle2013 =================================*)
   335 
   336 (*-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.
   337   -.-.-.-.-.-.-isolate response.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.*)
   338