English

Denotationally Correct, Purely Functional, Efficient Reverse-mode Automatic Differentiation

Programming Languages 2023-04-27 v2

Abstract

Reverse-mode differentiation is used for optimization, but it introduces references, which break the purity of the underlying programs, making them notoriously harder to optimize. We present a reverse-mode differentiation on a purely functional language with array operations. It is the first one to deliver a provably efficient, purely functional, and denotationally correct reverse-mode differentiation. We show that our transformation is semantically correct and verifies the cheap gradient principle. Inspired by PROPs and compilation to categories, we introduce a novel intermediate representation that we call 'unary form'. Our reverse-mode transformation is factored as a compilation scheme through this intermediate representation. We obtain provably efficient gradients by performing general partial evaluation optimizations after our reverse-mode transformation, as opposed to manually derived ones. For simple first-order programs, the obtained output programs resemble static-single-assignment (SSA) code. We emphasize the modularity of our approach and show how our language can easily be enriched with more optimized primitives, as required for some speed-ups in practice.

Keywords

Cite

@article{arxiv.2212.09801,
  title  = {Denotationally Correct, Purely Functional, Efficient Reverse-mode Automatic Differentiation},
  author = {Mathieu Huot and Amir Shaikhha},
  journal= {arXiv preprint arXiv:2212.09801},
  year   = {2023}
}

Comments

34 pages, 17 figures