src/Tools/isac/Knowledge/DiffApp.thy
author Walther Neuper <neuper@ist.tugraz.at>
Wed, 08 Sep 2010 17:49:36 +0200
branchisac-update-Isa09-2
changeset 37995 fac82f29f143
parent 37994 eb4c556a525b
child 38045 ac0f6fd8d129
permissions -rw-r--r--
updated Knowledge/DiffApp.thy
neuper@37906
     1
(* application of differential calculus
neuper@37954
     2
   Walther Neuper 2002
neuper@37954
     3
   (c) due to copyright terms
neuper@37906
     4
*)
neuper@37906
     5
neuper@37954
     6
theory DiffApp imports Diff begin
neuper@37906
     7
neuper@37906
     8
consts
neuper@37906
     9
neuper@37906
    10
  Maximum'_value
neuper@37954
    11
             :: "[bool list,real,bool list,real,real set,bool, 
neuper@37954
    12
		    bool list] => bool list"
neuper@37906
    13
               ("((Script Maximum'_value (_ _ _ _ _ _ =))// (_))" 9)
neuper@37906
    14
  
neuper@37906
    15
  Make'_fun'_by'_new'_variable
neuper@37954
    16
             :: "[real,real,bool list,  
neuper@37954
    17
		    bool] => bool"
neuper@37954
    18
               ("((Script Make'_fun'_by'_new'_variable (_ _ _ =))//  
neuper@37954
    19
		   (_))" 9)
neuper@37906
    20
  Make'_fun'_by'_explicit
neuper@37954
    21
             :: "[real,real,bool list,  
neuper@37954
    22
		    bool] => bool"
neuper@37954
    23
               ("((Script Make'_fun'_by'_explicit (_ _ _ =))//  
neuper@37954
    24
		   (_))" 9)
neuper@37906
    25
neuper@37906
    26
  dummy :: real
neuper@37906
    27
neuper@37906
    28
(*for script Maximum_value*)
neuper@37906
    29
  filterVar :: "[real, 'a list] => 'a list"
neuper@37906
    30
neuper@37983
    31
(*primrec*)axioms
neuper@37995
    32
  filterVar_Nil:		"filterVar v []     = []"
neuper@37995
    33
  filterVar_Const:	"filterVar v (x#xs) =                       
neuper@37954
    34
			 (if (v mem (Vars x)) then x#(filterVar v xs)  
neuper@37954
    35
			                    else filterVar v xs)   "
neuper@37954
    36
text {*WN.6.5.03: old decisions in this file partially are being changed
neuper@37954
    37
  in a quick-and-dirty way to make scripts run: Maximum_value,
neuper@37954
    38
  Make_fun_by_new_variable, Make_fun_by_explicit.
neuper@37954
    39
found to be reconsidered:
neuper@37954
    40
- descriptions (Descript.thy)
neuper@37954
    41
- penv: really need term list; or just rerun the whole example with num/var
neuper@37954
    42
- mk_arg, itms2args ... env in script different from penv ?
neuper@37954
    43
- L = SubProblem eq ... show some vars on the worksheet ? (other means for
neuper@37954
    44
  referencing are labels (no on worksheet))
neuper@37954
    45
neuper@37954
    46
WN.6.5.03 quick-and-dirty: mk_arg, itms2args just make most convenient env
neuper@37954
    47
  from penv as is.    
neuper@37954
    48
*}
neuper@37954
    49
neuper@37954
    50
ML {*
neuper@37972
    51
val thy = @{theory};
neuper@37972
    52
neuper@37954
    53
val eval_rls = prep_rls(
neuper@37954
    54
  Rls {id="eval_rls",preconds = [], rew_ord = ("termlessI",termlessI), 
neuper@37954
    55
      erls = e_rls, srls = Erls, calc = [], (*asm_thm = [],*)
neuper@37969
    56
      rules = [Thm ("refl",num_str @{thm refl}),
neuper@37965
    57
		Thm ("real_le_refl",num_str @{thm real_le_refl}),
neuper@37969
    58
		Thm ("radd_left_cancel_le",num_str @{thm radd_left_cancel_le}),
neuper@37969
    59
		Thm ("not_true",num_str @{thm not_true}),
neuper@37969
    60
		Thm ("not_false",num_str @{thm not_false}),
neuper@37969
    61
		Thm ("and_true",num_str @{thm and_true}),
neuper@37969
    62
		Thm ("and_false",num_str @{thm and_false}),
neuper@37969
    63
		Thm ("or_true",num_str @{thm or_true}),
neuper@37969
    64
		Thm ("or_false",num_str @{thm or_false}),
neuper@37969
    65
		Thm ("and_commute",num_str @{thm and_commute}),
neuper@37969
    66
		Thm ("or_commute",num_str @{thm or_commute}),
neuper@37954
    67
		
neuper@37954
    68
		Calc ("op <",eval_equ "#less_"),
neuper@37954
    69
		Calc ("op <=",eval_equ "#less_equal_"),
neuper@37954
    70
		
neuper@37954
    71
		Calc ("Atools.ident",eval_ident "#ident_"),    
neuper@37954
    72
		Calc ("Atools.is'_const",eval_const "#is_const_"),
neuper@37954
    73
		Calc ("Atools.occurs'_in",eval_occurs_in ""),    
neuper@37954
    74
		Calc ("Tools.matches",eval_matches "")
neuper@37954
    75
	       ],
neuper@37954
    76
      scr = Script ((term_of o the o (parse thy)) 
neuper@37954
    77
      "empty_script")
neuper@37954
    78
      }:rls);
neuper@37967
    79
ruleset' := overwritelthy @{theory}
neuper@37954
    80
		(!ruleset',
neuper@37954
    81
		 [("eval_rls",Atools_erls)(*FIXXXME:del with rls.rls'*)
neuper@37954
    82
		  ]);
neuper@37995
    83
*}
neuper@37995
    84
ML{*
neuper@37954
    85
neuper@37954
    86
(** problem types **)
neuper@37954
    87
neuper@37954
    88
store_pbt
neuper@37972
    89
 (prep_pbt thy "pbl_fun_max" [] e_pblID
neuper@37954
    90
 (["maximum_of","function"],
neuper@37995
    91
  [("#Given" ,["fixedValues f_ix"]),
neuper@37995
    92
   ("#Find"  ,["maximum m_m","valuesFor v_s"]),
neuper@37995
    93
   ("#Relate",["relations r_s"])
neuper@37954
    94
  ],
neuper@37954
    95
  e_rls, NONE, []));
neuper@37954
    96
neuper@37954
    97
store_pbt
neuper@37972
    98
 (prep_pbt thy "pbl_fun_make" [] e_pblID
neuper@37954
    99
 (["make","function"]:pblID,
neuper@37994
   100
  [("#Given" ,["functionOf f_f","boundVariable v_v","equalities eqs"]),
neuper@37995
   101
   ("#Find"  ,["functionEq f_1"])
neuper@37954
   102
  ],
neuper@37954
   103
  e_rls, NONE, []));
neuper@37954
   104
store_pbt
neuper@37972
   105
 (prep_pbt thy "pbl_fun_max_expl" [] e_pblID
neuper@37954
   106
 (["by_explicit","make","function"]:pblID,
neuper@37994
   107
  [("#Given" ,["functionOf f_f","boundVariable v_v","equalities eqs"]),
neuper@37995
   108
   ("#Find"  ,["functionEq f_1"])
neuper@37954
   109
  ],
neuper@37954
   110
  e_rls, NONE, [["DiffApp","make_fun_by_explicit"]]));
neuper@37954
   111
store_pbt
neuper@37972
   112
 (prep_pbt thy "pbl_fun_max_newvar" [] e_pblID
neuper@37954
   113
 (["by_new_variable","make","function"]:pblID,
neuper@37994
   114
  [("#Given" ,["functionOf f_f","boundVariable v_v","equalities eqs"]),
neuper@37954
   115
   (*WN.12.5.03: precond for distinction still missing*)
neuper@37995
   116
   ("#Find"  ,["functionEq f_1"])
neuper@37954
   117
  ],
neuper@37954
   118
  e_rls, NONE, [["DiffApp","make_fun_by_new_variable"]]));
neuper@37954
   119
neuper@37954
   120
store_pbt
neuper@37972
   121
 (prep_pbt thy "pbl_fun_max_interv" [] e_pblID
neuper@37954
   122
 (["on_interval","maximum_of","function"]:pblID,
neuper@37995
   123
  [("#Given" ,["functionEq t_t","boundVariable v_v","interval i_tv"]),
neuper@37954
   124
   (*WN.12.5.03: precond for distinction still missing*)
neuper@37995
   125
   ("#Find"  ,["maxArgument v_0"])
neuper@37954
   126
  ],
neuper@37954
   127
  e_rls, NONE, []));
neuper@37954
   128
neuper@37954
   129
store_pbt
neuper@37972
   130
 (prep_pbt thy "pbl_tool" [] e_pblID
neuper@37954
   131
 (["tool"]:pblID,
neuper@37954
   132
  [],
neuper@37954
   133
  e_rls, NONE, []));
neuper@37954
   134
neuper@37954
   135
store_pbt
neuper@37972
   136
 (prep_pbt thy "pbl_tool_findvals" [] e_pblID
neuper@37954
   137
 (["find_values","tool"]:pblID,
neuper@37995
   138
  [("#Given" ,["maxArgument m_ax","functionEq f_f","boundVariable v_v"]),
neuper@37995
   139
   ("#Find"  ,["valuesFor v_ls"]),
neuper@37995
   140
   ("#Relate",["additionalRels r_s"])
neuper@37954
   141
  ],
neuper@37954
   142
  e_rls, NONE, []));
neuper@37954
   143
neuper@37995
   144
*}
neuper@37995
   145
ML{*
neuper@37954
   146
neuper@37954
   147
(** methods, scripts not yet implemented **)
neuper@37954
   148
neuper@37954
   149
store_met
neuper@37972
   150
 (prep_met thy "met_diffapp" [] e_metID
neuper@37954
   151
 (["DiffApp"],
neuper@37954
   152
   [],
neuper@37954
   153
   {rew_ord'="tless_true",rls'=Atools_erls,calc = [], srls = e_rls, prls=e_rls,
neuper@37954
   154
    crls = Atools_erls, nrls=norm_Rational
neuper@37954
   155
    (*, asm_rls=[],asm_thm=[]*)}, "empty_script"));
neuper@37995
   156
*}
neuper@37995
   157
ML{*
neuper@37954
   158
store_met
neuper@37972
   159
 (prep_met thy "met_diffapp_max" [] e_metID
neuper@37954
   160
 (["DiffApp","max_by_calculus"]:metID,
neuper@37995
   161
  [("#Given" ,["fixedValues f_ix","maximum m_m","relations r_s",
neuper@37995
   162
	       "boundVariable v_v","interval i_tv","errorBound e_rr"]),
neuper@37995
   163
    ("#Find"  ,["valuesFor v_s"]),
neuper@37954
   164
    ("#Relate",[])
neuper@37954
   165
    ],
neuper@37954
   166
  {rew_ord'="tless_true",rls'=eval_rls,calc=[],srls=list_rls,prls=e_rls,
neuper@37954
   167
    crls = eval_rls, nrls=norm_Rational
neuper@37954
   168
   (*,  asm_rls=[],asm_thm=[]*)},
neuper@37995
   169
  "Script Maximum_value(f_ix::bool list)(m_m::real) (r_s::bool list)       " ^
neuper@37995
   170
  "      (v_v::real) (itv_v::real set) (e_rr::bool) =                       " ^ 
neuper@37995
   171
  " (let e_e = (hd o (filterVar m_m)) r_s;                                  " ^
neuper@37995
   172
  "      t_t = (if 1 < LENGTH r_s                                         " ^
neuper@37995
   173
  "           then (SubProblem (DiffApp',[make,function],[no_met])        " ^
neuper@37995
   174
  "                     [REAL m_m, REAL v_v, BOOL_LIST r_s])             " ^
neuper@37995
   175
  "           else (hd r_s));                                             " ^
neuper@37995
   176
  "      (m_x::real) =                                                    " ^ 
neuper@37995
   177
  "SubProblem(DiffApp',[on_interval,maximum_of,function],                 " ^
neuper@37954
   178
  "                                [DiffApp,max_on_interval_by_calculus]) " ^
neuper@37995
   179
  "                               [BOOL t_t, REAL v_v, REAL_SET i_tv]    " ^
neuper@37995
   180
  " in ((SubProblem (DiffApp',[find_values,tool],[Isac,find_values])      " ^
neuper@37995
   181
  "      [REAL m_x, REAL (Rhs t_t), REAL v_v, REAL m_m,                  " ^
neuper@37995
   182
  "       BOOL_LIST (dropWhile (ident e_e) r_s)])::bool list))            "
neuper@37954
   183
 ));
neuper@37995
   184
*}
neuper@37995
   185
ML{*
neuper@37954
   186
store_met
neuper@37972
   187
 (prep_met thy "met_diffapp_funnew" [] e_metID
neuper@37954
   188
 (["DiffApp","make_fun_by_new_variable"]:metID,
neuper@37994
   189
   [("#Given" ,["functionOf f_f","boundVariable v_v","equalities eqs"]),
neuper@37995
   190
    ("#Find"  ,["functionEq f_1"])
neuper@37954
   191
    ],
neuper@37954
   192
   {rew_ord'="tless_true",rls'=eval_rls,srls=list_rls,prls=e_rls,
neuper@37954
   193
    calc=[], crls = eval_rls, nrls=norm_Rational(*,asm_rls=[],asm_thm=[]*)},
neuper@37994
   194
  "Script Make_fun_by_new_variable (f_f::real) (v_v::real)                " ^
neuper@37994
   195
  "      (eqs::bool list) =                                            " ^
neuper@37995
   196
  "(let h_h = (hd o (filterVar f_f)) eqs;                                " ^
neuper@37995
   197
  "     e_s = dropWhile (ident h_h) eqs;                                " ^
neuper@37995
   198
  "     v_s = dropWhile (ident f_f) (Vars h_h);                           " ^
neuper@37995
   199
  "     v_1 = NTH 1 v_s;                                               " ^
neuper@37995
   200
  "     v_2 = NTH 2 v_s;                                               " ^
neuper@37995
   201
  "     e_1 = (hd o (filterVar v_1)) e_s;                               " ^
neuper@37995
   202
  "     e_2 = (hd o (filterVar v_2)) e_s;                               " ^
neuper@37954
   203
  "  (s_1::bool list) =                                                 " ^
neuper@37995
   204
  "                (SubProblem (DiffApp',[univariate,equation],[no_met])" ^
neuper@37984
   205
  "                    [BOOL e_1, REAL v_1]);                         " ^
neuper@37954
   206
  "  (s_2::bool list) =                                                 " ^
neuper@37995
   207
  "                (SubProblem (DiffApp',[univariate,equation],[no_met])" ^
neuper@37984
   208
  "                    [BOOL e_2, REAL v_2])" ^
neuper@37995
   209
  "in Substitute [(v_1 = (rhs o hd) s_1),(v_2 = (rhs o hd) s_2)] h_h)"
neuper@37954
   210
));
neuper@37995
   211
*}
neuper@37995
   212
ML{*
neuper@37954
   213
store_met
neuper@37972
   214
(prep_met thy "met_diffapp_funexp" [] e_metID
neuper@37954
   215
(["DiffApp","make_fun_by_explicit"]:metID,
neuper@37994
   216
   [("#Given" ,["functionOf f_f","boundVariable v_v","equalities eqs"]),
neuper@37995
   217
    ("#Find"  ,["functionEq f_1"])
neuper@37954
   218
    ],
neuper@37954
   219
   {rew_ord'="tless_true",rls'=eval_rls,calc=[],srls=list_rls,prls=e_rls,
neuper@37954
   220
    crls = eval_rls, nrls=norm_Rational
neuper@37954
   221
    (*, asm_rls=[],asm_thm=[]*)},
neuper@37994
   222
   "Script Make_fun_by_explicit (f_f::real) (v_v::real)                 " ^
neuper@37994
   223
   "      (eqs::bool list) =                                         " ^
neuper@37995
   224
   " (let h_h = (hd o (filterVar f_f)) eqs;                            " ^
neuper@37995
   225
   "      e_1 = hd (dropWhile (ident h_h) eqs);                       " ^
neuper@37995
   226
   "      v_s = dropWhile (ident f_f) (Vars h_h);                       " ^
neuper@37995
   227
   "      v_1 = hd (dropWhile (ident v_v) v_s);                        " ^
neuper@37954
   228
   "      (s_1::bool list)=                                           " ^ 
neuper@37995
   229
   "              (SubProblem(DiffApp',[univariate,equation],[no_met])" ^
neuper@37984
   230
   "                          [BOOL e_1, REAL v_1])                 " ^
neuper@37995
   231
   " in Substitute [(v_1 = (rhs o hd) s_1)] h_h)                       "
neuper@37954
   232
   ));
neuper@37995
   233
*}
neuper@37995
   234
ML{*
neuper@37954
   235
store_met
neuper@37972
   236
 (prep_met thy "met_diffapp_max_oninterval" [] e_metID
neuper@37954
   237
 (["DiffApp","max_on_interval_by_calculus"]:metID,
neuper@37995
   238
   [("#Given" ,["functionEq t_t","boundVariable v_v","interval i_tv"(*,
neuper@37995
   239
		"errorBound e_rr"*)]),
neuper@37995
   240
    ("#Find"  ,["maxArgument v_0"])
neuper@37954
   241
    ],
neuper@37954
   242
   {rew_ord'="tless_true",rls'=eval_rls,calc=[],srls = e_rls,prls=e_rls,
neuper@37954
   243
    crls = eval_rls, nrls=norm_Rational
neuper@37954
   244
    (*, asm_rls=[],asm_thm=[]*)},
neuper@37954
   245
   "empty_script"
neuper@37954
   246
   ));
neuper@37995
   247
*}
neuper@37995
   248
ML{*
neuper@37954
   249
store_met
neuper@37972
   250
 (prep_met thy "met_diffapp_findvals" [] e_metID
neuper@37954
   251
 (["DiffApp","find_values"]:metID,
neuper@37954
   252
   [],
neuper@37954
   253
   {rew_ord'="tless_true",rls'=eval_rls,calc=[],srls = e_rls,prls=e_rls,
neuper@37954
   254
    crls = eval_rls, nrls=norm_Rational(*,
neuper@37954
   255
    asm_rls=[],asm_thm=[]*)},
neuper@37954
   256
   "empty_script"));
neuper@37954
   257
neuper@37954
   258
val list_rls = append_rls "list_rls" list_rls
neuper@37969
   259
			  [Thm ("filterVar_Const", num_str @{thm filterVar_Const}),
neuper@37969
   260
			   Thm ("filterVar_Nil", num_str @{thm filterVar_Nil})
neuper@37954
   261
			   ];
neuper@37967
   262
ruleset' := overwritelthy @{theory} (!ruleset',
neuper@37954
   263
  [("list_rls",list_rls)
neuper@37954
   264
   ]);
neuper@37954
   265
*}
neuper@37906
   266
neuper@37906
   267
end