A C++ implementation of the discrete adjoint sensitivity analysis method for explicit adaptive Runge-Kutta methods enabled by automatic adjoint differentiation and SIMD vectorization
Rui Martins, Evgeny Lakshtanov
TL;DR
This work presents a C++ library implementing the discrete adjoint sensitivity analysis for adaptive explicit Runge-Kutta methods, enhanced by automatic adjoint differentiation and SIMD vectorization. By avoiding a black-box AD approach to the entire solver and employing a targeted discrete adjoint formulation, it achieves efficient vector-Jacobian product evaluations via AAD and parallelization through AVX. The authors compare against established tools, showing competitive or superior performance in large-parameter regimes, while adopting a memory-efficient checkpointing strategy. The approach enables efficient gradient computation for optimization and parameter estimation in ODE-based models, with potential extensions to more integrators and second-order adjoints. Overall, the work advances scalable sensitivity analysis for complex, parameter-rich dynamical systems using modern CPU architectures.
Abstract
A C++ library for sensitivity analysis of optimisation problems involving ordinary differential equations (ODEs) enabled by automatic differentiation (AD) and SIMD (Single Instruction, Multiple data) vectorization is presented. The discrete adjoint sensitivity analysis method is implemented for adaptive explicit Runge-Kutta (ERK) methods. Automatic adjoint differentiation (AAD) is employed for efficient evaluations of products of vectors and the Jacobian matrix of the right hand side of the ODE system. This approach avoids the low-level drawbacks of the black box approach of employing AAD on the entire ODE solver and opens the possibility to leverage parallelization. SIMD vectorization is employed to compute the vector-Jacobian products concurrently. We study the performance of other methods and implementations of sensitivity analysis and we find that our algorithm presents a small advantage compared to equivalent existing software.
