Verifying an Effect-Handler-Based Define-By-Run Reverse-Mode AD Library

From MaRDI portal
Publication:6178671

DOI10.46298/LMCS-19(4:5)2023arXiv2112.07292MaRDI QIDQ6178671FDOQ6178671


Authors: Paulo Emílio de Vilhena, François Pottier Edit this on Wikidata


Publication date: 16 January 2024

Published in: Logical Methods in Computer Science (Search for Journal in Brave)

Abstract: We apply program verification technology to the problem of specifying and verifying automatic differentiation (AD) algorithms. We focus on ``define-by-run, a style of AD where the program that must be differentiated is executed and monitored by the automatic differentiation algorithm. We begin by asking, ``what is an implementation of AD? and ``what does it mean for an implementation of AD to be correct? We answer these questions both at an informal level, in precise English prose, and at a formal level, using types and logical assertions. After answering these broad questions, we focus on a specific implementation of AD, which involves a number of subtle programming language features, including dynamically allocated mutable state, first-class functions, and effect handlers. We present a machine-checked proof, expressed in a modern variant of Separation Logic, of its correctness. We view this result as an advanced exercise in program verification, with potential future applications to the verification of more realistic automatic differentiation systems and of other software components that exploit delimited control effects.


Full work available at URL: https://arxiv.org/abs/2112.07292




Recommendations




Cites Work






This page was built for publication: Verifying an Effect-Handler-Based Define-By-Run Reverse-Mode AD Library

Report a bug (only for logged in users!)Click here to report a bug for this page (MaRDI item Q6178671)