src/Tools/isac/Build_Isac.thy
author Walther Neuper <walther.neuper@jku.at>
Mon, 11 May 2020 12:25:52 +0200
changeset 59963 e3cf90168a49
parent 59953 933211a252f2
child 59997 46fe5a8c3911
permissions -rw-r--r--
introduce Pre_Conds.T
walther@59632
     1
(*  Title:  build the Isac-Kernel: MathEngine & Knowledge
neuper@38057
     2
    Author: Walther Neuper, TU Graz, 100808
neuper@38051
     3
   (c) due to copyright terms
neuper@38051
     4
neuper@52062
     5
For creating a heap image of isac see ~~/ROOT.
walther@59632
     6
For debugging see text at begin below, e.g. theory dependencies:
walther@59632
     7
  ~$ evince file:///home/wneuper/.isabelle/isabisac/browser_info/Unsorted/Isac/session_graph.pdf &
neuper@52062
     8
wneuper@59586
     9
ATTENTION: no errors in this theory do not mean that there are no errors in Isac ..
walther@59866
    10
.. open theories collecting files from folders: BaseDefinitions.thy, ProgLang.thy etc.
walther@59632
    11
Errors are rigorously detected by isabelle build.
neuper@37906
    12
*)
neuper@37906
    13
wneuper@59347
    14
theory Build_Isac 
wneuper@59206
    15
imports
walther@59887
    16
(*  theory Know_Store imports Complex_Main
walther@59632
    17
      ML_file libraryC.sml
walther@59865
    18
      ML_file theoryC.sml
walther@59963
    19
      ML_file unparseC.sml
walther@59850
    20
      ML_file "rule-def.sml"
walther@59963
    21
      ML_file "thmC-def.sml"
walther@59919
    22
      ML_file "eval-def.sml"
walther@59858
    23
      ML_file "rewrite-order.sml"
walther@59632
    24
      ML_file rule.sml
walther@59963
    25
      ML_file "error-pattern-def.sml"
walther@59852
    26
      ML_file "rule-set.sml"
walther@59963
    27
      
walther@59963
    28
      ML_file "store.sml"
walther@59963
    29
      ML_file "check-unique.sml"
walther@59963
    30
      ML_file "specification.sml"
walther@59963
    31
      ML_file "model-pattern.sml"
walther@59963
    32
      ML_file "problem-def.sml"
walther@59963
    33
      ML_file "method-def.sml"
walther@59963
    34
      ML_file "cas-def.sml"
walther@59963
    35
      ML_file "thy-write.sml"
walther@59887
    36
  theory BaseDefinitions imports Know_Store
walther@59632
    37
    ML_file termC.sml
walther@59963
    38
    ML_file substitution.sml
walther@59632
    39
    ML_file contextC.sml
walther@59687
    40
    ML_file environment.sml
walther@59866
    41
*)        "BaseDefinitions/BaseDefinitions"
wneuper@59586
    42
walther@59866
    43
(*    theory Calculate imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59902
    44
        ML_file evaluate.sml
walther@59773
    45
walther@59866
    46
      theory ListC imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59632
    47
    theory Prog_Expr imports Calculate ListC
walther@59866
    48
      theory Program imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59866
    49
      theory Prog_Tac imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59866
    50
      theory Tactical imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59632
    51
    theory Auto_Prog imports Program Prog_Tac Tactical begin
walther@59632
    52
  theory ProgLang imports Prog_Expr Auto_Prog
neuper@52062
    53
*)        "ProgLang/ProgLang"
wneuper@59600
    54
(*
walther@59674
    55
  theory MathEngBasic imports
walther@59674
    56
    "~~/src/Tools/isac/ProgLang/ProgLang" "~~/src/Tools/isac/Specify/Input_Descript"
walther@59875
    57
    ML_file thmC.sml
walther@59963
    58
    ML_file problem.sml
walther@59963
    59
    ML_file method.sml
walther@59963
    60
    ML_file "cas-command.sml"
walther@59963
    61
  
walther@59865
    62
    ML_file rewrite.sml
walther@59963
    63
  
walther@59963
    64
    ML_file "model-def.sml"
walther@59963
    65
    ML_file "istate-def.sml"
walther@59674
    66
    ML_file "calc-tree-elem.sml"
walther@59963
    67
    ML_file "pre-conds-def.sml"
walther@59963
    68
  
walther@59632
    69
    ML_file tactic.sml
walther@59963
    70
    ML_file applicable.sml
walther@59963
    71
  
walther@59777
    72
    ML_file position.sml
walther@59674
    73
    ML_file "ctree-basic.sml"
walther@59674
    74
    ML_file "ctree-access.sml"
walther@59674
    75
    ML_file "ctree-navi.sml"
walther@59674
    76
    ML_file ctree.sml
walther@59963
    77
  
walther@59963
    78
    ML_file "state-steps.sml"
walther@59777
    79
    ML_file calculation.sml
walther@59674
    80
*)        "MathEngBasic/MathEngBasic"
walther@59674
    81
(*
walther@59866
    82
    theory Input_Descript imports "~~/src/Tools/isac/BaseDefinitions/BaseDefinitions"
walther@59674
    83
  theory Specify imports "~~/src/Tools/isac/ProgLang/ProgLang" Input_Descript
walther@59963
    84
    ML_file formalise.sml
walther@59963
    85
    ML_file "o-model.sml"
walther@59963
    86
    ML_file "i-model.sml"
walther@59963
    87
    ML_file "p-model.sml"
walther@59963
    88
    ML_file model.sml
walther@59963
    89
    ML_file "pre-conditions.sml"
walther@59963
    90
    ML_file refine.sml
walther@59963
    91
    ML_file "mstools.sml" (*..TODO review*)
walther@59963
    92
    ML_file ptyps.sml     (*..TODO review*)
walther@59963
    93
    ML_file "test-out.sml"
walther@59963
    94
    ML_file "specify-step.sml"
walther@59963
    95
    ML_file calchead.sml  (*..TODO review*)
walther@59963
    96
    ML_file "input-calchead.sml"
walther@59777
    97
    ML_file "step-specify.sml"
walther@59777
    98
    ML_file specify.sml
wneuper@59595
    99
*)        "Specify/Specify"
wneuper@59600
   100
(*
walther@59632
   101
  theory Interpret imports "~~/src/Tools/isac/Specify/Specify"
walther@59777
   102
    ML_file istate.sml
walther@59963
   103
    ML_file "sub-problem.sml"
walther@59963
   104
    ML_file "thy-read.sml"
walther@59963
   105
    ML_file "solve-step.sml"
walther@59963
   106
    ML_file "error-pattern.sml"
walther@59963
   107
    ML_file derive.sml
walther@59794
   108
    ML_file "li-tool.sml"
walther@59632
   109
    ML_file "lucas-interpreter.sml"
walther@59794
   110
    ML_file "step-solve.sml"
wneuper@59600
   111
*)        "Interpret/Interpret"
wneuper@59600
   112
(*
walther@59632
   113
  theory MathEngine imports "~~/src/Tools/isac/Interpret/Interpret"
walther@59833
   114
    ML_file "fetch-tactics.sml"
walther@59632
   115
    ML_file solve.sml
walther@59794
   116
    ML_file step.sml
walther@59833
   117
    ML_file "detail-step.sml"
walther@59634
   118
    ML_file "mathengine-stateless.sml"
walther@59632
   119
    ML_file messages.sml
walther@59632
   120
    ML_file states.sml
wneuper@59600
   121
*)        "MathEngine/MathEngine"
wneuper@59600
   122
(*
walther@59814
   123
  theory Test_Code imports "~~/src/Tools/isac/MathEngine/MathEngine"
walther@59814
   124
    ML_file "test-code.sml"
walther@59814
   125
*)        "Test_Code/Test_Code"
walther@59814
   126
(*
walther@59632
   127
  theory BridgeLibisabelle imports "~~/src/Tools/isac/MathEngine/MathEngine"
walther@59963
   128
    ML_file "thy-present.sml"
walther@59963
   129
    ML_file mathml.sml   
walther@59632
   130
    ML_file datatypes.sml
walther@59632
   131
    ML_file "pbl-met-hierarchy.sml"
walther@59632
   132
    ML_file "thy-hierarchy.sml" 
walther@59632
   133
    ML_file "interface-xml.sml"
walther@59632
   134
    ML_file interface.sml
walther@59614
   135
*)        "BridgeLibisabelle/BridgeLibisabelle"
wneuper@59147
   136
walther@59612
   137
          "Knowledge/Build_Thydata" (*imports Isac.thy etc*)
wneuper@59469
   138
wneuper@59601
   139
(*//-----------------------------------------------------------------------------------------\\*)
wneuper@59601
   140
(*\\-----------------------------------------------------------------------------------------//*)
neuper@48763
   141
begin
neuper@48760
   142
wneuper@59472
   143
text \<open>
neuper@55276
   144
  show theory dependencies using the graph browser, 
neuper@55276
   145
  open "browser_info/HOL/Isac/session.graph"
neuper@55276
   146
  and proceed from the ancestors towards the siblings.
wneuper@59472
   147
\<close>
neuper@55276
   148
wneuper@59472
   149
section \<open>check presence of definitions from directories\<close>
neuper@48763
   150
wneuper@59263
   151
(*declare [[ML_print_depth = 999]]*)
wneuper@59472
   152
ML \<open>
wneuper@59472
   153
\<close> ML \<open>
wneuper@59587
   154
\<close> ML \<open>
wneuper@59472
   155
\<close>
walther@59902
   156
ML \<open>Eval.adhoc_thm; (*from "ProgLang/evaluate.sml" *)\<close>
wneuper@59472
   157
ML \<open>Rewrite.rewrite_; (*from "ProgLang/rewrite.sml" *)\<close>
walther@59953
   158
ML \<open>Input_Descript.for_real_list; (*from "Input_Descript.thy" *)\<close>
walther@59814
   159
ML \<open>Test_Code.me;\<close>
walther@59613
   160
text \<open>contextthyOK2xml; (*"xmlsrc/interface-xml.sml"*)\<close>
walther@59801
   161
ML \<open>prog_expr\<close>
wneuper@59562
   162
                                                         
walther@59603
   163
ML \<open>Prog_Expr.eval_occurs_in\<close>
walther@59603
   164
ML \<open>@{thm last_thmI}\<close>
wneuper@59472
   165
ML \<open>@{thm Querkraft_Belastung}\<close>
neuper@41905
   166
walther@59904
   167
ML \<open>Check_Unique.on := false;\<close>
wneuper@59472
   168
ML \<open>writeln "**** isac kernel = math-engine + Knowledge complete ******"\<close>
wneuper@59592
   169
ML \<open>@{theory "Isac_Knowledge"}\<close>
wneuper@59472
   170
ML \<open>(*get_the ["IsacKnowledge", "Diff", "Theorems", "diff_sin_chain"]
wneuper@59472
   171
  ERROR: app_py: not found: ["IsacKnowledge","Diff","Theorems","diff_sin_chain"]*)\<close>
neuper@42412
   172
wneuper@59472
   173
section \<open>State of approaching Isabelle by Isac\<close>
wneuper@59472
   174
text \<open>
neuper@55431
   175
  Mathias Lehnfeld gives the following list in his thesis in section 
neuper@55431
   176
  4.2.3 Relation to Ongoing Isabelle Development.
wneuper@59472
   177
\<close>
wneuper@59472
   178
subsection \<open>(0) Survey on remaining Unsynchronized.ref\<close>
wneuper@59472
   179
text \<open>
walther@59887
   180
  REPLACE BY Know_Store... (has been overlooked)
neuper@55433
   181
    calcelems.sml:val rew_ord' = Unsynchronized.ref ...
neuper@55433
   182
  KEEP FOR TRACING
walther@59901
   183
    rewrite.sml:val Rewrite.trace_on = Unsynchronized.ref false;
walther@59901
   184
    rewrite.sml:val depth = Unsynchronized.ref 99999;
walther@59901
   185
    rewrite.sml:val lim_rewrite = Unsynchronized.ref 99999;
walther@59901
   186
    rewrite.sml:val lim_deriv = Unsynchronized.ref 100;
walther@59901
   187
    Interpret/rewtools.sml:val LItool.trace = Unsynchronized.ref false;
neuper@55433
   188
  KEEP FOR EASIER DEVELOPMENT
neuper@55433
   189
    calcelems.sml:val check_guhs_unique = Unsynchronized.ref true;
neuper@55433
   190
  KEEP FOR DEMOS
neuper@55433
   191
    Knowledge/GCD_Poly_ML.thy:  val trace_div = Unsynchronized.ref true;
neuper@55433
   192
    Knowledge/GCD_Poly_ML.thy:  val trace_div_invariant = Unsynchronized.ref false;
neuper@55433
   193
    Knowledge/GCD_Poly_ML.thy:  val trace_Euclid = Unsynchronized.ref true;
wneuper@59472
   194
\<close>
wneuper@59472
   195
subsection \<open>(1) Exploit parallelism for concurrent session management\<close>
wneuper@59472
   196
subsection \<open>(2) Make Isac’s programming language usable\<close>
wneuper@59472
   197
subsection \<open>(3) Adopt Isabelle’s numeral computation for Isac\<close>
wneuper@59472
   198
text \<open>
neuper@55431
   199
  In 2002 isac already strived for floating point numbers. Since that time
neuper@55431
   200
  isac represents numerals as "Free", see below (*1*). These experiments are
neuper@55431
   201
  unsatisfactory with respect to logical soundness.
neuper@55431
   202
  Since Isabelle now has started to care about floating point numbers, it is high 
neuper@55431
   203
  time to adopt these together with the other numerals. Isabelle2012/13's numerals
neuper@55431
   204
  are different from Isabelle2011, see "test/Tools/isac/ProgLang/termC.sml".
neuper@55431
   205
  
neuper@55431
   206
  The transition from "Free" to standard numerals is a task to be scheduled for 
neuper@55431
   207
  several weeks. The urgency of this task follows from the experience, 
neuper@55431
   208
  that (1.2) for "thehier" is very hard, because "num_str" seems to destroy 
neuper@55431
   209
  some of the long identifiers of theorems which would tremendously simplify
neuper@55431
   210
  building a hierarchy of theorems according to (1.2), see (*2*) below.
wneuper@59472
   211
\<close>
wneuper@59472
   212
ML \<open>(*1*) Free ("123.456", HOLogic.realT)\<close>
neuper@55484
   213
wneuper@59472
   214
subsection \<open>(4) Improve the efficiency of Isac’s rewrite-engine\<close>
wneuper@59472
   215
subsection \<open>(5) Adopt Isabelle/jEdit for Isac\<close>
neuper@55431
   216
neuper@37906
   217
end