Publication | Closed Access
A theory of changes for higher-order languages
21
Citations
21
References
2014
Year
EngineeringCompiler TechnologySoftware SystemsChomsky HierarchyHigher-order LogicSoftware AnalysisHardware SystemsFormal VerificationSyntaxDependently Typed ProgrammingProgram TransformationGrammarLanguage StudiesCompilersDynamic CompilationProgramming LanguagesCompiler SupportLanguage ChangeComputer EngineeringComputer ScienceHigher-order LanguagesChosen PrimitivesProgram AnalysisProgram Transformation CorrectFormal MethodsMathematical FoundationsLinguistics
If the result of an expensive computation is invalidated by a small change to the input, the old result should be updated incrementally instead of reexecuting the whole computation. We incrementalize programs through their derivative . A derivative maps changes in the program's input directly to changes in the program's output, without reexecuting the original program. We present a program transformation taking programs to their derivatives, which is fully static and automatic, supports first-class functions, and produces derivatives amenable to standard optimization. We prove the program transformation correct in Agda for a family of simply-typed λ-calculi, parameterized by base types and primitives. A precise interface specifies what is required to incrementalize the chosen primitives. We investigate performance by a case study: We implement in Scala the program transformation, a plugin and improve performance of a nontrivial program by orders of magnitude.
| Year | Citations | |
|---|---|---|
Page 1
Page 1