Open main menu
Home
Random
Recent changes
Special pages
Community portal
Preferences
About Wikipedia
Disclaimers
Incubator escapee wiki
Search
User menu
Talk
Dark mode
Contributions
Create account
Log in
Editing
Logic for Computable Functions
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
{{Short description|1970s automated theorem prover}} {{see also|Logic of Computable Functions}} '''Logic for Computable Functions''' ('''LCF''') is an interactive [[automated theorem prover]] developed at [[Stanford University|Stanford]] and [[University of Edinburgh|Edinburgh]] by [[Robin Milner]] and collaborators in early 1970s, based on the theoretical foundation of [[Logic of Computable Functions|logic of computable functions]] previously proposed by [[Dana Scott]]. Work on the LCF system introduced the general-purpose [[programming language]] [[ML (programming language)|ML]] to allow users to write theorem-proving tactics, supporting [[algebraic data type]]s, [[parametric polymorphism]], [[abstract data types]], and [[Exception handling|exceptions]]. == Basic idea == Theorems in the system are terms of a special "theorem" [[abstract data type]]. The general mechanism of abstract data types of ML ensures that theorems are derived using only the [[inference rule]]s given by the operations of the theorem abstract type. Users can write arbitrarily complex ML programs to compute theorems; the validity of theorems does not depend on the complexity of such programs, but follows from the soundness of the abstract data type implementation and the correctness of the ML compiler. == Advantages == The LCF approach provides similar trustworthiness to systems that generate explicit proof certificates but without the need to store proof objects in memory. The Theorem data type can be easily implemented to optionally store proof objects, depending on the system's run-time configuration, so it generalizes the basic proof-generation approach. The design decision to use a general-purpose programming language for developing theorems means that, depending on the complexity of programs written, it is possible to use the same language to write step-by-step proofs, decision procedures, or theorem provers. == Disadvantages == === Trusted computing base === The implementation of the underlying ML compiler adds to the [[trusted computing base]]. Work on CakeML<ref name="cakeml">{{cite web |title=CakeML |url=https://cakeml.org/ |access-date=2 November 2019}}</ref> resulted in a formally verified ML compiler, alleviating some of these concerns. === Efficiency and complexity of proof procedures === Theorem proving often benefits from decision procedures and theorem proving algorithms, whose correctness has been extensively analyzed. A straightforward way of implementing these procedures in an LCF approach requires such procedures to always derive outcomes from the axioms, lemmas, and inference rules of the system, as opposed to directly computing the outcome. A potentially more efficient approach is to use reflection to prove that a function operating on formulas always gives correct result.<ref>{{cite report |last1=Boyer |first1=Robert S |last2=Moore |first2=J Strother |title=Metafunctions: Proving Them Correct and Using Them Efficiently as New Proof Procedures |publisher=Technical Report CSL-108, SRI Projects 8527/4079 |pages=1β111 |url=https://apps.dtic.mil/dtic/tr/fulltext/u2/a094385.pdf |archive-url=https://web.archive.org/web/20191102152631/https://apps.dtic.mil/dtic/tr/fulltext/u2/a094385.pdf |url-status=live |archive-date=November 2, 2019 |access-date=2 November 2019}}</ref> == Influences == Among subsequent implementations is Cambridge LCF. Later systems simplified the logic to use total instead of partial functions, leading to [[HOL (proof assistant)|HOL]], [[HOL Light]], and the [[Isabelle proof assistant]] that supports various logics. As of 2019, the Isabelle [[proof assistant]] still contains an implementation of an LCF logic, Isabelle/LCF. == Notes == {{Reflist}} == References == {{Refbegin}} * {{cite book |last1=Gordon |first1=Michael J. |author1-link=Michael J. C. Gordon |last2=Milner |first2=Arthur J. |last3=Wadsworth |first3=Christopher P. |date=1979 |title=Edinburgh LCF: A Mechanised Logic of Computation |doi=10.1007/3-540-09724-4 |series=Lecture Notes in Computer Science |volume=78 |publisher=Springer |location=Berlin Heidelberg |isbn=978-3-540-09724-2 |s2cid=21159098 }} * {{cite book |last=Gordon |first=Michael J. C. |chapter=From LCF to HOL: a short history |url=http://www.cl.cam.ac.uk/~mjcg/papers/HolHistory.html |title=Proof, language, and interaction |pages=169β185 |publisher=MIT Press |location=Cambridge, Massachusetts |date=2000 |isbn=0-262-16188-5 |access-date=2007-10-11}} * {{cite book |last1=Loeckx |first1=Jacques |last2=Sieber |first2=Kurt |date=1987 |title=The Foundations of Program Verification |doi=10.1007/978-3-322-96753-4 |edition=2nd |publisher=Vieweg+Teubner Verlag |isbn=978-3-322-96754-1}} * {{cite manual |last=Milner |first=Robin |author-link=Robin Milner |title=Logic for Computable Functions: description of a machine implementation. |publisher=Stanford University |date=May 1972 |url=https://apps.dtic.mil/sti/pdfs/AD0785072.pdf}} * {{cite book |last=Milner |first=Robin |author-link=Robin Milner |editor=BeΔvΓ‘Ε, JiΕΓ |date=1979 |title=Mathematical Foundations of Computer Science 1979 |chapter=Lcf: A way of doing proofs with a machine |pages=146β159 |doi=10.1007/3-540-09526-8_11 |series=Lecture Notes in Computer Science |volume=74 |publisher=Springer |location=Berlin Heidelberg |isbn=978-3-540-09526-2}} {{Refend}} {{ML programming}} [[Category:Logic in computer science]] [[Category:Proof assistants]] {{Mathlogic-stub}}
Edit summary
(Briefly describe your changes)
By publishing changes, you agree to the
Terms of Use
, and you irrevocably agree to release your contribution under the
CC BY-SA 4.0 License
and the
GFDL
. You agree that a hyperlink or URL is sufficient attribution under the Creative Commons license.
Cancel
Editing help
(opens in new window)
Pages transcluded onto the current version of this page
(
help
)
:
Template:Cite book
(
edit
)
Template:Cite manual
(
edit
)
Template:Cite report
(
edit
)
Template:Cite web
(
edit
)
Template:ML programming
(
edit
)
Template:Mathlogic-stub
(
edit
)
Template:Refbegin
(
edit
)
Template:Refend
(
edit
)
Template:Reflist
(
edit
)
Template:See also
(
edit
)
Template:Short description
(
edit
)