src/HOL/Library/Transitive_Closure_Table.thy
author wenzelm
Fri, 14 Oct 2016 21:35:02 +0200
changeset 64215 123e6dcd3852
parent 62390 842917225d56
child 64632 9df24b8b6c0a
permissions -rw-r--r--
cronjob: build release from repository snapshot;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
     1
(*  Author: Stefan Berghofer, Lukas Bulwahn, TU Muenchen  *)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     2
60500
903bb1495239 isabelle update_cartouches;
wenzelm
parents: 58881
diff changeset
     3
section \<open>A table-based implementation of the reflexive transitive closure\<close>
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     4
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     5
theory Transitive_Closure_Table
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     6
imports Main
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     7
begin
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     8
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
     9
inductive rtrancl_path :: "('a \<Rightarrow> 'a \<Rightarrow> bool) \<Rightarrow> 'a \<Rightarrow> 'a list \<Rightarrow> 'a \<Rightarrow> bool"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    10
  for r :: "'a \<Rightarrow> 'a \<Rightarrow> bool"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    11
where
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    12
  base: "rtrancl_path r x [] x"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    13
| step: "r x y \<Longrightarrow> rtrancl_path r y ys z \<Longrightarrow> rtrancl_path r x (y # ys) z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    14
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    15
lemma rtranclp_eq_rtrancl_path: "r\<^sup>*\<^sup>* x y \<longleftrightarrow> (\<exists>xs. rtrancl_path r x xs y)"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    16
proof
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    17
  show "\<exists>xs. rtrancl_path r x xs y" if "r\<^sup>*\<^sup>* x y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    18
    using that
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    19
  proof (induct rule: converse_rtranclp_induct)
34912
c04747153bcf Changed case names of converse_rtranclp_induct.
berghofe
parents: 33870
diff changeset
    20
    case base
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    21
    have "rtrancl_path r y [] y" by (rule rtrancl_path.base)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    22
    then show ?case ..
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    23
  next
34912
c04747153bcf Changed case names of converse_rtranclp_induct.
berghofe
parents: 33870
diff changeset
    24
    case (step x z)
60500
903bb1495239 isabelle update_cartouches;
wenzelm
parents: 58881
diff changeset
    25
    from \<open>\<exists>xs. rtrancl_path r z xs y\<close>
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    26
    obtain xs where "rtrancl_path r z xs y" ..
60500
903bb1495239 isabelle update_cartouches;
wenzelm
parents: 58881
diff changeset
    27
    with \<open>r x z\<close> have "rtrancl_path r x (z # xs) y"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    28
      by (rule rtrancl_path.step)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    29
    then show ?case ..
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    30
  qed
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    31
  show "r\<^sup>*\<^sup>* x y" if "\<exists>xs. rtrancl_path r x xs y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    32
  proof -
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    33
    from that obtain xs where "rtrancl_path r x xs y" ..
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    34
    then show ?thesis
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    35
    proof induct
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    36
      case (base x)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    37
      show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    38
        by (rule rtranclp.rtrancl_refl)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    39
    next
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    40
      case (step x y ys z)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    41
      from \<open>r x y\<close> \<open>r\<^sup>*\<^sup>* y z\<close> show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    42
        by (rule converse_rtranclp_into_rtranclp)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    43
    qed
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    44
  qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    45
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    46
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    47
lemma rtrancl_path_trans:
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    48
  assumes xy: "rtrancl_path r x xs y"
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    49
    and yz: "rtrancl_path r y ys z"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    50
  shows "rtrancl_path r x (xs @ ys) z" using xy yz
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    51
proof (induct arbitrary: z)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    52
  case (base x)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    53
  then show ?case by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    54
next
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    55
  case (step x y xs)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    56
  then have "rtrancl_path r y (xs @ ys) z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    57
    by simp
60500
903bb1495239 isabelle update_cartouches;
wenzelm
parents: 58881
diff changeset
    58
  with \<open>r x y\<close> have "rtrancl_path r x (y # (xs @ ys)) z"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    59
    by (rule rtrancl_path.step)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    60
  then show ?case by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    61
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    62
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    63
lemma rtrancl_path_appendE:
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    64
  assumes xz: "rtrancl_path r x (xs @ y # ys) z"
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    65
  obtains "rtrancl_path r x (xs @ [y]) y" and "rtrancl_path r y ys z"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    66
  using xz
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    67
proof (induct xs arbitrary: x)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    68
  case Nil
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    69
  then have "rtrancl_path r x (y # ys) z" by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    70
  then obtain xy: "r x y" and yz: "rtrancl_path r y ys z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    71
    by cases auto
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    72
  from xy have "rtrancl_path r x [y] y"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    73
    by (rule rtrancl_path.step [OF _ rtrancl_path.base])
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    74
  then have "rtrancl_path r x ([] @ [y]) y" by simp
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    75
  then show thesis using yz by (rule Nil)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    76
next
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    77
  case (Cons a as)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    78
  then have "rtrancl_path r x (a # (as @ y # ys)) z" by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    79
  then obtain xa: "r x a" and az: "rtrancl_path r a (as @ y # ys) z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    80
    by cases auto
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    81
  show thesis
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    82
  proof (rule Cons(1) [OF _ az])
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    83
    assume "rtrancl_path r y ys z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    84
    assume "rtrancl_path r a (as @ [y]) y"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    85
    with xa have "rtrancl_path r x (a # (as @ [y])) y"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    86
      by (rule rtrancl_path.step)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    87
    then have "rtrancl_path r x ((a # as) @ [y]) y"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    88
      by simp
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    89
    then show thesis using \<open>rtrancl_path r y ys z\<close>
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    90
      by (rule Cons(2))
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    91
  qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    92
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    93
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    94
lemma rtrancl_path_distinct:
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    95
  assumes xy: "rtrancl_path r x xs y"
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
    96
  obtains xs' where "rtrancl_path r x xs' y" and "distinct (x # xs')" and "set xs' \<subseteq> set xs"
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
    97
  using xy
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    98
proof (induct xs rule: measure_induct_rule [of length])
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
    99
  case (less xs)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   100
  show ?case
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   101
  proof (cases "distinct (x # xs)")
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   102
    case True
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
   103
    with \<open>rtrancl_path r x xs y\<close> show ?thesis by (rule less) simp
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   104
  next
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   105
    case False
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   106
    then have "\<exists>as bs cs a. x # xs = as @ [a] @ bs @ [a] @ cs"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   107
      by (rule not_distinct_decomp)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   108
    then obtain as bs cs a where xxs: "x # xs = as @ [a] @ bs @ [a] @ cs"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   109
      by iprover
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   110
    show ?thesis
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   111
    proof (cases as)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   112
      case Nil
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   113
      with xxs have x: "x = a" and xs: "xs = bs @ a # cs"
35423
6ef9525a5727 eliminated hard tabs;
wenzelm
parents: 34912
diff changeset
   114
        by auto
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
   115
      from x xs \<open>rtrancl_path r x xs y\<close> have cs: "rtrancl_path r x cs y" "set cs \<subseteq> set xs"
35423
6ef9525a5727 eliminated hard tabs;
wenzelm
parents: 34912
diff changeset
   116
        by (auto elim: rtrancl_path_appendE)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   117
      from xs have "length cs < length xs" by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   118
      then show ?thesis
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
   119
        by (rule less(1))(blast intro: cs less(2) order_trans del: subsetI)+
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   120
    next
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   121
      case (Cons d ds)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   122
      with xxs have xs: "xs = ds @ a # (bs @ [a] @ cs)"
35423
6ef9525a5727 eliminated hard tabs;
wenzelm
parents: 34912
diff changeset
   123
        by auto
60500
903bb1495239 isabelle update_cartouches;
wenzelm
parents: 58881
diff changeset
   124
      with \<open>rtrancl_path r x xs y\<close> obtain xa: "rtrancl_path r x (ds @ [a]) a"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   125
        and ay: "rtrancl_path r a (bs @ a # cs) y"
35423
6ef9525a5727 eliminated hard tabs;
wenzelm
parents: 34912
diff changeset
   126
        by (auto elim: rtrancl_path_appendE)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   127
      from ay have "rtrancl_path r a cs y" by (auto elim: rtrancl_path_appendE)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   128
      with xa have xy: "rtrancl_path r x ((ds @ [a]) @ cs) y"
35423
6ef9525a5727 eliminated hard tabs;
wenzelm
parents: 34912
diff changeset
   129
        by (rule rtrancl_path_trans)
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
   130
      from xs have set: "set ((ds @ [a]) @ cs) \<subseteq> set xs" by auto
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   131
      from xs have "length ((ds @ [a]) @ cs) < length xs" by simp
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   132
      then show ?thesis
61764
ac6e5de1a50b strengthen lemma
Andreas Lochbihler
parents: 60519
diff changeset
   133
        by (rule less(1))(blast intro: xy less(2) set[THEN subsetD])+
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   134
    qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   135
  qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   136
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   137
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   138
inductive rtrancl_tab :: "('a \<Rightarrow> 'a \<Rightarrow> bool) \<Rightarrow> 'a list \<Rightarrow> 'a \<Rightarrow> 'a \<Rightarrow> bool"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   139
  for r :: "'a \<Rightarrow> 'a \<Rightarrow> bool"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   140
where
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   141
  base: "rtrancl_tab r xs x x"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   142
| step: "x \<notin> set xs \<Longrightarrow> r x y \<Longrightarrow> rtrancl_tab r (x # xs) y z \<Longrightarrow> rtrancl_tab r xs x z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   143
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   144
lemma rtrancl_path_imp_rtrancl_tab:
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   145
  assumes path: "rtrancl_path r x xs y"
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   146
    and x: "distinct (x # xs)"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   147
    and ys: "({x} \<union> set xs) \<inter> set ys = {}"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   148
  shows "rtrancl_tab r ys x y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   149
  using path x ys
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   150
proof (induct arbitrary: ys)
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   151
  case base
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   152
  show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   153
    by (rule rtrancl_tab.base)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   154
next
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   155
  case (step x y zs z)
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   156
  then have "x \<notin> set ys"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   157
    by auto
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   158
  from step have "distinct (y # zs)"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   159
    by simp
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   160
  moreover from step have "({y} \<union> set zs) \<inter> set (x # ys) = {}"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   161
    by auto
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   162
  ultimately have "rtrancl_tab r (x # ys) y z"
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   163
    by (rule step)
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   164
  with \<open>x \<notin> set ys\<close> \<open>r x y\<close> show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   165
    by (rule rtrancl_tab.step)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   166
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   167
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   168
lemma rtrancl_tab_imp_rtrancl_path:
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   169
  assumes tab: "rtrancl_tab r ys x y"
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   170
  obtains xs where "rtrancl_path r x xs y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   171
  using tab
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   172
proof induct
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   173
  case base
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   174
  from rtrancl_path.base show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   175
    by (rule base)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   176
next
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   177
  case step
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   178
  show ?case
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   179
    by (iprover intro: step rtrancl_path.step)
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   180
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   181
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   182
lemma rtranclp_eq_rtrancl_tab_nil: "r\<^sup>*\<^sup>* x y \<longleftrightarrow> rtrancl_tab r [] x y"
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   183
proof
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   184
  show "rtrancl_tab r [] x y" if "r\<^sup>*\<^sup>* x y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   185
  proof -
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   186
    from that obtain xs where "rtrancl_path r x xs y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   187
      by (auto simp add: rtranclp_eq_rtrancl_path)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   188
    then obtain xs' where xs': "rtrancl_path r x xs' y" and distinct: "distinct (x # xs')"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   189
      by (rule rtrancl_path_distinct)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   190
    have "({x} \<union> set xs') \<inter> set [] = {}"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   191
      by simp
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   192
    with xs' distinct show ?thesis
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   193
      by (rule rtrancl_path_imp_rtrancl_tab)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   194
  qed
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   195
  show "r\<^sup>*\<^sup>* x y" if "rtrancl_tab r [] x y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   196
  proof -
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   197
    from that obtain xs where "rtrancl_path r x xs y"
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   198
      by (rule rtrancl_tab_imp_rtrancl_path)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   199
    then show ?thesis
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   200
      by (auto simp add: rtranclp_eq_rtrancl_path)
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   201
  qed
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   202
qed
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   203
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   204
declare rtranclp_rtrancl_eq [code del]
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   205
declare rtranclp_eq_rtrancl_tab_nil [THEN iffD2, code_pred_intro]
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   206
60519
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   207
code_pred rtranclp
84b8e5c2580e tuned proofs;
wenzelm
parents: 60500
diff changeset
   208
  using rtranclp_eq_rtrancl_tab_nil [THEN iffD1] by fastforce
33649
854173fcd21c added a tabled implementation of the reflexive transitive closure
bulwahn
parents:
diff changeset
   209
61765
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   210
lemma rtrancl_path_Range: "\<lbrakk> rtrancl_path R x xs y; z \<in> set xs \<rbrakk> \<Longrightarrow> RangeP R z"
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   211
by(induction rule: rtrancl_path.induct) auto
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   212
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   213
lemma rtrancl_path_Range_end: "\<lbrakk> rtrancl_path R x xs y; xs \<noteq> [] \<rbrakk> \<Longrightarrow> RangeP R y"
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   214
by(induction rule: rtrancl_path.induct)(auto elim: rtrancl_path.cases)
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   215
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   216
lemma rtrancl_path_nth:
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   217
  "\<lbrakk> rtrancl_path R x xs y; i < length xs \<rbrakk> \<Longrightarrow> R ((x # xs) ! i) (xs ! i)"
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   218
proof(induction arbitrary: i rule: rtrancl_path.induct)
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   219
  case step thus ?case by(cases i) simp_all
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   220
qed simp
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   221
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   222
lemma rtrancl_path_last: "\<lbrakk> rtrancl_path R x xs y; xs \<noteq> [] \<rbrakk> \<Longrightarrow> last xs = y"
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   223
by(induction rule: rtrancl_path.induct)(auto elim: rtrancl_path.cases)
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   224
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   225
lemma rtrancl_path_mono:
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   226
  "\<lbrakk> rtrancl_path R x p y; \<And>x y. R x y \<Longrightarrow> S x y \<rbrakk> \<Longrightarrow> rtrancl_path S x p y"
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   227
by(induction rule: rtrancl_path.induct)(auto intro: rtrancl_path.intros)
13ca8f4f6907 add lemmas
Andreas Lochbihler
parents: 61764
diff changeset
   228
62390
842917225d56 more canonical names
nipkow
parents: 61765
diff changeset
   229
end