src/ZF/Induct/Mutil.thy
author blanchet
Thu, 16 Jan 2014 16:33:19 +0100
changeset 55018 2a526bd279ed
parent 46822 95f1e700b712
child 58871 c399ae4b836f
permissions -rw-r--r--
moved 'Zorn' into 'Main', since it's a BNF dependency
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
     1
(*  Title:      ZF/Induct/Mutil.thy
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
     2
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
     3
    Copyright   1996  University of Cambridge
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
     4
*)
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
     5
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
     6
header {* The Mutilated Chess Board Problem, formalized inductively *}
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
     7
16417
9bc16273c2d4 migrated theory headers to new format
haftmann
parents: 12185
diff changeset
     8
theory Mutil imports Main begin
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
     9
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    10
text {*
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    11
  Originator is Max Black, according to J A Robinson.  Popularized as
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    12
  the Mutilated Checkerboard Problem by J McCarthy.
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    13
*}
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    14
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
    15
consts
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    16
  domino :: i
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    17
  tiling :: "i => i"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    18
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    19
inductive
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    20
  domains "domino" \<subseteq> "Pow(nat \<times> nat)"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    21
  intros
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    22
    horiz: "[| i \<in> nat;  j \<in> nat |] ==> {<i,j>, <i,succ(j)>} \<in> domino"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    23
    vertl: "[| i \<in> nat;  j \<in> nat |] ==> {<i,j>, <succ(i),j>} \<in> domino"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    24
  type_intros empty_subsetI cons_subsetI PowI SigmaI nat_succI
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
    25
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
    26
inductive
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    27
  domains "tiling(A)" \<subseteq> "Pow(\<Union>(A))"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    28
  intros
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    29
    empty: "0 \<in> tiling(A)"
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    30
    Un: "[| a \<in> A;  t \<in> tiling(A);  a \<inter> t = 0 |] ==> a \<union> t \<in> tiling(A)"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    31
  type_intros empty_subsetI Union_upper Un_least PowI
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    32
  type_elims PowD [elim_format]
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    33
24893
b8ef7afe3a6b modernized specifications;
wenzelm
parents: 18415
diff changeset
    34
definition
b8ef7afe3a6b modernized specifications;
wenzelm
parents: 18415
diff changeset
    35
  evnodd :: "[i, i] => i"  where
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    36
  "evnodd(A,b) == {z \<in> A. \<exists>i j. z = <i,j> \<and> (i #+ j) mod 2 = b}"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    37
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    38
12185
wenzelm
parents: 12173
diff changeset
    39
subsection {* Basic properties of evnodd *}
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    40
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    41
lemma evnodd_iff: "<i,j>: evnodd(A,b) \<longleftrightarrow> <i,j>: A & (i#+j) mod 2 = b"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    42
  by (unfold evnodd_def) blast
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    43
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    44
lemma evnodd_subset: "evnodd(A, b) \<subseteq> A"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    45
  by (unfold evnodd_def) blast
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    46
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    47
lemma Finite_evnodd: "Finite(X) ==> Finite(evnodd(X,b))"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    48
  by (rule lepoll_Finite, rule subset_imp_lepoll, rule evnodd_subset)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    49
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    50
lemma evnodd_Un: "evnodd(A \<union> B, b) = evnodd(A,b) \<union> evnodd(B,b)"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    51
  by (simp add: evnodd_def Collect_Un)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    52
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    53
lemma evnodd_Diff: "evnodd(A - B, b) = evnodd(A,b) - evnodd(B,b)"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    54
  by (simp add: evnodd_def Collect_Diff)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    55
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    56
lemma evnodd_cons [simp]:
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    57
  "evnodd(cons(<i,j>,C), b) =
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    58
    (if (i#+j) mod 2 = b then cons(<i,j>, evnodd(C,b)) else evnodd(C,b))"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    59
  by (simp add: evnodd_def Collect_cons)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    60
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    61
lemma evnodd_0 [simp]: "evnodd(0, b) = 0"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    62
  by (simp add: evnodd_def)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    63
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    64
12185
wenzelm
parents: 12173
diff changeset
    65
subsection {* Dominoes *}
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    66
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    67
lemma domino_Finite: "d \<in> domino ==> Finite(d)"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    68
  by (blast intro!: Finite_cons Finite_0 elim: domino.cases)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    69
12185
wenzelm
parents: 12173
diff changeset
    70
lemma domino_singleton:
wenzelm
parents: 12173
diff changeset
    71
    "[| d \<in> domino; b<2 |] ==> \<exists>i' j'. evnodd(d,b) = {<i',j'>}"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    72
  apply (erule domino.cases)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    73
   apply (rule_tac [2] k1 = "i#+j" in mod2_cases [THEN disjE])
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    74
     apply (rule_tac k1 = "i#+j" in mod2_cases [THEN disjE])
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    75
       apply (rule add_type | assumption)+
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    76
      (*Four similar cases: case (i#+j) mod 2 = b, 2#-b, ...*)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    77
      apply (auto simp add: mod_succ succ_neq_self dest: ltD)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    78
  done
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
    79
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
    80
12185
wenzelm
parents: 12173
diff changeset
    81
subsection {* Tilings *}
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    82
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    83
text {* The union of two disjoint tilings is a tiling *}
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    84
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    85
lemma tiling_UnI:
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    86
    "t \<in> tiling(A) ==> u \<in> tiling(A) ==> t \<inter> u = 0 ==> t \<union> u \<in> tiling(A)"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    87
  apply (induct set: tiling)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    88
   apply (simp add: tiling.intros)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    89
  apply (simp add: Un_assoc subset_empty_iff [THEN iff_sym])
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    90
  apply (blast intro: tiling.intros)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    91
  done
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    92
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    93
lemma tiling_domino_Finite: "t \<in> tiling(domino) ==> Finite(t)"
18415
eb68dc98bda2 improved proofs;
wenzelm
parents: 16417
diff changeset
    94
  apply (induct set: tiling)
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    95
   apply (rule Finite_0)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    96
  apply (blast intro!: Finite_Un intro: domino_Finite)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    97
  done
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    98
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
    99
lemma tiling_domino_0_1: "t \<in> tiling(domino) ==> |evnodd(t,0)| = |evnodd(t,1)|"
18415
eb68dc98bda2 improved proofs;
wenzelm
parents: 16417
diff changeset
   100
  apply (induct set: tiling)
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   101
   apply (simp add: evnodd_def)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   102
  apply (rule_tac b1 = 0 in domino_singleton [THEN exE])
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   103
    prefer 2
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   104
    apply simp
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   105
   apply assumption
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   106
  apply (rule_tac b1 = 1 in domino_singleton [THEN exE])
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   107
    prefer 2
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   108
    apply simp
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   109
   apply assumption
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   110
  apply safe
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
   111
  apply (subgoal_tac "\<forall>p b. p \<in> evnodd (a,b) \<longrightarrow> p\<notin>evnodd (t,b)")
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   112
   apply (simp add: evnodd_Un Un_cons tiling_domino_Finite
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   113
     evnodd_subset [THEN subset_Finite] Finite_imp_cardinal_cons)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   114
  apply (blast dest!: evnodd_subset [THEN subsetD] elim: equalityE)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   115
  done
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
   116
12185
wenzelm
parents: 12173
diff changeset
   117
lemma dominoes_tile_row:
wenzelm
parents: 12173
diff changeset
   118
    "[| i \<in> nat;  n \<in> nat |] ==> {i} * (n #+ n) \<in> tiling(domino)"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   119
  apply (induct_tac n)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   120
   apply (simp add: tiling.intros)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   121
  apply (simp add: Un_assoc [symmetric] Sigma_succ2)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   122
  apply (rule tiling.intros)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   123
    prefer 2 apply assumption
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   124
   apply (rename_tac n')
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   125
   apply (subgoal_tac (*seems the easiest way of turning one to the other*)
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
   126
     "{i}*{succ (n'#+n') } \<union> {i}*{n'#+n'} =
12185
wenzelm
parents: 12173
diff changeset
   127
       {<i,n'#+n'>, <i,succ (n'#+n') >}")
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   128
    prefer 2 apply blast
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   129
  apply (simp add: domino.horiz)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   130
  apply (blast elim: mem_irrefl mem_asym)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   131
  done
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   132
12185
wenzelm
parents: 12173
diff changeset
   133
lemma dominoes_tile_matrix:
wenzelm
parents: 12173
diff changeset
   134
    "[| m \<in> nat;  n \<in> nat |] ==> m * (n #+ n) \<in> tiling(domino)"
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   135
  apply (induct_tac m)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   136
   apply (simp add: tiling.intros)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   137
  apply (simp add: Sigma_succ1)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   138
  apply (blast intro: tiling_UnI dominoes_tile_row elim: mem_irrefl)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   139
  done
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   140
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   141
lemma eq_lt_E: "[| x=y; x<y |] ==> P"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   142
  by auto
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   143
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   144
theorem mutil_not_tiling: "[| m \<in> nat;  n \<in> nat;
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   145
         t = (succ(m)#+succ(m))*(succ(n)#+succ(n));
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   146
         t' = t - {<0,0>} - {<succ(m#+m), succ(n#+n)>} |]
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   147
      ==> t' \<notin> tiling(domino)"
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   148
  apply (rule notI)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   149
  apply (drule tiling_domino_0_1)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   150
  apply (erule_tac x = "|?A|" in eq_lt_E)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   151
  apply (subgoal_tac "t \<in> tiling (domino)")
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   152
   prefer 2 (*Requires a small simpset that won't move the succ applications*)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   153
   apply (simp only: nat_succI add_type dominoes_tile_matrix)
12185
wenzelm
parents: 12173
diff changeset
   154
  apply (simp add: evnodd_Diff mod2_add_self mod2_succ_succ
wenzelm
parents: 12173
diff changeset
   155
    tiling_domino_0_1 [symmetric])
12173
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   156
  apply (rule lt_trans)
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   157
   apply (rule Finite_imp_cardinal_Diff,
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   158
     simp add: tiling_domino_Finite Finite_evnodd Finite_Diff,
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   159
     simp add: evnodd_iff nat_0_le [THEN ltD] mod2_add_self)+
f3f7993ae6da converted;
wenzelm
parents: 12088
diff changeset
   160
  done
12088
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
   161
6f463d16cbd0 reorganization of the ZF examples
paulson
parents:
diff changeset
   162
end