src/LCF/ex/Ex3.thy
author wenzelm
Sun, 25 Nov 2012 18:47:33 +0100
changeset 50199 6d04e2422769
parent 47025 b2b8ae61d6ad
child 58889 5b7a9633cfa8
permissions -rw-r--r--
quasi-abstract module Rendering, with Isabelle-specific implementation;

header {* Addition with fixpoint of successor *}

theory Ex3
imports LCF
begin

axiomatization
  s     :: "'a => 'a" and
  p     :: "'a => 'a => 'a"
where
  p_strict:     "p(UU) = UU" and
  p_s:          "p(s(x),y) = s(p(x,y))"

declare p_strict [simp] p_s [simp]

lemma example: "p(FIX(s),y) = FIX(s)"
  apply (tactic {* induct_tac @{context} "s" 1 *})
  apply simp
  apply simp
  done

end