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 L, types and terms in this language
  • a denotational semantics associating a mathematical structure to some type τ:

    M:τ an element Mτ
  • From this, two programs of the same type M,M:τ being definitionally equal is defined as

    M=denMM=M

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 M:τM:τ be a function computed via some deterministic operational semantics.

Observational equivalence:

M=obsMC,C[M]of some base typevC[M]v and conversely

Full abstraction

Full abstraction: by Plotkin (76-77) and Milner.

Full abstraction/Complete adequacy:
M=obsMM=denM
Adequacy:
M=obsMM=denM
Completeness:
M=obsMM=denM

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:

por:Bool×BoolBool

Flat boolean domain:

%3 T T ⊥->T F F ⊥->F
por(T,)=Tpor(,T)=Tpor(,)=⊥

Not doable in PCF because you have no notion of parallelism therein.

Plotkin exploited por to build two terms of the appropriate type M,M (BoolBoolBool)Bool such that

MM but M=obsM

Seminal question on which many people (Berry, Curien, Ong, Abramsky) worked afterwards: for which model is PCF fully-abstract?

What did Plotkin: added por to the syntax of PCF, and then showed that we do have full abstraction!

Language Model Completeness/Adequacy?
PCF Scott semantics Adequacy but not Completeness
PCF+por Scott semantics Adequacy and Completeness (full abstraction)

Actually, por is not stable (showed by Berry).

por not stable

NB: here, as DCPOs are finite, Scott-continuity amounts to monotonicity

f:DD is stable :

if it is Scott-continuous and x,y st z;x,yz (denoted by xy):

f(xy)=f(x)f(y)

NB:

x,yBooln,x↑̸yi;xiyi and xi,yi≠⊥ por((T,))por((,T))=TT=T≠⊥=por((T,)(,T)=(,))

The function Gustave

Even by replacing Scott-semantics by stable semantics, there a function (the Gustave function) that make full-abstraction fail.

Language Model Completeness/Adequacy?
PCF Scott semantics Adequacy but not Completeness
PCF Stable semantics Adequacy but not Completeness
Gustave:Bool×Bool×BoolBool

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.

G(T,F,)=TG(F,,T)=TG(,T,F)=T

⟶ stable but not sequential.

Stability: to remove por Sequentiality: to remove G

Sequentiality (due to Jean Vuillemin)

Sequential function f:BoolnBool at xBooln:

iff

f(x)=⊥ and (yx,f(y)≠⊥)(i[1,,n];xi=⊥ and zx,f(z)≠⊥⟹zi≠⊥)

Stability of G: (T,F,),(F,,T) and (,T,F) are pairwise incompatible, so G is vacuously stable

G is not sequential.

Sequential model: way harder than from continuous to stable.

Difficulties:

  1. 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))

  2. 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 Bool from events? Let e1,e2 be two events/tokens that are incompatible (denoted by e_1 # e_2):

%9 {e_1} {e_1} ∅->{e_1} {e_2} {e_2} ∅->{e_2}

Description in the world of Concrete data structures

Events are now of the form:

e=(cell,value)

Cells can be filled with at most one value.

Let ?,True,False be the only elements we have.

%15 {(?, True)} {(?, True)} ∅->{(?, True)} {?, False} {?, False} ∅->{?, False}

Concrete data structures

Concrete data structure 𝕄(C,V,E,):

is given by

  • a set C of cells
  • a set V of values
  • a set EC×V of events
  • Enabling relation ⊢⊆Cwe write c (initial cell)E×Cwe write ec

  • If you write (c1,v1)c as c1v1c, then the following conditions must be enforced:

    • infinite sequences of the form c2v2c1v1c are forbidden
    • A sequence c0v0ckvk such that

      c0 and i>0,(ci1,vi1)ci

      is called

      • a response if the last label is a value vn
      • a query if the last label is a value cn
    • If c0v0cnvn and d0w0dkwk are two responses, then their least common prefix is a response.

Example: Signature (arity in superscript):

Σa0g1h2values

Example of a term:

%21 a2 a h h g g h->g a a h->a g->a2

Values ⟺ Labels Cells ⟺ Nodes in the tree:

%29 ε ε 0 0 ε->0 1 1 ε->1 00 00 0->00

i.e., here:

  • C= (words)
  • V={a,g,h}
:

rules of the form ε(u,hm)ui where i<m

States in CDS

States ⟺ Partial first order terms

  • Coherence spaces E:

    • Data: set of cliques ordered by inclusion D(E)
  • Concrete Data Structures (CDS):

    • Data: set of states D(𝕄) ordered by inclusion

Let 𝕄 be a CDS.

A state of 𝕄:

is a set xE such that

  • Coherence: (c,v1),(c,v2)xv1=v2

  • If (c,v)x, then

    • either c
    • or there exists (d,w)x such that (d,w)c

Sequential functions f:𝕄𝕄: the index i is replaced by a cell here.

D(𝕄):

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

𝕄=(C,V,E,),𝕄=(C,V,E,)

Let’s build the cartesian product 𝕄=(C,V,E,).

  • C=CC=C.1C.2
  • V=VV
  • E={(c.1,w)(c,w)E}{(c.2,w)(c,w)E}

Enabling relation:

cc.1cc.2(c,v)d(c.1,v)d.1(c,v)d(c.2,v)d.2

Prop: in the category of Scott domains:

D(M×M)D(M)×D(M)

Function space

In the category of Coherence Spaces:

if e(E,E) and e(E,E), the elements of EE are of the form (x,e) where

  • x is a finite clique
  • eE

As it happens, we have:

D(EE)D(E)stableD(E)

Now back to our CDS’s.

𝕄=(C,V,E,),𝕄=(C,V,E,)

Let’s build the function space 𝕄𝕄𝕄=(C,V,E,).

  • C=Dfin(𝕄)×C
  • V={valofccC}{outputvvV}
  • E={(xc,valofc)cA(x)}{(xc,outputv)(c,v)E}

    where

    cA(x)c is enabled in x but not filled in x

    (cell just outside of x, ready to be filled)

Enabling relation:

cc(c,v)E(xc,valofc)(x{(c,v)})c(c,v)d(xc,outputv)xd

Example: quick left “or” Bool×BoolBool:

(?,valof?.1)({(?.1,T)}?,outputT)({(?.1,F)}?,valof?.2)({(?.1,F),(?.2,F)}?,outputF)({(?.1,F),(?.2,T)}?,outputV)

Depicted as: cf. picture

Leave a comment