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
aaab7fde
Commit
aaab7fde
authored
Oct 05, 2008
by
Adam Chlipala
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Subset exercises
parent
6a439a53
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
0 deletions
+24
-0
Subset.v
src/Subset.v
+24
-0
No files found.
src/Subset.v
View file @
aaab7fde
...
@@ -758,3 +758,27 @@ Eval simpl in typeCheck' (Plus (Nat 1) (Bool false)).
...
@@ -758,3 +758,27 @@ Eval simpl in typeCheck' (Plus (Nat 1) (Bool false)).
:
{
t
:
type
|
hasType
(
Plus
(
Nat
1
)
(
Bool
false
))
t
}
+
:
{
t
:
type
|
hasType
(
Plus
(
Nat
1
)
(
Bool
false
))
t
}
+
{
(
forall
t
:
type
,
~
hasType
(
Plus
(
Nat
1
)
(
Bool
false
))
t
)
}
{
(
forall
t
:
type
,
~
hasType
(
Plus
(
Nat
1
)
(
Bool
false
))
t
)
}
]]
*
)
]]
*
)
(
**
*
Exercises
*
)
(
**
All
of
the
notations
defined
in
this
chapter
,
plus
some
extras
,
are
available
for
import
from
the
module
[
MoreSpecif
]
of
the
book
source
.
%
\
begin
{
enumerate
}%
#
<
ol
>
#
%
\
item
%
#
<
li
>
#
Write
a
function
of
type
[
forall
n
m
:
nat
,
{
n
<=
m
}
+
{
n
>
m
}
]
.
That
is
,
this
function
decides
whether
one
natural
is
less
than
another
,
and
its
dependent
type
guarantees
that
its
results
are
accurate
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
%
\
begin
{
enumerate
}%
#
<
ol
>
#
%
\
item
%
#
<
li
>
#
Define
[
var
]
,
a
type
of
propositional
variables
,
as
a
synonym
for
[
nat
]
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Define
an
inductive
type
[
prop
]
of
propositional
logic
formulas
,
consisting
of
variables
,
negation
,
and
binary
conjunction
and
disjunction
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Define
a
function
[
propDenote
]
from
variable
truth
assignments
and
[
prop
]
s
to
[
Prop
]
,
based
on
the
usual
meanings
of
the
connectives
.
Represent
truth
assignments
as
functions
from
[
var
]
to
[
bool
]
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Define
a
function
[
bool_true_dec
]
that
checks
whether
a
boolean
is
true
,
with
a
maximally
expressive
dependent
type
.
That
is
,
the
function
should
have
type
[
forall
b
,
{
b
=
true
}
+
{
b
=
true
->
False
}
]
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Define
a
function
[
decide
]
that
determines
whether
a
particular
[
prop
]
is
true
under
a
particular
truth
assignment
.
That
is
,
the
function
should
have
type
[
forall
(
truth
:
var
->
bool
)
(
p
:
prop
)
,
{
propDenote
truth
p
}
+
{
~
propDenote
truth
p
}
]
.
This
function
is
probably
easiest
to
write
in
the
usual
tactical
style
,
instead
of
programming
with
[
refine
]
.
[
bool_true_dec
]
may
come
in
handy
as
a
hint
.
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Define
a
function
[
negate
]
that
returns
a
simplified
version
of
the
negation
of
a
[
prop
]
.
That
is
,
the
function
should
have
type
[
forall
p
:
prop
,
{
p
'
:
prop
|
forall
truth
,
propDenote
truth
p
<->
~
propDenote
truth
p
'
}
]
.
To
simplify
a
variable
,
just
negate
it
.
Simplify
a
negation
by
returning
its
argument
.
Simplify
conjunctions
and
disjunctions
using
De
Morgan
'
s
laws
,
negating
the
arguments
recursively
and
switching
the
kind
of
connective
.
[
decide
]
may
be
useful
in
some
of
the
proof
obligations
,
even
if
you
do
not
use
it
in
the
computational
part
of
[
negate
]
'
s
definition
.
Lemmas
like
[
decide
]
allow
us
to
compensate
for
the
lack
of
a
general
Law
of
the
Excluded
Middle
in
CIC
.
#
</
li
>
#
#
</
ol
>
#
%
\
end
{
enumerate
}%
#
</
li
>
#
%
\
item
%
#
<
li
>
#
Implement
the
DPLL
satisfiability
decision
procedure
for
boolean
formulas
in
conjunctive
normal
form
,
with
a
dependent
type
that
guarantees
its
correctness
.
An
example
of
a
reasonable
type
for
this
function
would
be
[
forall
f
:
formula
,
{
truth
:
tvals
|
formulaTrue
truth
f
}
+
{
forall
truth
,
~
formulaTrue
truth
f
}
]
.
Implement
at
least
"the basic backtracking algorithm"
as
defined
here
:
%
\
begin
{
center
}
\
url
{
http
:
//en.wikipedia.org/wiki/DPLL_algorithm}\end{center}%
#
<
blockquote
><
a
href
=
"http://en.wikipedia.org/wiki/DPLL_algorithm"
>
http
:
//en.wikipedia.org/wiki/DPLL_algorithm</a></blockquote>#
It
might
also
be
instructive
to
implement
the
unit
propagation
and
pure
literal
elimination
optimizations
described
there
or
some
other
optimizations
that
have
been
used
in
modern
SAT
solvers
.
#
</
li
>
#
#
</
ol
>
#
%
\
end
{
enumerate
}%
*
)
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