Publication | Open Access
Toward automatic program synthesis
293
Citations
15
References
1971
Year
Elementary OutlineEngineeringInduction RuleVerificationSoftware EngineeringSoftware AnalysisFormal VerificationProgram TransformationProgram DerivationAutomatic ProgrammingComputer ScienceSoftware DesignProgram AnalysisAutomated ReasoningSoftware TestingAutomatic Program SynthesisFormal MethodsProgram SynthesisRecursive FunctionComputability Theory
The paper outlines a theorem‑proving approach to automatic program synthesis, illustrating it with automatic construction of recursive and iterative programs over natural numbers, lists, and trees. The method constructs programs by proving a theorem induced from specifications and extracting the program from the proof, using mathematical induction to handle loops or recursion, and examining how different induction rules affect the resulting program form. Applying the technique transforms recursively defined functions into iterative programs, often yielding major efficiency gains.
An elementary outline of the theorem-proving approach to automatic program synthesis is given, without dwelling on technical details. The method is illustrated by the automatic construction of both recursive and iterative programs operating on natural numbers, lists, and trees. In order to construct a program satisfying certain specifications, a theorem induced by those specifications is proved, and the desired program is extracted from the proof. The same technique is applied to transform recursively defined functions into iterative programs, frequently with a major gain in efficiency. It is emphasized that in order to construct a program with loops or with recursion, the principle of mathematical induction must be applied. The relation between the version of the induction rule used and the form of the program constructed is explored in some detail.
| Year | Citations | |
|---|---|---|
Page 1
Page 1