Lecture 14: Sequentiality, Concrete Data Structures
Full Abstraction
Lecture 14
Sequentiality | Games |
---|---|
CCC, Abstract machines, Syntax (77) | Linear Logic (86) |
Full abstraction:
Timeline:
- PCF: what were the challenges
- Stability
- Sequential functions
- Sequential algorithms
- Game semantics
Consider
- a programming language
, types and terms in this language -
a denotational semantics associating a mathematical structure to some type
: -
From this, two programs of the same type
being definitionally equal is defined as
Observational equality
- Observable type:
-
some type for which computations end up with a value of this type in finite time (e.g.
nat
in CamL)
Consider an observable type and values of this type.
Let
Observational equivalence:
Full abstraction
Full abstraction: by Plotkin (76-77) and Milner.
- Full abstraction/Complete adequacy:
-
- Adequacy:
-
- Completeness:
-
NB:
- adequacy: relatively easy, more frequent
- completeness: rare/hard
- overall: complete adequacy is a matter of finding a good model (observational fixed) or finding a good language (denotational (model) fixed)
PCF with Scott semantics
Language | Model | Completeness/Adequacy? |
---|---|---|
PCF | Scott semantics | Adequacy but not Completeness |
Where the shoe pinches: parallel or:
Flat boolean domain:
Not doable in PCF because you have no notion of parallelism therein.
Plotkin exploited
Seminal question on which many people (Berry, Curien, Ong, Abramsky) worked afterwards: for which model is PCF fully-abstract?
What did Plotkin: added
Language | Model | Completeness/Adequacy? |
---|---|---|
PCF | Scott semantics | Adequacy but not Completeness |
PCF+ |
Scott semantics | Adequacy and Completeness (full abstraction) |
Actually,
not stable
NB: here, as DCPOs are finite, Scott-continuity amounts to monotonicity
is stable :-
if it is Scott-continuous and
(denoted by ):
NB:
The function
Even by replacing Scott-semantics by stable semantics, there a function (the
Language | Model | Completeness/Adequacy? |
---|---|---|
PCF | Scott semantics | Adequacy but not Completeness |
PCF | Stable semantics | Adequacy but not Completeness |
NB: the name of the function is a joke, it was the nickname of Gérard Béry, because there was already two other Gérard in the lab where he worked.
⟶ stable but not sequential.
Stability: to remove
Sequentiality (due to Jean Vuillemin)
- Sequential function
at : -
iff
Stability of
Sequential model: way harder than from continuous to stable.
Difficulties:
-
How to adapt the definition to more general domains?
⟹ Kahn-Poltkin: Category of Concrete data structures and sequential functions, where you can make sense of sequential functions (it is of the same flavour as coherence spaces (but it appeared way before))
-
Problem: the category of concrete data structures and sequential functions is not cartesian closed
⟹ Fix:
The category of of concrete data structures and sequential algorithms is cartesian closed
About booleans…
Description in the world of Coherence spaces
How do you recover
Description in the world of Concrete data structures
Events are now of the form:
Cells can be filled with at most one value.
Let
Concrete data structures
- Concrete data structure
: -
is given by
- a set
of cells - a set
of values - a set
of events -
Enabling relation
-
If you write
as , then the following conditions must be enforced:- infinite sequences of the form
are forbidden -
A sequence
such thatis called
- a response if the last label is a value
- a query if the last label is a value
- a response if the last label is a value
- If
and are two responses, then their least common prefix is a response.
- infinite sequences of the form
- a set
Example: Signature (arity in superscript):
Example of a term:
Values ⟺ Labels Cells ⟺ Nodes in the tree:
i.e., here:
(words)
:-
rules of the form
States in CDS
States ⟺ Partial first order terms
-
Coherence spaces
:- Data: set of cliques ordered by inclusion
- Data: set of cliques ordered by inclusion
-
Concrete Data Structures (CDS):
- Data: set of states
ordered by inclusion
- Data: set of states
Let
- A state of
: -
is a set
such that-
Coherence:
-
If
, then- either
- or there exists
such that
- either
-
Sequential functions
:-
set of states of
ordered by inclusion (it is a Scott domain, by the way)
Cartesian Closed Structure on CDS’s
Related to a model of intuitionistic affine logic (weaking allowed).
Product
Let’s build the cartesian product
Enabling relation:
Prop: in the category of Scott domains:
Function space
In the category of Coherence Spaces:
if
is a finite clique
As it happens, we have:
Now back to our CDS’s.
Let’s build the function space
-
-
where
(cell just outside of
, ready to be filled)
Enabling relation:
Example: quick left “or”
Depicted as: cf. picture
Leave a comment