Academia.edu no longer supports Internet Explorer.
To browse Academia.edu and the wider internet faster and more securely, please take a few seconds to upgrade your browser.
2008
…
308 pages
1 file
This tutorial paper aims to provide the necessary expertise for working with the proof assistant Sparkle, which is dedicated to the lazy functional programming language Clean. The purpose of a proof assistant is to use formal reasoning to verify the correctness of a computer program. Formal reasoning is very powerful, but is unfortunately also difficult to carry out. Due to their mathematical nature, functional programming languages are well suited for formal reasoning.
2002
Sparkle is a new theorem prover written in and specialized for the functional programming language Clean. It is mainly intended to be used by programmers for proving properties of parts of programs, combining programming and reasoning into one process. It can also be used by logicians interested in proving properties of larger programs. Two features of Sparkle are in particular helpful for programmers. Firstly, Sparkle is integrated in Clean and has a semantics based on lazy graph-rewriting.
2007
This report presents the mathematical foundation of the proof assistant Sparkle, which is dedicated to the lazy functional language Clean. The mathematical foundation provides a formalization of the programming, logic and proof languages that are supported by Sparkle. Furthermore, it formalizes the reduction of programs and the semantics of properties, and provides proofs for the soundness of the dened tactics.
1999
This paper examines an approach to computer assisted formalreasoning in relation to functional programming. Instead of usinga generic proof tool which may di# er on some points from the functionallanguage used, a new proof tool is to be developed which is solelyintended for proving properties of programs written in one specific language. This proof tool is intended to be inserted in the Integrated DevelopmentEnvironment of the programming language, which ensures aseamless integration.
2004
Abstract: Sparkle is a proof assistant designed for the lazy functional programming language Clean. It is designed to facilitate proofs of first order logical predicates on existing and newly written programs. In order to achieve this it is of the utmost importance that the proof system is easy to use and integrated into the IDE. The implementation of Sparkle only has a basic induction principle so far. For many programs and complex proofs this will not suffice.
Science of Computer Programming, 1995
In this paper we present a new programming technique for lazy functional programming languages. The technique is embedded in a programming methodology which is based on divide and conquer: the division of problems into subproblems. Such a division will be represented by a call graph.
Theoretical Computer Science, 1989
A denotationaf semantics for the A-calculus is described. The semantics is cotinuationbased, and so reflects the order in which expressions are evaluated. It provides a means by which lazy functional languages can be better understood.
Electronic Notes in Theoretical Computer Science, 2009
This paper is based on a recently developed technique to build debugging tools for lazy functional programming languages. With this technique it is possible to replay the execution of a lazy program with a strict semantics by recording information of unevaluated expressions. The recorded information is called an oracle and is very compact. Oracles contain the number of strict steps between discarding unevaluated expressions. The technique has already been successfully employed to construct a debugger for lazy functional languages. This paper extends the technique to include also lazy functional logic languages. A debugging tool built with the technique can be downloaded at www-ps.informatik.uni-kiel.de/~bbr.
2014
We report on the design and preliminary evaluation of a short introductory course on interactive theorem proving and program verification using the Coq proof assistant, targeted at students with background in functional programming and software engineering. The course builds on concepts familiar from functional programming to develop understanding of logic and mechanized proving by means of the Curry-Howard isomorphism. A particular emphasis is made of the computational nature of decidable properties of various data structures. This approach is of practical importance, as Coq’s normalization can automatically simplify or discharge such properties, thus reducing the burden of constructing the proofs by hand. As a basis for teaching this style of mechanization, we use Gonthier et al.’s Ssreflect extension of Coq and its associated libraries. In the course, we minimize the exposure to ad-hoc proof automation via tactics, and request that students develop proofs using only a small set o...
2007
Partial Evaluation is a well-known technique for specializing programs w.r.t. a given restriction of their input data. Although partial evaluation has been widely investigated in the context of functional and functional logic languages like Haskell or Curry, current schemes are either overly restrictive or destroy sharing through the specialization process, which may produce incorrect specializations when non-deterministic functions are considered. In this work, we present a new partial evaluation scheme for lazy functional logic programs that preserves sharing through the specialization process and still allows the unfolding of arbitrary functions. Furthermore, our approach ensures that sharing is also preserved across non-deterministic computations.
Artificial Intelligence …, 2003
Acta Cybernetica, 2005
Journal of Functional Programming, 1994
Lecture Notes in Computer Science, 2003
Journal of Functional Programming, 1996
Lecture Notes in Computer Science, 2011
Electronic Notes in Theoretical Computer Science, 2002
Lecture Notes in Computer Science, 2008
Lecture Notes in Computer Science, 2012
Lecture Notes in Computer Science, 2008