Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
ReLoC
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Model registry
Operate
Environments
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Iris
ReLoC
Commits
0c77ba26
Commit
0c77ba26
authored
6 years ago
by
Dan Frumin
Browse files
Options
Downloads
Patches
Plain Diff
solve_proper_from_ne tactic
parent
80ec05b7
No related branches found
No related tags found
No related merge requests found
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
_CoqProject
+1
-0
1 addition, 0 deletions
_CoqProject
theories/logic/model.v
+10
-42
10 additions, 42 deletions
theories/logic/model.v
theories/prelude/tactics.v
+18
-0
18 additions, 0 deletions
theories/prelude/tactics.v
with
29 additions
and
42 deletions
_CoqProject
+
1
−
0
View file @
0c77ba26
-Q theories reloc
-Q theories reloc
-arg -w -arg -notation-overridden,-redundant-canonical-projection,-several-object-files
-arg -w -arg -notation-overridden,-redundant-canonical-projection,-several-object-files
theories/prelude/ctx_subst.v
theories/prelude/ctx_subst.v
theories/prelude/tactics.v
theories/logic/spec_ra.v
theories/logic/spec_ra.v
theories/logic/spec_rules.v
theories/logic/spec_rules.v
theories/logic/model.v
theories/logic/model.v
...
...
This diff is collapsed.
Click to expand it.
theories/logic/model.v
+
10
−
42
View file @
0c77ba26
...
@@ -7,7 +7,7 @@ From iris.heap_lang Require Export lifting metatheory.
...
@@ -7,7 +7,7 @@ From iris.heap_lang Require Export lifting metatheory.
From
iris
.
base_logic
.
lib
Require
Import
invariants
.
From
iris
.
base_logic
.
lib
Require
Import
invariants
.
From
iris
.
algebra
Require
Import
list
gmap
.
From
iris
.
algebra
Require
Import
list
gmap
.
From
iris
.
heap_lang
Require
Import
notation
proofmode
.
From
iris
.
heap_lang
Require
Import
notation
proofmode
.
From
reloc
Require
Import
logic
.
spec_rules
prelude
.
ctx_subst
.
From
reloc
Require
Import
prelude
.
tactics
logic
.
spec_rules
prelude
.
ctx_subst
.
From
reloc
Require
Export
logic
.
spec_ra
.
From
reloc
Require
Export
logic
.
spec_ra
.
(** Semantic intepretation of types *)
(** Semantic intepretation of types *)
...
@@ -46,7 +46,7 @@ Section lty2_ofe.
...
@@ -46,7 +46,7 @@ Section lty2_ofe.
Global
Instance
lty2_car_ne
n
:
Proper
(
dist
n
==>
(
=
)
==>
(
=
)
==>
dist
n
)
lty2_car
.
Global
Instance
lty2_car_ne
n
:
Proper
(
dist
n
==>
(
=
)
==>
(
=
)
==>
dist
n
)
lty2_car
.
Proof
.
by
intros
A
A'
?
w1
w2
<-
?
?
<-.
Qed
.
Proof
.
by
intros
A
A'
?
w1
w2
<-
?
?
<-.
Qed
.
Global
Instance
lty2_car_proper
:
Proper
((
≡
)
==>
(
=
)
==>
(
=
)
==>
(
≡
))
lty2_car
.
Global
Instance
lty2_car_proper
:
Proper
((
≡
)
==>
(
=
)
==>
(
=
)
==>
(
≡
))
lty2_car
.
Proof
.
by
intros
A
A'
?
w1
w2
<-
?
?
<-
.
Qed
.
Proof
.
solve_proper_from_ne
.
Qed
.
End
lty2_ofe
.
End
lty2_ofe
.
Section
semtypes
.
Section
semtypes
.
...
@@ -65,7 +65,7 @@ Section semtypes.
...
@@ -65,7 +65,7 @@ Section semtypes.
Global
Instance
interp_expr_proper
E
e
e'
:
Global
Instance
interp_expr_proper
E
e
e'
:
Proper
((
≡
)
==>
(
≡
))
(
interp_expr
E
e
e'
)
.
Proper
((
≡
)
==>
(
≡
))
(
interp_expr
E
e
e'
)
.
Proof
.
apply
ne_proper
=>
n
.
by
apply
interp_expr_ne
.
Qed
.
Proof
.
apply
ne_proper
=>
n
.
apply
_
.
Qed
.
Definition
lty2_unit
:
lty2
:=
Lty2
(
λ
w1
w2
,
⌜
w1
=
#
()
∧
w2
=
#
()
⌝%
I
)
.
Definition
lty2_unit
:
lty2
:=
Lty2
(
λ
w1
w2
,
⌜
w1
=
#
()
∧
w2
=
#
()
⌝%
I
)
.
Definition
lty2_bool
:
lty2
:=
Lty2
(
λ
w1
w2
,
∃
b
:
bool
,
⌜
w1
=
#
b
∧
w2
=
#
b
⌝
)
%
I
.
Definition
lty2_bool
:
lty2
:=
Lty2
(
λ
w1
w2
,
∃
b
:
bool
,
⌜
w1
=
#
b
∧
w2
=
#
b
⌝
)
%
I
.
...
@@ -185,7 +185,7 @@ Instance option_mbind_ne {A B : ofeT} n :
...
@@ -185,7 +185,7 @@ Instance option_mbind_ne {A B : ofeT} n :
Proper
(((
dist
n
)
==>
(
dist
n
))
==>
(
dist
n
)
==>
(
dist
n
))
(
@
option_bind
A
B
)
.
Proper
(((
dist
n
)
==>
(
dist
n
))
==>
(
dist
n
)
==>
(
dist
n
))
(
@
option_bind
A
B
)
.
Proof
.
destruct
2
;
simpl
;
try
constructor
;
auto
.
Qed
.
Proof
.
destruct
2
;
simpl
;
try
constructor
;
auto
.
Qed
.
(** todo
generaliz
e *)
(** todo
move somewher
e *)
Instance
map_zip_with_ne
{
K
}
{
A
B
C
:
ofeT
}
(
f
:
A
→
B
→
C
)
Instance
map_zip_with_ne
{
K
}
{
A
B
C
:
ofeT
}
(
f
:
A
→
B
→
C
)
`{
Countable
K
}
`{
!
EqDecision
K
}
n
:
`{
Countable
K
}
`{
!
EqDecision
K
}
n
:
Proper
(
dist
n
==>
dist
n
==>
dist
n
)
f
→
Proper
(
dist
n
==>
dist
n
==>
dist
n
)
f
→
...
@@ -204,42 +204,18 @@ Proof.
...
@@ -204,42 +204,18 @@ Proof.
intros
Γ
Γ'
HΓ
?
vvs
->
.
intros
Γ
Γ'
HΓ
?
vvs
->
.
rewrite
/
env_ltyped2
.
rewrite
/
env_ltyped2
.
f_equiv
.
f_equiv
.
-
repeat
f_equiv
.
split
.
-
f_equiv
.
{
intros
Hvvs
x
.
split
;
intros
HH
.
split
;
-
apply
Hvvs
.
destruct
(
Γ
!!
x
)
as
[?|]
eqn
:
lawl
;
eauto
.
intros
Hvvs
x
;
specialize
(
HΓ
x
);
rewrite
-
(
Hvvs
x
);
specialize
(
HΓ
x
)
.
revert
HΓ
.
by
apply
(
is_Some_ne
n
)
.
destruct
HH
as
[?
HH
]
.
rewrite
HH
lawl
.
inversion
1
.
-
destruct
(
Γ'
!!
x
)
as
[?|]
eqn
:
lawl
;
eauto
.
specialize
(
HΓ
x
)
.
revert
HΓ
.
apply
(
Hvvs
x
)
in
HH
.
destruct
HH
as
[?
HH
]
.
rewrite
HH
lawl
.
inversion
1
.
}
(* MM TASTY COPYPASTA WITH CARBONARYA SAUCE *)
{
intros
Hvvs
x
.
split
;
intros
HH
.
-
apply
Hvvs
.
destruct
(
Γ'
!!
x
)
as
[?|]
eqn
:
lawl
;
eauto
.
specialize
(
HΓ
x
)
.
revert
HΓ
.
destruct
HH
as
[?
HH
]
.
rewrite
HH
lawl
.
inversion
1
.
-
destruct
(
Γ
!!
x
)
as
[?|]
eqn
:
lawl
;
eauto
.
specialize
(
HΓ
x
)
.
revert
HΓ
.
apply
(
Hvvs
x
)
in
HH
.
destruct
HH
as
[?
HH
]
.
rewrite
HH
lawl
.
inversion
1
.
}
-
apply
big_opM_ne2
;
first
apply
_
.
-
apply
big_opM_ne2
;
first
apply
_
.
+
by
intros
x
A
B
->
.
+
by
intros
x
A
B
->
.
+
apply
map_zip_with_ne
=>
//.
apply
_
.
+
apply
map_zip_with_ne
=>
//.
apply
_
.
Qed
.
Qed
.
(* Hmmm *)
Instance
env_ltyped2_proper
`{
relocG
Σ
}
:
Instance
env_ltyped2_proper
`{
relocG
Σ
}
:
Proper
((
≡
)
==>
(
=
)
==>
(
≡
))
env_ltyped2
.
Proper
((
≡
)
==>
(
=
)
==>
(
≡
))
env_ltyped2
.
Proof
.
Proof
.
solve_proper_from_ne
.
Qed
.
intros
Γ
Γ'
HΓ
?
vvs
->
.
apply
equiv_dist
=>
n
.
setoid_rewrite
equiv_dist
in
HΓ
.
by
rewrite
HΓ
.
Qed
.
Section
refinement
.
Section
refinement
.
Context
`{
relocG
Σ
}
.
Context
`{
relocG
Σ
}
.
...
@@ -264,17 +240,9 @@ Section refinement.
...
@@ -264,17 +240,9 @@ Section refinement.
solve_proper
.
solve_proper
.
Qed
.
Qed
.
(* TODO: this is a bit icky *)
Global
Instance
refines_proper
E
:
Global
Instance
refines_proper
E
:
Proper
((
≡
)
==>
(
=
)
==>
(
=
)
==>
(
≡
)
==>
(
≡
))
(
refines
E
)
.
Proper
((
≡
)
==>
(
=
)
==>
(
=
)
==>
(
≡
)
==>
(
≡
))
(
refines
E
)
.
Proof
.
Proof
.
solve_proper_from_ne
.
Qed
.
intros
Γ
Γ'
HΓ
?
e
->
?
e'
->
A
A'
HA
.
apply
equiv_dist
=>
n
.
setoid_rewrite
equiv_dist
in
HA
.
setoid_rewrite
equiv_dist
in
HΓ
.
by
rewrite
HA
HΓ
.
Defined
.
End
refinement
.
End
refinement
.
Notation
"⟦ A ⟧ₑ"
:=
(
λ
e
e'
,
interp_expr
⊤
e
e'
A
)
.
Notation
"⟦ A ⟧ₑ"
:=
(
λ
e
e'
,
interp_expr
⊤
e
e'
A
)
.
...
...
This diff is collapsed.
Click to expand it.
theories/prelude/tactics.v
0 → 100644
+
18
−
0
View file @
0c77ba26
From
stdpp
Require
Export
tactics
.
From
iris
.
algebra
Require
Export
ofe
.
(* Hmmm *)
Ltac
my_prepare
:=
intros
;
repeat
lazymatch
goal
with
|
|
-
Proper
_
_
=>
intros
???
|
|
-
(_
==>
_)
%
signature
_
_
=>
intros
???
|
|
-
pointwise_relation
_
_
_
_
=>
intros
?
end
;
simplify_eq
.
Ltac
solve_proper_from_ne
:=
my_prepare
;
solve
[
repeat
first
[
done
|
eassumption
|
apply
equiv_dist
=>?
|
match
goal
with
|
[
H
:
_
≡
_
|
-
_]
=>
setoid_rewrite
equiv_dist
in
H
;
rewrite
H
end
]
]
.
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment