src/smltest/IsacKnowledge/polyminus.sml
branchstart-work-070517
changeset 264 9e1001a89c66
parent 263 cf52bc3a36cb
child 265 9845f2ecd851
     1.1 --- a/src/smltest/IsacKnowledge/polyminus.sml	Thu Dec 27 15:20:44 2007 +0100
     1.2 +++ b/src/smltest/IsacKnowledge/polyminus.sml	Thu Dec 27 17:44:23 2007 +0100
     1.3 @@ -6,13 +6,15 @@
     1.4  use"../smltest/IsacKnowledge/polyminus.sml";
     1.5  use"polyminus.sml";
     1.6  *)
     1.7 -val thy = EqSystem.thy;
     1.8 +val thy = PolyMinus.thy;
     1.9  
    1.10  "-----------------------------------------------------------------";
    1.11  "table of contents -----------------------------------------------";
    1.12  "-----------------------------------------------------------------";
    1.13  "----------- watch order_add_mult  -------------------------------";
    1.14  "----------- build predicate for +- ordering ---------------------";
    1.15 +"----------- build fasse_zuswammen -------------------------------";
    1.16 +"----------- build verschoenere ----------------------------------";
    1.17  "-----------------------------------------------------------------";
    1.18  "-----------------------------------------------------------------";
    1.19  "-----------------------------------------------------------------";
    1.20 @@ -23,6 +25,7 @@
    1.21  "----------- watch order_add_mult  -------------------------------";
    1.22  "----- with these simple variables it works...";
    1.23  trace_rewrite:=true;
    1.24 +trace_rewrite:=false;
    1.25  val t = str2term "((a + d) + c) + b";
    1.26  val Some (t,_) = rewrite_set_ thy false order_add_mult t; term2str t;
    1.27  if term2str t = "a + (b + (c + d))" then ()
    1.28 @@ -69,7 +72,6 @@
    1.29  (*@@@ rew_sub gosub: t = d + (b + a + c)
    1.30    @@@ rew_sub begin: t = b + a + c*)
    1.31  
    1.32 -(*#####################################################################
    1.33  
    1.34  "----------- build predicate for +- ordering ---------------------";
    1.35  "----------- build predicate for +- ordering ---------------------";
    1.36 @@ -91,16 +93,22 @@
    1.37      Some ("a kleiner b = True", _) => ()
    1.38    | _ => raise error "polyminus.sml: a kleiner b = True";
    1.39  
    1.40 -"----- test rewrite_, rewrite_set_";
    1.41 +"----- compare tausche_plus with real_num_collect";
    1.42  val od = dummy_ord;
    1.43 +
    1.44  val erls = erls_ordne_alphabetisch;
    1.45  val t = str2term "b + a";
    1.46 -"############################################";
    1.47  val Some (t,_) = rewrite_ thy od erls false tausche_plus t; term2str t;
    1.48  if term2str t = "a + b" then ()
    1.49  else raise error "polyminus.sml: ordne_alphabetisch1 b + a";
    1.50  
    1.51 +val erls = Atools_erls;
    1.52 +val t = str2term "2*a + 3*a";
    1.53 +val Some (t,_) = rewrite_ thy od erls false real_num_collect t; term2str t;
    1.54 +
    1.55 +"----- test rewrite_, rewrite_set_";
    1.56  trace_rewrite:=true;
    1.57 +val erls = erls_ordne_alphabetisch;
    1.58  val t = str2term "b + a";
    1.59  val Some (t,_) = rewrite_set_ thy false ordne_alphabetisch t; term2str t;
    1.60  if term2str t = "a + b" then ()
    1.61 @@ -136,14 +144,31 @@
    1.62  "----- compile rls for the most complicated terms";
    1.63  val t = str2term "5*e + 6*f - 8*g - 9 - 7*e - 4*f + 10*g + 12";
    1.64  "5 * e + 6 * f - 8 * g - 9 - 7 * e - 4 * f + 10 * g + 12";
    1.65 -val Some (t,_) = rewrite_set_ thy false ordne_alphabetisch t; term2str t;
    1.66 -"5 * e - 8 * g + 6 * f - 9 - 7 * e + 10 * g - 4 * f + 12";
    1.67 +val Some (t,_) = rewrite_set_ thy false ordne_alphabetisch t; 
    1.68 +if term2str t = "- 9 + 12 + 5 * e - 7 * e + 6 * f - 4 * f - 8 * g + 10 * g"
    1.69 +then () else raise error "polyminus.sml: ordne_alphabetisch finished";
    1.70  
    1.71  
    1.72 +"----------- build fasse_zuswammen -------------------------------";
    1.73 +"----------- build fasse_zuswammen -------------------------------";
    1.74 +"----------- build fasse_zuswammen -------------------------------";
    1.75 +val t = str2term "- 9 + 12 + 5 * e - 7 * e + 6 * f - 4 * f - 8 * g + 10 * g";
    1.76 +val Some (t,_) = rewrite_set_ thy false fasse_zusammen t;
    1.77 +if term2str t = "3 + -2 * e + 2 * f + 2 * g" then ()
    1.78 +else raise error "polyminus.sml: fasse_zusammen finished";
    1.79 +
    1.80 +"----------- build verschoenere ----------------------------------";
    1.81 +"----------- build verschoenere ----------------------------------";
    1.82 +"----------- build verschoenere ----------------------------------";
    1.83 +val t = str2term "3 + -2 * e + 2 * f + 2 * g";
    1.84 +val Some (t,_) = rewrite_set_ thy false verschoenere t;
    1.85 +if term2str t = "3 - 2 * e + 2 * f + 2 * g" then ()
    1.86 +else raise error "polyminus.sml: verschoenere 3 + -2 * e ...";
    1.87 +
    1.88 +trace_rewrite:=true;
    1.89  trace_rewrite:=false;
    1.90  (*
    1.91  use"../smltest/IsacKnowledge/polyminus.sml";
    1.92  use"polyminus.sml";
    1.93    *)
    1.94  
    1.95 -#####################################################################*)