Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
C
cpdt
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
research
cpdt
Commits
faababe2
Commit
faababe2
authored
Nov 03, 2008
by
Adam Chlipala
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Hoas, up to type soundness
parent
b5d37b21
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
132 additions
and
1 deletion
+132
-1
Makefile
Makefile
+1
-1
Hoas.v
src/Hoas.v
+128
-0
Intro.v
src/Intro.v
+2
-0
toc.html
src/toc.html
+1
-0
No files found.
Makefile
View file @
faababe2
MODULES_NODOC
:=
Axioms Tactics MoreSpecif DepList
MODULES_PROSE
:=
Intro
MODULES_CODE
:=
StackMachine InductiveTypes Predicates Coinductive Subset
\
MoreDep DataStruct Equality Match Reflection Firstorder
MoreDep DataStruct Equality Match Reflection Firstorder
Hoas
MODULES_DOC
:=
$(MODULES_PROSE)
$(MODULES_CODE)
MODULES
:=
$(MODULES_NODOC)
$(MODULES_DOC)
VS
:=
$
(
MODULES:%
=
src/%.v
)
...
...
src/Hoas.v
0 → 100644
View file @
faababe2
(
*
Copyright
(
c
)
2008
,
Adam
Chlipala
*
*
This
work
is
licensed
under
a
*
Creative
Commons
Attribution
-
Noncommercial
-
No
Derivative
Works
3.0
*
Unported
License
.
*
The
license
text
is
available
at
:
*
http
:
//creativecommons.org/licenses/by-nc-nd/3.0/
*
)
(
*
begin
hide
*
)
Require
Import
Arith
Eqdep
String
List
.
Require
Import
Tactics
.
Set
Implicit
Arguments
.
(
*
end
hide
*
)
(
**
%
\
chapter
{
Higher
-
Order
Abstract
Syntax
}%
*
)
(
**
TODO
:
Prose
for
this
chapter
*
)
(
**
*
Parametric
Higher
-
Order
Abstract
Syntax
*
)
Inductive
type
:
Type
:=
|
Bool
:
type
|
Arrow
:
type
->
type
->
type
.
Infix
"-->"
:=
Arrow
(
right
associativity
,
at
level
60
)
.
Section
exp
.
Variable
var
:
type
->
Type
.
Inductive
exp
:
type
->
Type
:=
|
Const
'
:
bool
->
exp
Bool
|
Var
:
forall
t
,
var
t
->
exp
t
|
App
'
:
forall
dom
ran
,
exp
(
dom
-->
ran
)
->
exp
dom
->
exp
ran
|
Abs
'
:
forall
dom
ran
,
(
var
dom
->
exp
ran
)
->
exp
(
dom
-->
ran
)
.
End
exp
.
Implicit
Arguments
Const
'
[
var
]
.
Implicit
Arguments
Var
[
var
t
]
.
Implicit
Arguments
Abs
'
[
var
dom
ran
]
.
Definition
Exp
t
:=
forall
var
,
exp
var
t
.
Definition
Exp1
t1
t2
:=
forall
var
,
var
t1
->
exp
var
t2
.
Definition
Const
(
b
:
bool
)
:
Exp
Bool
:=
fun
_
=>
Const
'
b
.
Definition
App
dom
ran
(
F
:
Exp
(
dom
-->
ran
))
(
X
:
Exp
dom
)
:
Exp
ran
:=
fun
_
=>
App
'
(
F
_
)
(
X
_
)
.
Definition
Abs
dom
ran
(
B
:
Exp1
dom
ran
)
:
Exp
(
dom
-->
ran
)
:=
fun
_
=>
Abs
'
(
B
_
)
.
Section
flatten
.
Variable
var
:
type
->
Type
.
Fixpoint
flatten
t
(
e
:
exp
(
exp
var
)
t
)
{
struct
e
}
:
exp
var
t
:=
match
e
in
exp
_
t
return
exp
_
t
with
|
Const
'
b
=>
Const
'
b
|
Var
_
e
'
=>
e
'
|
App
'
_
_
e1
e2
=>
App
'
(
flatten
e1
)
(
flatten
e2
)
|
Abs
'
_
_
e
'
=>
Abs
'
(
fun
x
=>
flatten
(
e
'
(
Var
x
)))
end
.
End
flatten
.
Definition
Subst
t1
t2
(
E1
:
Exp
t1
)
(
E2
:
Exp1
t1
t2
)
:
Exp
t2
:=
fun
_
=>
flatten
(
E2
_
(
E1
_
))
.
(
**
*
A
Type
Soundness
Proof
*
)
Reserved
Notation
"E1 ==> E2"
(
no
associativity
,
at
level
90
)
.
Inductive
Val
:
forall
t
,
Exp
t
->
Prop
:=
|
VConst
:
forall
b
,
Val
(
Const
b
)
|
VAbs
:
forall
dom
ran
(
B
:
Exp1
dom
ran
)
,
Val
(
Abs
B
)
.
Hint
Constructors
Val
.
Inductive
Step
:
forall
t
,
Exp
t
->
Exp
t
->
Prop
:=
|
Beta
:
forall
dom
ran
(
B
:
Exp1
dom
ran
)
(
X
:
Exp
dom
)
,
App
(
Abs
B
)
X
==>
Subst
X
B
|
Cong1
:
forall
dom
ran
(
F
:
Exp
(
dom
-->
ran
))
(
X
:
Exp
dom
)
F
'
,
F
==>
F
'
->
App
F
X
==>
App
F
'
X
|
Cong2
:
forall
dom
ran
(
F
:
Exp
(
dom
-->
ran
))
(
X
:
Exp
dom
)
X
'
,
Val
F
->
X
==>
X
'
->
App
F
X
==>
App
F
X
'
where
"E1 ==> E2"
:=
(
Step
E1
E2
)
.
Hint
Constructors
Step
.
Inductive
Closed
:
forall
t
,
Exp
t
->
Prop
:=
|
CConst
:
forall
b
,
Closed
(
Const
b
)
|
CApp
:
forall
dom
ran
(
E1
:
Exp
(
dom
-->
ran
))
E2
,
Closed
E1
->
Closed
E2
->
Closed
(
App
E1
E2
)
|
CAbs
:
forall
dom
ran
(
E1
:
Exp1
dom
ran
)
,
Closed
(
Abs
E1
)
.
Axiom
closed
:
forall
t
(
E
:
Exp
t
)
,
Closed
E
.
Ltac
my_crush
:=
crush
;
repeat
(
match
goal
with
|
[
H
:
_
|-
_
]
=>
generalize
(
inj_pairT2
_
_
_
_
_
H
)
;
clear
H
end
;
crush
)
.
Lemma
progress
'
:
forall
t
(
E
:
Exp
t
)
,
Closed
E
->
Val
E
\
/
exists
E
'
,
E
==>
E
'
.
induction
1
;
crush
;
try
match
goal
with
|
[
H
:
@
Val
(
_
-->
_
)
_
|-
_
]
=>
inversion
H
;
my_crush
end
;
eauto
.
Qed
.
Theorem
progress
:
forall
t
(
E
:
Exp
t
)
,
Val
E
\
/
exists
E
'
,
E
==>
E
'
.
intros
;
apply
progress
'
;
apply
closed
.
Qed
.
src/Intro.v
View file @
faababe2
...
...
@@ -205,6 +205,8 @@ Proof by Reflection & \texttt{Reflection.v} \\
\
hline
First
-
Order
Abstract
Syntax
&
\
texttt
{
Firstorder
.
v
}
\
\
\
hline
Higher
-
Order
Abstract
Syntax
&
\
texttt
{
Hoas
.
v
}
\
\
\
hline
\
end
{
tabular
}
\
end
{
center
}
%
*
)
src/toc.html
View file @
faababe2
...
...
@@ -16,5 +16,6 @@
<li><a
href=
"Match.html"
>
Proof Search in Ltac
</a>
<li><a
href=
"Reflection.html"
>
Proof by Reflection
</a>
<li><a
href=
"Firstorder.html"
>
First-Order Abstract Syntax
</a>
<li><a
href=
"Hoas.html"
>
Higher-Order Abstract Syntax
</a>
</body></html>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment