-
Notifications
You must be signed in to change notification settings - Fork 108
/
Copy pathGeneric_Separation_Algebras.thy
98 lines (74 loc) · 2.94 KB
/
Generic_Separation_Algebras.thy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
(*
* Copyright 2020, Data61, CSIRO (ABN 41 687 119 230)
*
* SPDX-License-Identifier: BSD-2-Clause
*)
theory Generic_Separation_Algebras
imports Sep_Algebra_L4v
begin
instantiation "prod" :: (stronger_sep_algebra,stronger_sep_algebra) zero
begin
definition "zero_prod \<equiv> (0,0)"
instance ..
end
instantiation "prod" :: (stronger_sep_algebra,stronger_sep_algebra) stronger_sep_algebra
begin
definition "sep_disj_prod x y \<equiv> sep_disj (fst x) (fst y) \<and> sep_disj (snd x) (snd y)"
definition "plus_prod x y \<equiv> ( (fst x) + (fst y) , (snd x) + (snd y))"
instance
apply intro_classes
apply (metis fst_conv sep_disj_prod_def sep_disj_zero snd_conv zero_prod_def)
apply (metis (full_types) sep_disj_commuteI sep_disj_prod_def)
apply (clarsimp simp: plus_prod_def zero_prod_def)
apply (clarsimp simp: plus_prod_def sep_disj_prod_def)
apply safe
apply (metis sep_add_commute)
apply (metis sep_add_commute)
apply (clarsimp simp: plus_prod_def sep_disj_prod_def)
apply (metis sep_add_assoc)
apply (clarsimp simp: plus_prod_def sep_disj_prod_def)
apply (clarsimp simp: plus_prod_def sep_disj_prod_def)
apply (clarsimp simp: plus_prod_def sep_disj_prod_def)
done
end
instantiation "option" :: (type) zero
begin
definition "zero_option \<equiv> None"
instance ..
end
definition
orelse :: "'a option \<Rightarrow> 'a option \<Rightarrow> 'a option"
where
"orelse x y \<equiv> case x of Some x' => Some x' | None => y"
definition
onlyone :: "'a option => 'a option => bool"
where
"onlyone x y \<equiv> case x of
Some x' => (case y of Some y' => False | _ => True)
| None => True"
instantiation "option" :: (type) stronger_sep_algebra
begin
definition "sep_disj_option \<equiv> onlyone "
definition "plus_option \<equiv> orelse"
instance
by intro_classes
(clarsimp simp: sep_disj_option_def zero_option_def plus_option_def onlyone_def orelse_def
split: option.splits)+
end
record 'a generic_heap_record =
heap :: "'a "
instantiation "generic_heap_record_ext" :: (stronger_sep_algebra, stronger_sep_algebra) stronger_sep_algebra
begin
definition "zero_generic_heap_record_ext \<equiv> Abs_generic_heap_record_ext 0"
definition "plus_generic_heap_record_ext h1 h2 \<equiv>
Abs_generic_heap_record_ext (Rep_generic_heap_record_ext h1 + Rep_generic_heap_record_ext h2)"
definition "sep_disj_generic_heap_record_ext h1 h2 \<equiv> Rep_generic_heap_record_ext h1 ## Rep_generic_heap_record_ext h2"
instance
apply intro_classes
apply (fastforce simp: sep_add_left_commute sep_disj_commute Rep_generic_heap_record_ext_inverse
sep_disj_commuteI sep_add_assoc sep_add_commute Abs_generic_heap_record_ext_inverse
zero_generic_heap_record_ext_def sep_disj_generic_heap_record_ext_def
plus_generic_heap_record_ext_def)+
done
end
end