src/HOL/Library/Rewrite.thy
author noschinl
Mon, 13 Apr 2015 20:11:12 +0200
changeset 60054 ef4878146485
parent 60047 58e5b16cbd94
child 61383 6762c8445138
permissions -rw-r--r--
rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59975
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     1
(*  Title:      HOL/Library/Rewrite.thy
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     2
    Author:     Christoph Traut, Lars Noschinski, TU Muenchen
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     3
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     4
Proof method "rewrite" with support for subterm-selection based on patterns.
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     5
*)
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
     6
59739
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
     7
theory Rewrite
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
     8
imports Main
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
     9
begin
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    10
59975
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
    11
consts rewrite_HOLE :: "'a::{}"
59739
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    12
notation rewrite_HOLE ("HOLE")
60047
58e5b16cbd94 enable \<hole> syntax for rewrite
noschinl
parents: 59975
diff changeset
    13
notation rewrite_HOLE ("\<hole>")
59739
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    14
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    15
lemma eta_expand:
59975
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
    16
  fixes f :: "'a::{} \<Rightarrow> 'b::{}"
da10875adf8e more standard Isabelle/ML tool setup;
wenzelm
parents: 59739
diff changeset
    17
  shows "f \<equiv> \<lambda>x. f x" .
59739
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    18
60054
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    19
lemma rewr_imp:
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    20
  assumes "PROP A \<equiv> PROP B"
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    21
  shows "(PROP A \<Longrightarrow> PROP C) \<equiv> (PROP B \<Longrightarrow> PROP C)"
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    22
  apply (rule Pure.equal_intr_rule)
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    23
  apply (drule equal_elim_rule2[OF assms]; assumption)
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    24
  apply (drule equal_elim_rule1[OF assms]; assumption)
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    25
  done
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    26
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    27
lemma imp_cong_eq:
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    28
  "(PROP A \<Longrightarrow> (PROP B \<Longrightarrow> PROP C) \<equiv> (PROP B' \<Longrightarrow> PROP C')) \<equiv> ((PROP B \<Longrightarrow> PROP A \<Longrightarrow> PROP C) \<equiv> (PROP B' \<Longrightarrow> PROP A \<Longrightarrow> PROP C'))"
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    29
  apply (intro Pure.equal_intr_rule)
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    30
     apply (drule (1) cut_rl; drule Pure.equal_elim_rule1 Pure.equal_elim_rule2; assumption)+
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    31
   apply (drule Pure.equal_elim_rule1 Pure.equal_elim_rule2; assumption)+
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    32
  done
ef4878146485 rewrite: with asm pattern, propagate also remaining assumptions to new subgoals
noschinl
parents: 60047
diff changeset
    33
59739
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    34
ML_file "cconv.ML"
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    35
ML_file "rewrite.ML"
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    36
4ed50ebf5d36 added proof method rewrite
noschinl
parents:
diff changeset
    37
end