| 
  15-317 Constructive Logic Lecture 17: Modes, Termination, and Coverage
  Twelf is an implementation of LF as a logic programming
  language with a number of additional features.  Besides the
  strong type system, it can also check mode, termination, and
  coverage properties of programs.
 
  Modes specify the expected input/output behavior of predicates
  (represented in Twelf as type families) and mode checking will
  verify that the program satisfies a given input/output specification.
  Termination checking verifies that a given predicate will always
  terminate.  If a predicate passes type, mode, and termination checking
  we know that every well-typed, well-moded query will terminate either
  with success (and a well-typed substitution for its free variables) or
  fail.  Certain predicates such as append, are intended to compute
  total functions and should therefore never fail on any input.  This
  can be verified through coverage.  All these checks together can
  certify that programs are total in their inputs, always succeeding
  and producing ground outputs.
 
 
  [ Home
  | Schedule
  | Assignments
  | Handouts
  | Software
  ]
 
  fp@cs Frank Pfenning
 |