Note: |
|
(LaTeX) Abstract: |
We develop two applications of middle-out reasoning in inductive proofs: the logic program synthesis and the selection of induction schemes. Middle-out reasoning uses variables to represent unknown terms and formulae. Unification instantiates the variables in the subsequent planning, while proof planning provides the necessary search control. Middle-out reasoning is used for synthesis by planning the verification of an unknown logic program: the program body is represented with a meta-variable. The planning results both in an instantiation of the program body and a plan for the verification of that program. If the plan executes successfully, the synthesized program is partially correct and complete. Middle-out reasoning is also used to select induction schemes. In middle-out induction, we set up a schematic step case by representing the constructors that are applied to induction variables with meta-variables. Once the step case is complete, the instantiated variables correspond to an induction appropriate to the recursion of the program. We have implemented these techniques as an extension of the proof planning system CLAM, called Periwinkle, and synthesized a variety of programs fully automatically. |
URL for the Abstract: |
|
Categories,
Keywords: |
automatic programming, inference mechanisms, logic programming, planning (artificial intelligence), program verification, theorem proving, middle-out reasoning, logic program, inductive proofs, proof planning, search control, meta-variable, program verification, Periwinkle, proof planning system CLAM, automated theorem proving |
HyperLinks / References / URLs: |
5299831 INSPEC Abstract No: C9608-6110L-001 |
Copyright Message: |
|
Personal Comments: |
|
Download
Access Level: |
|
|