Skip to main content

Specifying theorem provers in a higher-order logic programming language

  • Conference paper
  • First Online:
9th International Conference on Automated Deduction (CADE 1988)

Part of the book series: Lecture Notes in Computer Science ((LNCS,volume 310))

Included in the following conference series:

  • 207 Accesses

Abstract

Since logic programming systems directly implement search and unification and since these operations are essential for the implementation of most theorem provers, logic programming languages should make ideal implementation languages for theorem provers. We shall argue that this is indeed the case if the logic programming language is extended in several ways. We present an extended logic programming language where first-order terms are replaced with simply-typed λ-terms, higher-order unification replaces first-order unification, and implication and universal quantification are allowed in queries and the bodies of clauses. This language naturally specifies inference rules for various proof systems. The primitive search operations required to search for proofs generally have very simple implementations using the logical connectives of this extended logic programming language. Higher-order unification, which provides sophisticated pattern matching on formulas and proofs, can be used to determine when and at what instance an inference rule can be employed in the search for a proof. Tactics and tacticals, which provide a framework for high-level control over search, can also be directly implemented in this extended language. The theorem provers presented in this paper have been implemented in the higher-order logic programming language λProlog.

This is a preview of subscription content, log in via an institution to check access.

Access this chapter

Institutional subscriptions

Preview

Unable to display preview. Download preview PDF.

Unable to display preview. Download preview PDF.

References

  1. Arnon Avron, Furio A. Honsell, and Ian A. Mason. Using Typed Lambda Calculus to Implement Formal Systems on a Machine. Technical Report ECS-LFCS-87-31, Laboratory for the Foundations of Computer Science, University of Edinburgh, June 1987.

    Google Scholar 

  2. W. W. Bledsoe. Non-resolution theorem proving. Artificial Intelligence, 9:1–35, 1977.

    Article  Google Scholar 

  3. W. W. Bledsoe. The UT Prover. Technical Report ATP-17B, University of Texas at Austin, April 1983.

    Google Scholar 

  4. R. L. Constable et al. Implementing Mathematics with the Nuprl Proof Development System. Prentice-Hall, 1986.

    Google Scholar 

  5. Alonzo Church. A formulation of the simple theory of types. Journal of Symbolic Logic, 5:56–68, 1940.

    Google Scholar 

  6. Amy Felty. Implementing theorem provers in logic programming. November 1987. Dissertation Proposal, University of Pennsylvania.

    Google Scholar 

  7. Gerhard Gentzen. Investigations into logical deductions, 1935. In M. E. Szabo, editor, The Collected Papers of Gerhard Gentzen, pages 68–131, North-Holland Publishing Co., Amsterdam, 1969.

    Google Scholar 

  8. Michael J. Gordon, Arthur J. Milner, and Christopher P. Wadsworth. Edinburgh LCF: A Mechanised Logic of Computation. Volume 78 of Lecture Notes in Computer Science, Springer-Verlag, 1979.

    Google Scholar 

  9. Robert Harper, Furio Honsell, and Gordon Plotkin. A framework for defining logics. In Symposium on Logic in Computer Science, pages 194–204, Ithaca, NY, June 1987.

    Google Scholar 

  10. G. P. Huet. A unification algorithm for typed λ-calculus. Theoretical Computer Science, 1:27–57, 1975.

    Article  Google Scholar 

  11. Dale Miller and Gopalan Nadathur. Higher-order logic programming. In Proceedings of the Third International Logic Programming Conference, pages 448–462, London, June 1986.

    Google Scholar 

  12. Dale Miller and Gopalan Nadathur. Some uses of higher-order logic in computational linguistics. In Proceedings of the 24th Annual Meeting of the Association for Computational Linguistics, pages 247–255, 1986.

    Google Scholar 

  13. Dale Miller and Gopalan Nadathur. λProlog Version 2.6. August 1987. Distribution in C-Prolog code.

    Google Scholar 

  14. Dale Miller and Gopalan Nadathur. A logic programming approach to manipulating formulas and programs. In IEEE Symposium on Logic Programming, San Francisco, September 1987.

    Google Scholar 

  15. Dale Miller, Gopalan Nadathur, and Andre Scedrov. Hereditary harrop formulas and uniform proof systems. In Symposium on Logic in Computer Science, pages 98–105, Ithaca, NY, June 1987.

    Google Scholar 

  16. Gopalan Nadathur. A Higher-Order Logic as the Basis for Logic Programming. PhD thesis, University of Pennsylvania, December 1986.

    Google Scholar 

  17. Larence C. Paulson. Natural deduction as higher-order resolution. Journal of Logic Programming, 3:237–258, 1986.

    Article  Google Scholar 

  18. Lawrence C. Paulson. The Representation of Logics in Higher-Order Logic. Draft, University of Cambridge, July 1987.

    Google Scholar 

  19. Dag Prawitz. Natural Deduction. Almqvist & Wiksell, Uppsala, 1965.

    Google Scholar 

  20. L. Sterling and E. Shapiro. The Art of Prolog: Advanced Programming Techniques. MIT Press, Cambridge MA, 1986.

    Google Scholar 

  21. Mabry Tyson and W. W. Bledsoe. Conflicting bindings and generalized substitutions. In 4th International Conference on Automated Deduction, pages 14–18, Springer-Verlag, February 1979.

    Google Scholar 

Download references

Author information

Authors and Affiliations

Authors

Editor information

Ewing Lusk Ross Overbeek

Rights and permissions

Reprints and permissions

Copyright information

© 1988 Springer-Verlag Berlin Heidelberg

About this paper

Cite this paper

Felty, A., Miller, D. (1988). Specifying theorem provers in a higher-order logic programming language. In: Lusk, E., Overbeek, R. (eds) 9th International Conference on Automated Deduction. CADE 1988. Lecture Notes in Computer Science, vol 310. Springer, Berlin, Heidelberg. https://doi.org/10.1007/BFb0012823

Download citation

  • DOI: https://doi.org/10.1007/BFb0012823

  • Published:

  • Publisher Name: Springer, Berlin, Heidelberg

  • Print ISBN: 978-3-540-19343-2

  • Online ISBN: 978-3-540-39216-3

  • eBook Packages: Springer Book Archive

Publish with us

Policies and ethics