1 (* Title: Knowledge/DiophantEq.thy
2 Author: Mathias Lehnfeld 2011
3 (c) due to copyright terms
4 12345678901234567890123456789012345678901234567890123456789012345678901234567890
5 10 20 30 40 50 60 70 80
8 theory DiophantEq imports Base_Tools Equation Test
12 Diophant'_equation :: "[bool, int, bool ]
14 ("((Script Diophant'_equation (_ _ =))//(_))" 9)
17 int_isolate_add: "(bdv + a = b) = (bdv = b + (-1)*(a::int))"
19 ML \<open>val thy = @{theory}\<close>
21 text \<open>problemclass for the usecase\<close>
22 setup \<open>KEStore_Elems.add_pbts
23 [(Specify.prep_pbt thy "pbl_equ_dio" [] Celem.e_pblID
24 (["diophantine","equation"],
25 [("#Given" ,["boolTestGiven e_e","intTestGiven (v_v::int)"]),
28 ("#Find" ,["boolTestFind s_s"])],
29 Rule.e_rls, SOME "solve (e_e::bool, v_v::int)", [["LinEq","solve_lineq_equation"]]))]\<close>
31 text \<open>method solving the usecase\<close>
32 setup \<open>KEStore_Elems.add_mets
33 [Specify.prep_met thy "met_test_diophant" [] Celem.e_metID
34 (["Test","solve_diophant"],
35 [("#Given" ,["boolTestGiven e_e","intTestGiven (v_v::int)"]),
38 ("#Find" ,["boolTestFind s_s"])],
39 {rew_ord' = "e_rew_ord", rls' = tval_rls, srls = Rule.e_rls, prls = Rule.e_rls, calc = [],
40 crls = tval_rls, errpats = [], nrls = Test_simplify},
41 "Script Diophant_equation (e_e::bool) (v_v::int)= " ^
43 " ((Try (Rewrite_Inst [(''bdv'',v_v::int)] ''int_isolate_add'' False)) @@" ^
44 " (Try (Calculate ''PLUS'')) @@ " ^
45 " (Try (Calculate ''TIMES''))) e_e::bool)")]