src/Tools/isac/Knowledge/RatEq.thy
author Walther Neuper <neuper@ist.tugraz.at>
Tue, 28 Sep 2010 09:06:56 +0200
branchisac-update-Isa09-2
changeset 38031 460c24a6a6ba
parent 38015 67ba02dffacc
child 41922 32d7766945fb
permissions -rw-r--r--
tuned error and writeln

# raise error --> error
# writeln in atomtyp, atomty, atomt and xmlsrc
neuper@37906
     1
(*.(c) by Richard Lang, 2003 .*)
neuper@37906
     2
(* theory collecting all knowledge for RationalEquations
neuper@37906
     3
   created by: rlang 
neuper@37906
     4
         date: 02.08.12
neuper@37906
     5
   changed by: rlang
neuper@37906
     6
   last change by: rlang
neuper@37906
     7
             date: 02.11.28
neuper@37906
     8
*)
neuper@37906
     9
neuper@37954
    10
theory RatEq imports Rational begin
neuper@37906
    11
neuper@37906
    12
consts
neuper@37906
    13
neuper@37906
    14
  is'_ratequation'_in :: "[bool, real] => bool" ("_ is'_ratequation'_in _")
neuper@37906
    15
neuper@37906
    16
  (*----------------------scripts-----------------------*)
neuper@37906
    17
  Solve'_rat'_equation
neuper@37954
    18
             :: "[bool,real, 
neuper@37954
    19
		   bool list] => bool list"
neuper@37954
    20
               ("((Script Solve'_rat'_equation (_ _ =))// 
neuper@37954
    21
                  (_))" 9)
neuper@37906
    22
neuper@37954
    23
axioms 
neuper@37906
    24
   (* FIXME also in Poly.thy def. --> FIXED*)
neuper@37906
    25
   (*real_diff_minus            
neuper@37906
    26
   "a - b = a + (-1) * b"*)
neuper@37983
    27
   real_rat_mult_1:   "a*(b/c) = (a*b)/c"
neuper@37983
    28
   real_rat_mult_2:   "(a/b)*(c/d) = (a*c)/(b*d)"
neuper@37983
    29
   real_rat_mult_3:   "(a/b)*c = (a*c)/b"
neuper@37983
    30
   real_rat_pow:      "(a/b)^^^2 = a^^^2/b^^^2"
neuper@37906
    31
neuper@37983
    32
   rat_double_rat_1:   "[|Not(c=0); Not(d=0)|] ==> (a / (c/d) = (a*d) / c)"
neuper@37983
    33
   rat_double_rat_2:   "[|Not(b=0);Not(c=0); Not(d=0)|] ==> 
neuper@37983
    34
                                           ((a/b) / (c/d) = (a*d) / (b*c))"
neuper@37983
    35
   rat_double_rat_3:   "[|Not(b=0);Not(c=0)|] ==> ((a/b) / c = a / (b*c))"
neuper@37906
    36
neuper@37906
    37
  (* equation to same denominator *)
neuper@37983
    38
  rat_mult_denominator_both:
neuper@37906
    39
   "[|Not(b=0); Not(d=0)|] ==> ((a::real) / b = c / d) = (a*d = c*b)"
neuper@37983
    40
  rat_mult_denominator_left:
neuper@37906
    41
   "[|Not(d=0)|] ==> ((a::real) = c / d) = (a*d = c)"
neuper@37983
    42
  rat_mult_denominator_right:
neuper@37906
    43
   "[|Not(b=0)|] ==> ((a::real) / b = c) = (a = c*b)"
neuper@37906
    44
neuper@37954
    45
ML {*
neuper@37972
    46
val thy = @{theory};
neuper@37972
    47
neuper@37954
    48
(*-------------------------functions-----------------------*)
neuper@37954
    49
(* is_rateqation_in becomes true, if a bdv is in the denominator of a fraction*)
neuper@37954
    50
fun is_rateqation_in t v = 
neuper@37954
    51
    let 
neuper@37954
    52
	fun coeff_in c v = member op = (vars c) v;
neuper@38031
    53
   	fun finddivide (_ $ _ $ _ $ _) v = error("is_rateqation_in:")
neuper@37954
    54
	    (* at the moment there is no term like this, but ....*)
neuper@38014
    55
	  | finddivide (t as (Const ("Rings.inverse_class.divide",_) $ _ $ b)) v = coeff_in b v
neuper@37954
    56
	  | finddivide (_ $ t1 $ t2) v = (finddivide t1 v) 
neuper@37954
    57
                                         orelse (finddivide t2 v)
neuper@37954
    58
	  | finddivide (_ $ t1) v = (finddivide t1 v)
neuper@37954
    59
	  | finddivide _ _ = false;
neuper@37954
    60
     in
neuper@37954
    61
	finddivide t v
neuper@37954
    62
    end;
neuper@37954
    63
    
neuper@37954
    64
fun eval_is_ratequation_in _ _ 
neuper@37954
    65
       (p as (Const ("RatEq.is'_ratequation'_in",_) $ t $ v)) _  =
neuper@37954
    66
    if is_rateqation_in t v then 
neuper@37954
    67
	SOME ((term2str p) ^ " = True",
neuper@37954
    68
	      Trueprop $ (mk_equality (p, HOLogic.true_const)))
neuper@37954
    69
    else SOME ((term2str p) ^ " = True",
neuper@37954
    70
	       Trueprop $ (mk_equality (p, HOLogic.false_const)))
neuper@38015
    71
  | eval_is_ratequation_in _ _ _ _ = ((*tracing"### nichts matcht";*) NONE);
neuper@37954
    72
neuper@37954
    73
(*-------------------------rulse-----------------------*)
neuper@37954
    74
val RatEq_prls = (*15.10.02:just the following order due to subterm evaluation*)
neuper@37954
    75
  append_rls "RatEq_prls" e_rls 
neuper@37954
    76
	     [Calc ("Atools.ident",eval_ident "#ident_"),
neuper@37954
    77
	      Calc ("Tools.matches",eval_matches ""),
neuper@37954
    78
	      Calc ("Tools.lhs"    ,eval_lhs ""),
neuper@37954
    79
	      Calc ("Tools.rhs"    ,eval_rhs ""),
neuper@37954
    80
	      Calc ("RatEq.is'_ratequation'_in",eval_is_ratequation_in ""),
neuper@37954
    81
	      Calc ("op =",eval_equal "#equal_"),
neuper@37969
    82
	      Thm ("not_true",num_str @{thm not_true}),
neuper@37969
    83
	      Thm ("not_false",num_str @{thm not_false}),
neuper@37969
    84
	      Thm ("and_true",num_str @{thm and_true}),
neuper@37969
    85
	      Thm ("and_false",num_str @{thm and_false}),
neuper@37969
    86
	      Thm ("or_true",num_str @{thm or_true}),
neuper@37969
    87
	      Thm ("or_false",num_str @{thm or_false})
neuper@37954
    88
	      ];
neuper@37954
    89
neuper@37954
    90
neuper@37954
    91
(*rls = merge_rls erls Poly_erls *)
neuper@37954
    92
val rateq_erls = 
neuper@37954
    93
    remove_rls "rateq_erls"                                   (*WN: ein Hack*)
neuper@37954
    94
	(merge_rls "is_ratequation_in" calculate_Rational
neuper@37954
    95
		   (append_rls "is_ratequation_in"
neuper@37954
    96
			Poly_erls
neuper@38014
    97
			[(*Calc ("Rings.inverse_class.divide", eval_cancel "#divide_e"),*)
neuper@37954
    98
			 Calc ("RatEq.is'_ratequation'_in",
neuper@37954
    99
			       eval_is_ratequation_in "")
neuper@37954
   100
neuper@37954
   101
			 ]))
neuper@37969
   102
	[Thm ("and_commute",num_str @{thm and_commute}), (*WN: ein Hack*)
neuper@37969
   103
	 Thm ("or_commute",num_str @{thm or_commute})    (*WN: ein Hack*)
neuper@37954
   104
	 ];
neuper@37967
   105
ruleset' := overwritelthy @{theory} (!ruleset',
neuper@37954
   106
			[("rateq_erls",rateq_erls)(*FIXXXME:del with rls.rls'*)
neuper@37954
   107
			 ]);
neuper@37954
   108
neuper@37954
   109
neuper@37954
   110
val RatEq_crls = 
neuper@37954
   111
    remove_rls "RatEq_crls"                                   (*WN: ein Hack*)
neuper@37954
   112
	(merge_rls "is_ratequation_in" calculate_Rational
neuper@37954
   113
		   (append_rls "is_ratequation_in"
neuper@37954
   114
			Poly_erls
neuper@38014
   115
			[(*Calc ("Rings.inverse_class.divide", eval_cancel "#divide_e"),*)
neuper@37954
   116
			 Calc ("RatEq.is'_ratequation'_in",
neuper@37954
   117
			       eval_is_ratequation_in "")
neuper@37954
   118
			 ]))
neuper@37969
   119
	[Thm ("and_commute",num_str @{thm and_commute}), (*WN: ein Hack*)
neuper@37969
   120
	 Thm ("or_commute",num_str @{thm or_commute})    (*WN: ein Hack*)
neuper@37954
   121
	 ];
neuper@37954
   122
neuper@37954
   123
val RatEq_eliminate = prep_rls(
neuper@37954
   124
  Rls {id = "RatEq_eliminate", preconds = [],
neuper@37954
   125
       rew_ord = ("termlessI", termlessI), erls = rateq_erls, srls = Erls, 
neuper@37954
   126
       calc = [], 
neuper@37954
   127
       rules = [
neuper@37969
   128
	    Thm("rat_mult_denominator_both",num_str @{thm rat_mult_denominator_both}), 
neuper@37954
   129
	     (* a/b=c/d -> ad=cb *)
neuper@37969
   130
	    Thm("rat_mult_denominator_left",num_str @{thm rat_mult_denominator_left}), 
neuper@37954
   131
	     (* a  =c/d -> ad=c  *)
neuper@37969
   132
	    Thm("rat_mult_denominator_right",num_str @{thm rat_mult_denominator_right})
neuper@37954
   133
	     (* a/b=c   ->  a=cb *)
neuper@37954
   134
	    ],
neuper@37954
   135
    scr = Script ((term_of o the o (parse thy)) "empty_script")
neuper@37954
   136
    }:rls);
neuper@37967
   137
ruleset' := overwritelthy @{theory} (!ruleset',
neuper@37954
   138
			[("RatEq_eliminate",RatEq_eliminate)
neuper@37954
   139
			 ]);
neuper@37954
   140
neuper@37954
   141
val RatEq_simplify = prep_rls(
neuper@37954
   142
  Rls {id = "RatEq_simplify", preconds = [], rew_ord = ("termlessI", termlessI),
neuper@37954
   143
      erls = rateq_erls, srls = Erls, calc = [], 
neuper@37954
   144
    rules = [
neuper@37969
   145
	     Thm("real_rat_mult_1",num_str @{thm real_rat_mult_1}),
neuper@37954
   146
	     (*a*(b/c) = (a*b)/c*)
neuper@37969
   147
	     Thm("real_rat_mult_2",num_str @{thm real_rat_mult_2}),
neuper@37954
   148
	     (*(a/b)*(c/d) = (a*c)/(b*d)*)
neuper@37969
   149
             Thm("real_rat_mult_3",num_str @{thm real_rat_mult_3}),
neuper@37954
   150
             (* (a/b)*c = (a*c)/b*)
neuper@37969
   151
	     Thm("real_rat_pow",num_str @{thm real_rat_pow}),
neuper@37954
   152
	     (*(a/b)^^^2 = a^^^2/b^^^2*)
neuper@37969
   153
	     Thm("real_diff_minus",num_str @{thm real_diff_minus}),
neuper@37954
   154
	     (* a - b = a + (-1) * b *)
neuper@37969
   155
             Thm("rat_double_rat_1",num_str @{thm rat_double_rat_1}),
neuper@37954
   156
             (* (a / (c/d) = (a*d) / c) *)
neuper@37969
   157
             Thm("rat_double_rat_2",num_str @{thm rat_double_rat_2}), 
neuper@37954
   158
             (* ((a/b) / (c/d) = (a*d) / (b*c)) *)
neuper@37969
   159
             Thm("rat_double_rat_3",num_str @{thm rat_double_rat_3}) 
neuper@37954
   160
             (* ((a/b) / c = a / (b*c) ) *)
neuper@37954
   161
	     ],
neuper@37954
   162
    scr = Script ((term_of o the o (parse thy)) "empty_script")
neuper@37954
   163
    }:rls);
neuper@37967
   164
ruleset' := overwritelthy @{theory} (!ruleset',
neuper@37954
   165
			[("RatEq_simplify",RatEq_simplify)
neuper@37954
   166
			 ]);
neuper@37954
   167
neuper@37954
   168
(*-------------------------Problem-----------------------*)
neuper@37954
   169
(*
neuper@37954
   170
(get_pbt ["rational","univariate","equation"]);
neuper@37954
   171
show_ptyps(); 
neuper@37954
   172
*)
neuper@37954
   173
store_pbt
neuper@37972
   174
 (prep_pbt thy "pbl_equ_univ_rat" [] e_pblID
neuper@37954
   175
 (["rational","univariate","equation"],
neuper@37981
   176
  [("#Given" ,["equality e_e","solveFor v_v"]),
neuper@37982
   177
   ("#Where" ,["(e_e::bool) is_ratequation_in (v_v::real)"]),
neuper@38012
   178
   ("#Find"  ,["solutions v_v'i'"]) 
neuper@37954
   179
  ],
neuper@37954
   180
neuper@37981
   181
  RatEq_prls, SOME "solve (e_e::bool, v_v)",
neuper@37954
   182
  [["RatEq","solve_rat_equation"]]));
neuper@37988
   183
*}
neuper@37954
   184
neuper@37988
   185
ML {*
neuper@37954
   186
(*-------------------------methods-----------------------*)
neuper@37954
   187
store_met
neuper@37972
   188
 (prep_met thy "met_rateq" [] e_metID
neuper@37954
   189
 (["RatEq"],
neuper@37954
   190
   [],
neuper@37954
   191
   {rew_ord'="tless_true",rls'=Atools_erls,calc = [], srls = e_rls, prls=e_rls,
neuper@37954
   192
    crls=RatEq_crls, nrls=norm_Rational
neuper@37954
   193
    (*, asm_rls=[],asm_thm=[]*)}, "empty_script"));
neuper@37988
   194
*}
neuper@37988
   195
neuper@37988
   196
ML {*
neuper@37954
   197
store_met
neuper@37972
   198
 (prep_met thy "met_rat_eq" [] e_metID
neuper@37954
   199
 (["RatEq","solve_rat_equation"],
neuper@37981
   200
   [("#Given" ,["equality e_e","solveFor v_v"]),
neuper@37982
   201
   ("#Where" ,["(e_e::bool) is_ratequation_in (v_v::real)"]),
neuper@38012
   202
   ("#Find"  ,["solutions v_v'i'"])
neuper@37954
   203
  ],
neuper@37954
   204
   {rew_ord'="termlessI",
neuper@37954
   205
    rls'=rateq_erls,
neuper@37954
   206
    srls=e_rls,
neuper@37954
   207
    prls=RatEq_prls,
neuper@37954
   208
    calc=[],
neuper@37954
   209
    crls=RatEq_crls, nrls=norm_Rational},
neuper@37982
   210
   "Script Solve_rat_equation  (e_e::bool) (v_v::real) =                   " ^
neuper@37981
   211
    "(let e_e = ((Repeat(Try (Rewrite_Set RatEq_simplify      True))) @@  " ^
neuper@37954
   212
    "           (Repeat(Try (Rewrite_Set norm_Rational      False))) @@  " ^
neuper@37954
   213
    "           (Repeat(Try (Rewrite_Set common_nominator_p False))) @@  " ^
neuper@37988
   214
    "           (Repeat(Try (Rewrite_Set RatEq_eliminate     True)))) e_e;" ^
neuper@37988
   215
    " (L_L::bool list) = (SubProblem (RatEq',[univariate,equation], [no_met])" ^
neuper@37988
   216
    "                    [BOOL e_e, REAL v_v])                     " ^
neuper@37991
   217
    " in Check_elementwise L_LL {(v_v::real). Assumptions})"
neuper@37954
   218
   ));
neuper@37988
   219
*}
neuper@37954
   220
neuper@37988
   221
ML {*
neuper@37954
   222
calclist':= overwritel (!calclist', 
neuper@37954
   223
   [("is_ratequation_in", ("RatEq.is_ratequation_in", 
neuper@37954
   224
			   eval_is_ratequation_in ""))
neuper@37954
   225
    ]);
neuper@37954
   226
*}
neuper@37906
   227
neuper@37906
   228
end