Skip to content

Commit

Permalink
lib/monads/trace: prove more lemmas connecting valid and validI
Browse files Browse the repository at this point in the history
Signed-off-by: Corey Lewis <[email protected]>
  • Loading branch information
corlewis committed Sep 29, 2023
1 parent fa5c46a commit 7390538
Showing 1 changed file with 35 additions and 2 deletions.
37 changes: 35 additions & 2 deletions lib/Monads/trace/Trace_RG.thy
Original file line number Diff line number Diff line change
Expand Up @@ -235,6 +235,14 @@ lemma last_st_tr_Cons[simp]:
"last_st_tr (x # xs) s = snd x"
by (simp add: last_st_tr_def)

lemma no_trace_last_st_tr:
"\<lbrakk>no_trace f; (tr, res) \<in> f s\<rbrakk> \<Longrightarrow> last_st_tr tr s0 = s0"
by (fastforce simp: no_trace_def)

lemma no_trace_rely_cond:
"\<lbrakk>no_trace f; (tr, res) \<in> f s\<rbrakk> \<Longrightarrow> rely_cond R s0 tr"
by (fastforce simp: no_trace_def rely_cond_def)

lemma bind_twp[wp_split]:
"\<lbrakk> \<And>r. \<lbrace>Q' r\<rbrace>,\<lbrace>R\<rbrace> g r \<lbrace>G\<rbrace>,\<lbrace>Q\<rbrace>; \<lbrace>P\<rbrace>,\<lbrace>R\<rbrace> f \<lbrace>G\<rbrace>,\<lbrace>Q'\<rbrace> \<rbrakk>
\<Longrightarrow> \<lbrace>P\<rbrace>,\<lbrace>R\<rbrace> f >>= (\<lambda>r. g r) \<lbrace>G\<rbrace>,\<lbrace>Q\<rbrace>"
Expand Down Expand Up @@ -532,11 +540,19 @@ lemma no_trace_prefix_closed:
"no_trace f \<Longrightarrow> prefix_closed f"
by (auto simp add: prefix_closed_def dest: no_trace_emp)

lemma validI_valid_no_trace_eq:
"no_trace f \<Longrightarrow> \<lbrace>P\<rbrace>,\<lbrace>R\<rbrace> f \<lbrace>G\<rbrace>,\<lbrace>Q\<rbrace> = (\<forall>s0. \<lbrace>P s0\<rbrace> f \<lbrace>\<lambda>v. Q v s0\<rbrace>)"
apply (rule iffI)
apply (fastforce simp: rely_def validI_def valid_def mres_def
dest: no_trace_emp)
apply (clarsimp simp: rely_def validI_def valid_def mres_def no_trace_prefix_closed)
apply (fastforce simp: eq_snd_iff dest: no_trace_emp)
done

lemma valid_validI_wp[wp_comb]:
"\<lbrakk>no_trace f; \<And>s0. \<lbrace>P s0\<rbrace> f \<lbrace>\<lambda>v. Q v s0 \<rbrace>\<rbrakk>
\<Longrightarrow> \<lbrace>P\<rbrace>,\<lbrace>R\<rbrace> f \<lbrace>G\<rbrace>,\<lbrace>Q\<rbrace>"
by (fastforce simp: rely_def validI_def valid_def mres_def no_trace_prefix_closed dest: no_trace_emp
elim: image_eqI[rotated])
by (clarsimp simp: validI_valid_no_trace_eq)


lemma env_steps_twp[wp]:
Expand Down Expand Up @@ -725,4 +741,21 @@ lemma repeat_prefix_closed[intro!]:
apply (auto intro: prefix_closed_bind)
done

lemma rely_cond_True[simp]:
"rely_cond \<top>\<top> s0 tr = True"
by (clarsimp simp: rely_cond_def)

lemma guar_cond_True[simp]:
"guar_cond \<top>\<top> s0 tr = True"
by (clarsimp simp: guar_cond_def)

lemma validI_valid_wp:
"\<lbrakk>\<lbrace>P\<rbrace>,\<lbrace>\<top>\<top>\<rbrace> f \<lbrace>G\<rbrace>,\<lbrace>\<lambda>rv _ s. Q rv s\<rbrace>\<rbrakk>
\<Longrightarrow> \<lbrace>P s0\<rbrace> f \<lbrace>Q\<rbrace>"
by (auto simp: rely_def validI_def valid_def mres_def)

lemma validI_triv_valid_eq:
"prefix_closed f \<Longrightarrow> \<lbrace>P\<rbrace>,\<lbrace>\<top>\<top>\<rbrace> f \<lbrace>\<top>\<top>\<rbrace>,\<lbrace>\<lambda>rv _ s. Q rv s\<rbrace> = (\<forall>s0. \<lbrace>\<lambda>s. P s0 s\<rbrace> f \<lbrace>Q\<rbrace>)"
by (fastforce simp: rely_def validI_def valid_def mres_def image_def)

end

0 comments on commit 7390538

Please sign in to comment.