Moved even/odd lemmas from ex/Mutil to Arith
authorpaulson
Thu, 28 Mar 1996 12:36:50 +0100
changeset 1626 12560b3ebf2c
parent 1625 40501958d0f6
child 1627 64ee96ebf32a
Moved even/odd lemmas from ex/Mutil to Arith
src/HOL/Arith.ML
src/HOL/ex/Mutil.ML
--- a/src/HOL/Arith.ML	Thu Mar 28 12:25:55 1996 +0100
+++ b/src/HOL/Arith.ML	Thu Mar 28 12:36:50 1996 +0100
@@ -315,6 +315,33 @@
 qed "mod_less_divisor";
 
 
+(** Evens and Odds **)
+
+val less_cs = set_cs addSEs [less_zeroE, less_SucE];
+
+goal thy "!!k b. b<2 ==> k mod 2 = b | k mod 2 = (if b=1 then 0 else 1)";
+by (subgoal_tac "k mod 2 < 2" 1);
+by (asm_simp_tac (!simpset addsimps [mod_less_divisor]) 2);
+by (asm_simp_tac (!simpset setloop split_tac [expand_if]) 1);
+by (fast_tac less_cs 1);
+qed "mod2_cases";
+
+goal thy "Suc(Suc(m)) mod 2 = m mod 2";
+by (subgoal_tac "m mod 2 < 2" 1);
+by (asm_simp_tac (!simpset addsimps [mod_less_divisor]) 2);
+by (safe_tac less_cs);
+by (ALLGOALS (asm_simp_tac (!simpset addsimps [mod_Suc])));
+qed "mod2_Suc_Suc";
+Addsimps [mod2_Suc_Suc];
+
+goal thy "(m+m) mod 2 = 0";
+by (nat_ind_tac "m" 1);
+by (simp_tac (!simpset addsimps [mod_less]) 1);
+by (asm_simp_tac (!simpset addsimps [mod2_Suc_Suc, add_Suc_right]) 1);
+qed "mod2_add_self";
+Addsimps [mod2_add_self];
+
+
 (**** Additional theorems about "less than" ****)
 
 goal Arith.thy "!!m. m<n --> (? k. n=Suc(m+k))";
--- a/src/HOL/ex/Mutil.ML	Thu Mar 28 12:25:55 1996 +0100
+++ b/src/HOL/ex/Mutil.ML	Thu Mar 28 12:36:50 1996 +0100
@@ -45,33 +45,6 @@
 qed "evnodd_empty";
 
 
-(*** Evens and Odds ***)
-
-val less_cs = set_cs addSEs [less_zeroE, less_SucE];
-
-goal thy "!!k b. b<2 ==> k mod 2 = b | k mod 2 = (if b=1 then 0 else 1)";
-by (subgoal_tac "k mod 2 < 2" 1);
-by (asm_simp_tac (!simpset addsimps [mod_less_divisor]) 2);
-by (asm_simp_tac (!simpset setloop split_tac [expand_if]) 1);
-by (fast_tac less_cs 1);
-qed "mod2_cases";
-
-goal thy "Suc(Suc(m)) mod 2 = m mod 2";
-by (subgoal_tac "m mod 2 < 2" 1);
-by (asm_simp_tac (!simpset addsimps [mod_less_divisor]) 2);
-by (safe_tac less_cs);
-by (ALLGOALS (asm_simp_tac (!simpset addsimps [mod_Suc])));
-qed "mod2_Suc_Suc";
-Addsimps [mod2_Suc_Suc];
-
-goal thy "(m+m) mod 2 = 0";
-by (nat_ind_tac "m" 1);
-by (simp_tac (!simpset addsimps [mod_less]) 1);
-by (asm_simp_tac (!simpset addsimps [mod2_Suc_Suc, add_Suc_right]) 1);
-qed "mod2_add_self";
-Addsimps [mod2_add_self];
-
-
 (*** Dominoes ***)
 
 goal thy "!!d. d:domino ==> finite d";
@@ -85,8 +58,7 @@
 by (REPEAT_FIRST assume_tac);
 (*Four similar cases: case (i+j) mod 2 = b, 2#-b, ...*)
 by (REPEAT (asm_simp_tac (!simpset addsimps
-                          [evnodd_insert, evnodd_empty, mod_Suc,
-                           Suc_n_not_n] 
+                          [evnodd_insert, evnodd_empty, mod_Suc] 
                           setloop split_tac [expand_if]) 1
            THEN fast_tac less_cs 1));
 qed "domino_singleton";
@@ -138,8 +110,7 @@
 
 val [below_0, below_Suc] = nat_recs below_def;
 Addsimps [below_0];
-(*Strangely, below_Suc should NOT be added as rewrites -- 
-  or Sigma_Suc1,2 cannot be used*)
+(*below_Suc should NOT be added, or Sigma_Suc1,2 cannot be used*)
 
 goal thy "(i: below k) = (i<k)";
 by (res_inst_tac [("x", "i")] spec 1);
@@ -185,8 +156,7 @@
 qed "dominoes_tile_matrix";
 
 
-goal thy "!!m n. [| m: nat;  n: nat;  \
-\                   t = Sigma (below (Suc m + Suc m))\
+goal thy "!!m n. [| t = Sigma (below (Suc m + Suc m))\
 \                             (%x. below (Suc n + Suc n));          \
 \                   t' = t - {(0,0)} - {(Suc(m+m), Suc(n+n))}       \
 \                |] ==> t' ~: tiling domino";