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
47d5a3fc
Commit
47d5a3fc
authored
Mar 26, 2012
by
Adam Chlipala
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prose for third LogicProg section
parent
ff18c64f
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
52 additions
and
0 deletions
+52
-0
LogicProg.v
src/LogicProg.v
+52
-0
No files found.
src/LogicProg.v
View file @
47d5a3fc
...
@@ -600,11 +600,15 @@ Print length_and_sum''.
...
@@ -600,11 +600,15 @@ Print length_and_sum''.
(
**
*
Synthesizing
Programs
*
)
(
**
*
Synthesizing
Programs
*
)
(
**
Here
is
a
simple
syntax
type
for
arithmetic
expressions
,
similar
to
those
we
have
used
several
times
before
in
the
book
.
In
this
case
,
we
allow
expressions
to
mention
exactly
one
distinguished
variable
.
*
)
Inductive
exp
:
Set
:=
Inductive
exp
:
Set
:=
|
Const
:
nat
->
exp
|
Const
:
nat
->
exp
|
Var
:
exp
|
Var
:
exp
|
Plus
:
exp
->
exp
->
exp
.
|
Plus
:
exp
->
exp
->
exp
.
(
**
An
inductive
relation
specifies
the
semantics
of
an
expression
,
relating
a
variable
value
and
an
expression
to
the
expression
value
.
*
)
Inductive
eval
(
var
:
nat
)
:
exp
->
nat
->
Prop
:=
Inductive
eval
(
var
:
nat
)
:
exp
->
nat
->
Prop
:=
|
EvalConst
:
forall
n
,
eval
var
(
Const
n
)
n
|
EvalConst
:
forall
n
,
eval
var
(
Const
n
)
n
|
EvalVar
:
eval
var
Var
var
|
EvalVar
:
eval
var
Var
var
...
@@ -616,18 +620,24 @@ Inductive eval (var : nat) : exp -> nat -> Prop :=
...
@@ -616,18 +620,24 @@ Inductive eval (var : nat) : exp -> nat -> Prop :=
Hint
Constructors
eval
.
Hint
Constructors
eval
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
**
We
can
use
[
auto
]
to
execute
the
semantics
for
specific
expressions
.
*
)
Example
eval1
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
var
+
(
8
+
var
))
.
Example
eval1
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
var
+
(
8
+
var
))
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
auto
.
auto
.
Qed
.
Qed
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
**
Unfortunately
,
just
the
constructors
of
[
eval
]
are
not
enough
to
prove
theorems
like
the
following
,
which
depends
on
an
arithmetic
identity
.
*
)
Example
eval1
'
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
2
*
var
+
8
)
.
Example
eval1
'
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
2
*
var
+
8
)
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
eauto
.
eauto
.
Abort
.
Abort
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
**
To
help
prove
[
eval1
'
]
,
we
prove
an
alternate
version
of
[
EvalPlus
]
that
inserts
an
extra
equality
premise
.
*
)
(
*
begin
thide
*
)
(
*
begin
thide
*
)
Theorem
EvalPlus
'
:
forall
var
e1
e2
n1
n2
n
,
eval
var
e1
n1
Theorem
EvalPlus
'
:
forall
var
e1
e2
n1
n2
n
,
eval
var
e1
n1
->
eval
var
e2
n2
->
eval
var
e2
n2
...
@@ -638,9 +648,13 @@ Qed.
...
@@ -638,9 +648,13 @@ Qed.
Hint
Resolve
EvalPlus
'
.
Hint
Resolve
EvalPlus
'
.
(
**
Further
,
we
instruct
[
eauto
]
to
apply
%
\
index
{
tactics
!
omega
}%
[
omega
]
,
a
standard
tactic
that
provides
a
complete
decision
procedure
for
quantifier
-
free
linear
arithmetic
.
Via
[
Hint
Extern
]
,
we
ask
for
use
of
[
omega
]
on
any
equality
goal
.
The
[
abstract
]
tactical
generates
a
new
lemma
for
every
such
successful
proof
,
so
that
,
in
the
final
proof
term
,
the
lemma
may
be
referenced
in
place
of
dropping
in
the
full
proof
of
the
arithmetic
equality
.
*
)
Hint
Extern
1
(
_
=
_
)
=>
abstract
omega
.
Hint
Extern
1
(
_
=
_
)
=>
abstract
omega
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
**
Now
we
can
return
to
[
eval1
'
]
and
prove
it
automatically
.
*
)
Example
eval1
'
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
2
*
var
+
8
)
.
Example
eval1
'
:
forall
var
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
2
*
var
+
8
)
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
eauto
.
eauto
.
...
@@ -648,6 +662,19 @@ Qed.
...
@@ -648,6 +662,19 @@ Qed.
(
*
end
thide
*
)
(
*
end
thide
*
)
Print
eval1
'
.
Print
eval1
'
.
(
**
%
\
vspace
{-
.15
in
}%
[[
eval1
'
=
fun
var
:
nat
=>
EvalPlus
'
(
EvalVar
var
)
(
EvalPlus
(
EvalConst
var
8
)
(
EvalVar
var
))
(
eval1
'_
subproof
var
)
:
forall
var
:
nat
,
eval
var
(
Plus
Var
(
Plus
(
Const
8
)
Var
))
(
2
*
var
+
8
)
]]
*
)
(
**
The
lemma
[
eval1
'_
subproof
]
was
generated
by
[
abstract
omega
]
.
Now
we
are
ready
to
take
advantage
of
logic
programming
'
s
flexibility
by
searching
for
a
program
(
arithmetic
expression
)
that
always
evaluates
to
a
particular
symbolic
value
.
*
)
Example
synthesize1
:
exists
e
,
forall
var
,
eval
var
e
(
var
+
7
)
.
Example
synthesize1
:
exists
e
,
forall
var
,
eval
var
e
(
var
+
7
)
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
...
@@ -656,6 +683,15 @@ Qed.
...
@@ -656,6 +683,15 @@ Qed.
(
*
end
thide
*
)
(
*
end
thide
*
)
Print
synthesize1
.
Print
synthesize1
.
(
**
%
\
vspace
{-
.15
in
}%
[[
synthesize1
=
ex_intro
(
fun
e
:
exp
=>
forall
var
:
nat
,
eval
var
e
(
var
+
7
))
(
Plus
Var
(
Const
7
))
(
fun
var
:
nat
=>
EvalPlus
(
EvalVar
var
)
(
EvalConst
var
7
))
]]
*
)
(
**
Here
are
two
more
examples
showing
off
our
program
synthesis
abilities
.
*
)
Example
synthesize2
:
exists
e
,
forall
var
,
eval
var
e
(
2
*
var
+
8
)
.
Example
synthesize2
:
exists
e
,
forall
var
,
eval
var
e
(
2
*
var
+
8
)
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
...
@@ -663,7 +699,9 @@ Example synthesize2 : exists e, forall var, eval var e (2 * var + 8).
...
@@ -663,7 +699,9 @@ Example synthesize2 : exists e, forall var, eval var e (2 * var + 8).
Qed
.
Qed
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
*
begin
hide
*
)
Print
synthesize2
.
Print
synthesize2
.
(
*
end
hide
*
)
Example
synthesize3
:
exists
e
,
forall
var
,
eval
var
e
(
3
*
var
+
42
)
.
Example
synthesize3
:
exists
e
,
forall
var
,
eval
var
e
(
3
*
var
+
42
)
.
(
*
begin
thide
*
)
(
*
begin
thide
*
)
...
@@ -671,7 +709,13 @@ Example synthesize3 : exists e, forall var, eval var e (3 * var + 42).
...
@@ -671,7 +709,13 @@ Example synthesize3 : exists e, forall var, eval var e (3 * var + 42).
Qed
.
Qed
.
(
*
end
thide
*
)
(
*
end
thide
*
)
(
*
begin
hide
*
)
Print
synthesize3
.
Print
synthesize3
.
(
*
end
hide
*
)
(
**
These
examples
show
linear
expressions
over
the
variable
[
var
]
.
Any
such
expression
is
equivalent
to
[
k
*
var
+
n
]
for
some
[
k
]
and
[
n
]
.
It
is
probably
not
so
surprising
that
we
can
prove
that
any
expression
'
s
semantics
is
equivalent
to
some
such
linear
expression
,
but
it
is
tedious
to
prove
such
a
fact
manually
.
To
finish
this
section
,
we
will
use
[
eauto
]
to
complete
the
proof
,
finding
[
k
]
and
[
n
]
values
automatically
.
We
prove
a
series
of
lemmas
and
add
them
as
hints
.
We
have
alternate
[
eval
]
constructor
lemmas
and
some
facts
about
arithmetic
.
*
)
(
*
begin
thide
*
)
(
*
begin
thide
*
)
Theorem
EvalConst
'
:
forall
var
n
m
,
n
=
m
Theorem
EvalConst
'
:
forall
var
n
m
,
n
=
m
...
@@ -709,6 +753,8 @@ Qed.
...
@@ -709,6 +753,8 @@ Qed.
Hint
Resolve
plus_0
times_1
.
Hint
Resolve
plus_0
times_1
.
(
**
We
finish
with
one
more
arithmetic
lemma
that
is
particularly
specialized
to
this
theorem
.
This
fact
happens
to
follow
by
the
axioms
of
the
%
\
emph
{%
#
<
i
>
#
ring
#
</
i
>
#
%}%
algebraic
structure
,
so
,
since
the
naturals
form
a
ring
,
we
can
use
the
built
-
in
tactic
%
\
index
{
tactics
!
ring
}%
[
ring
]
.
*
)
Require
Import
Arith
Ring
.
Require
Import
Arith
Ring
.
Theorem
combine
:
forall
x
k1
k2
n1
n2
,
Theorem
combine
:
forall
x
k1
k2
n1
n2
,
...
@@ -718,14 +764,20 @@ Qed.
...
@@ -718,14 +764,20 @@ Qed.
Hint
Resolve
combine
.
Hint
Resolve
combine
.
(
**
Our
choice
of
hints
is
cheating
,
to
an
extent
,
by
telegraphing
the
procedure
for
choosing
values
of
[
k
]
and
[
n
]
.
Nonetheless
,
with
these
lemmas
in
place
,
we
achieve
an
automated
proof
without
explicitly
orchestrating
the
lemmas
'
composition
.
*
)
Theorem
linear
:
forall
e
,
exists
k
,
exists
n
,
Theorem
linear
:
forall
e
,
exists
k
,
exists
n
,
forall
var
,
eval
var
e
(
k
*
var
+
n
)
.
forall
var
,
eval
var
e
(
k
*
var
+
n
)
.
induction
e
;
crush
;
eauto
.
induction
e
;
crush
;
eauto
.
Qed
.
Qed
.
(
*
begin
hide
*
)
Print
linear
.
Print
linear
.
(
*
end
hide
*
)
(
*
end
thide
*
)
(
*
end
thide
*
)
(
**
By
printing
the
proof
term
,
it
is
possible
to
see
the
procedure
that
is
used
to
choose
the
constants
for
each
input
term
.
*
)
(
**
*
More
on
[
auto
]
Hints
*
)
(
**
*
More
on
[
auto
]
Hints
*
)
...
...
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