Logic Programming with Extensible Types
By: Ivan Perez, Angel Herranz
Potential Business Impact:
Lets computer code do smart thinking easily.
Logic programming languages present clear advantages in terms of declarativeness and conciseness. However, the ideas of logic programming have been met with resistance in other programming communities, and have not generally been adopted by other paradigms and languages. This paper proposes a novel way to incorporate logic programming in an existing codebase in a typed functional programming language. Our approach integrates with the host language without sacrificing static typing, and leverages strengths of typed functional programming such as polymorphism and higher-order. We do so by combining three ideas. First, we use the extensible types technique to allow values of the host language to contain logic variables. Second, we implement a unification algorithm that works for any data structure that supports certain operations.Third, we introduce a domain-specific language to define and query predicates. We demonstrate our proposal via a series of examples, and provide aids to make the notation convenient for users, showing that the proposed approach is not just technically possible but also practical. Our ideas have been implemented in the language Haskell with very good results.
Similar Papers
Extensibility in Programming Languages: An overview
Programming Languages
Makes computer languages easier to change.
Filling the Gaps of Polarity: Implementing Dependent Data and Codata Types with Implicit Arguments
Programming Languages
Lets computers add new features easily.
A Programming Language for Feasible Solutions
Programming Languages
Guarantees computer programs finish quickly.