src/HOL/Library/Size_Change_Termination.thy
author krauss
Wed, 28 Feb 2007 11:12:12 +0100
changeset 22371 c9f5895972b0
parent 22359 94a794672c8b
child 22375 823f7bee42df
permissions -rw-r--r--
added headers
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
22371
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
     1
(*  Title:      HOL/Library/Size_Change_Termination.thy
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
     2
    ID:         $Id$
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
     3
    Author:     Alexander Krauss, TU Muenchen
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
     4
*)
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
     5
22359
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
     6
theory Size_Change_Termination
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
     7
imports SCT_Theorem SCT_Interpretation SCT_Implementation 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
     8
uses "size_change_termination.ML"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
     9
begin
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    10
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    11
section {* Simplifier setup *}
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    12
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    13
text {* This is needed to run the SCT algorithm in the simplifier: *}
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    14
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    15
lemma setbcomp_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    16
  "{x\<in>{}. P x} = {}"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    17
  "{x\<in>insert y ys. P x} = (if P y then insert y {x\<in>ys. P x} else {x\<in>ys. P x})"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    18
  by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    19
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    20
lemma setbcomp_cong:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    21
  "A = B \<Longrightarrow> (\<And>x. P x = Q x) \<Longrightarrow> {x\<in>A. P x} = {x\<in>B. Q x}"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    22
  by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    23
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    24
lemma cartprod_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    25
  "{} \<times> A = {}"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    26
  "insert a A \<times> B = Pair a ` B \<union> (A \<times> B)"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    27
  by (auto simp:image_def)
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    28
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    29
lemma image_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    30
  "fu ` {} = {}"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    31
  "fu ` insert a A = insert (fu a) (fu ` A)"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    32
  by (auto simp:image_def)
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    33
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    34
lemmas union_simps = 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    35
  Un_empty_left Un_empty_right Un_insert_left
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    36
  
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    37
lemma subset_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    38
  "{} \<subseteq> B"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    39
  "insert a A \<subseteq> B \<equiv> a \<in> B \<and> A \<subseteq> B"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    40
  by auto 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    41
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    42
lemma element_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    43
  "x \<in> {} \<equiv> False"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    44
  "x \<in> insert a A \<equiv> x = a \<or> x \<in> A"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    45
  by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    46
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    47
lemma set_eq_simp:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    48
  "A = B \<longleftrightarrow> A \<subseteq> B \<and> B \<subseteq> A" by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    49
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    50
lemma ball_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    51
  "\<forall>x\<in>{}. P x \<equiv> True"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    52
  "(\<forall>x\<in>insert a A. P x) \<equiv> P a \<and> (\<forall>x\<in>A. P x)"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    53
by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    54
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    55
lemma bex_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    56
  "\<exists>x\<in>{}. P x \<equiv> False"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    57
  "(\<exists>x\<in>insert a A. P x) \<equiv> P a \<or> (\<exists>x\<in>A. P x)"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    58
by auto
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    59
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    60
lemmas set_simps =
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    61
  setbcomp_simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    62
  cartprod_simps image_simps union_simps subset_simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    63
  element_simps set_eq_simp
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    64
  ball_simps bex_simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    65
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    66
lemma sedge_simps:
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    67
  "\<down> * x = \<down>"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    68
  "\<Down> * x = x"
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    69
  by (auto simp:mult_sedge_def)
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    70
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    71
lemmas sctTest_simps =
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    72
  simp_thms
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    73
  if_True
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    74
  if_False
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    75
  nat.inject
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    76
  nat.distinct
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    77
  Pair_eq 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    78
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    79
  grcomp_code 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    80
  edges_match.simps 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    81
  connect_edges.simps 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    82
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    83
  sedge_simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    84
  sedge.distinct
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    85
  set_simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    86
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    87
  graph_mult_def 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    88
  graph_leq_def
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    89
  dest_graph.simps
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    90
  graph_plus_def
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    91
  graph.inject
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    92
  graph_zero_def
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    93
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    94
  test_SCT_def
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    95
  mk_tcl_code
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    96
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    97
  Let_def
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    98
  split_conv
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
    99
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
   100
lemmas sctTest_congs = 
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
   101
  if_weak_cong let_weak_cong setbcomp_cong
94a794672c8b Added formalization of size-change principle (experimental).
krauss
parents:
diff changeset
   102
22371
c9f5895972b0 added headers
krauss
parents: 22359
diff changeset
   103
end