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 Atools 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 {*val thy = @{theory}*}
21 text {*problemclass for the usecase*}
22 setup {* 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"]]))] *}
31 text {*method solving the usecase*}
32 setup {* 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)")]