Definitions in nonstrict positive free logic
暂无分享,去创建一个
Every \practical" programming language supplies the programmer with at least one nonstrict construct, such as the ALGOL60 arithmeticìf-then-else' and the LISP`cond'. Many programming languages also enable the user to deene nonstrict functions. In some languages, this is accomplished through the lazy evaluation of procedure parameters, as realized, for example, by the call-by-name devices of ALGOL60 and SIMULA67 and the call-by-need mechanism of Haskell. In other languages, such as Common LISP, a macro deenition facility can serve a similar purpose. Programming languages that provide a mechanism for the user to deene nonstrict functions are nonstrict languages, and we call the natural underlying logic of these languages nonstrict positive free logic. In this paper, we present the deenition theory of nonstrict positive free logic. Suitable transformations of sentences in standard logic into sentences in nonstrict positive free logic preserve many properties of deenitions in standard logic. Before embarking on details, here is one general piece of advice. One often hears that : : : some : : : logic is pointless because it can be translated into some simpler language in a rst-order way. Take no notice of such arguments. There is no weight to the claim that the original system must therefore be replaced by the new one. What is essential is to single out important concepts and to investigate their properties.
[1] K. Lambert. On the philosophical foundations of free logic , 1981 .
[2] Simon J. Thompson,et al. A logic for Miranda , 1989, Formal Aspects of Computing.
[3] Martin D. Davis,et al. A Free Variable Version of the First-Order Predicate Calculus , 1991, J. Log. Comput..
[4] Raymond D. Gumb. An Extended Joint Consistency Theorem for a Family of Free Modal Logics with Equality , 1984, J. Symb. Log..