Programming Computable Functions

From testwiki
Revision as of 15:36, 14 February 2025 by imported>Oneequalsequalsone (fix note)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Template:Short description In computer science, Programming Computable Functions (PCF) is a typed functional language introduced by Gordon Plotkin in 1977,[1] based on previous unpublished material by Dana Scott.Template:Efn It can be considered to be an extended version of the typed lambda calculus or a simplified version of modern typed functional languages such as ML or Haskell.

A fully abstract model for PCF was first given by Robin Milner.[2] However, since Milner's model was essentially based on the syntax of PCF it was considered less than satisfactory.[3] The first two fully abstract models not employing syntax were formulated during the 1990s. These models are based on game semantics[4][5] and Kripke logical relations.[6] For a time it was felt that neither of these models was completely satisfactory, since they were not effectively presentable. However, Ralph Loader demonstrated that no effectively presentable fully abstract model could exist, since the question of program equivalence in the finitary fragment of PCF is not decidable.[7]

Syntax

The types of PCF are inductively defined as

  • nat is a type
  • For types σ and τ, there is a type στ

A context is a list of pairs x : σ, where x is a variable name and σ is a type, such that no variable name is duplicated. One then defines typing judgments of terms-in-context in the usual way for the following syntactical constructs:

  • Variables (if x : σ is part of a context Γ, then Γx : σ)
  • Application (of a term of type στ to a term of type σ)
  • λ-abstraction
  • The Y fixed point combinator (making terms of type σ out of terms of type σσ)
  • The successor (succ) and predecessor (pred) operations on nat and the constant 0
  • The conditional if with the typing rule:
Γt:nat,Γs0:σ,Γs1:σΓif(t,s0,s1):σ
(nats will be interpreted as booleans here with a convention like zero denoting truth, and any other number denoting falsity)

Semantics

Denotational semantics

A relatively straightforward semantics for the language is the Scott model. In this model,

  • Types are interpreted as certain domains.
    • [[nat]]:= (the natural numbers with a bottom element adjoined, with the flat ordering)
    • [[στ]] is interpreted as the domain of Scott-continuous functions from [[σ]] to [[τ]], with the pointwise ordering.
  • A context x1:σ1,,xn:σn is interpreted as the product [[σ1]]××[[σn]]
  • Terms in context Γx:σ are interpreted as continuous functions [[Γ]][[σ]]
    • Variable terms are interpreted as projections
    • Lambda abstraction and application are interpreted by making use of the cartesian closed structure of the category of domains and continuous functions
    • Y is interpreted by taking the least fixed point of the argument

This model is not fully abstract for PCF; but it is fully abstract for the language obtained by adding a parallel or operator to PCF.[4]Template:Rp

Notes

Template:Notelist

References

Template:Reflist

  1. Cite error: Invalid <ref> tag; no text was provided for refs named Plotkin 1977
  2. Cite error: Invalid <ref> tag; no text was provided for refs named Milner 1977
  3. Cite error: Invalid <ref> tag; no text was provided for refs named Ong 1995
  4. 4.0 4.1 Cite error: Invalid <ref> tag; no text was provided for refs named Hyland 2000
  5. Cite error: Invalid <ref> tag; no text was provided for refs named Abramsky 2000
  6. Cite error: Invalid <ref> tag; no text was provided for refs named O'Hearn 1995
  7. Cite error: Invalid <ref> tag; no text was provided for refs named Loader 2001