diff -r b505be6f029a -r 686fa0a0696e src/HOL/IMP/Def_Ass_Sound_Big.thy --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/HOL/IMP/Def_Ass_Sound_Big.thy Mon Jun 06 16:29:38 2011 +0200 @@ -0,0 +1,41 @@ +(* Author: Tobias Nipkow *) + +theory Def_Ass_Sound_Big imports Def_Ass Def_Ass_Big +begin + + +subsection "Soundness wrt Big Steps" + +text{* Note the special form of the induction because one of the arguments +of the inductive predicate is not a variable but the term @{term"Some s"}: *} + +theorem Sound: + "\ (c,Some s) \ s'; D A c A'; A \ dom s \ + \ \ t. s' = Some t \ A' \ dom t" +proof (induct c "Some s" s' arbitrary: s A A' rule:big_step_induct) + case AssignNone thus ?case + by auto (metis aval_Some option.simps(3) subset_trans) +next + case Semi thus ?case by auto metis +next + case IfTrue thus ?case by auto blast +next + case IfFalse thus ?case by auto blast +next + case IfNone thus ?case + by auto (metis bval_Some option.simps(3) order_trans) +next + case WhileNone thus ?case + by auto (metis bval_Some option.simps(3) order_trans) +next + case (WhileTrue b s c s' s'') + from `D A (WHILE b DO c) A'` obtain A' where "D A c A'" by blast + then obtain t' where "s' = Some t'" "A \ dom t'" + by (metis D_incr WhileTrue(3,7) subset_trans) + from WhileTrue(5)[OF this(1) WhileTrue(6) this(2)] show ?case . +qed auto + +corollary sound: "\ D (dom s) c A'; (c,Some s) \ s' \ \ s' \ None" +by (metis Sound not_Some_eq subset_refl) + +end