Efficient and automatic implementation of the adjoint state method
Combination of object-oriented programming with automatic differentiation techniques facilitates the solution of data fitting, control, and design problems driven by explicit time stepping schemes for initial-boundary value problems. The C++ class fdtd takes a complete specification of a single step, along with some associated code, and assembles from it a complete simulator, along with the linearized and adjoint simulations. The result is a (nonlinear) operator in the sense of the Hilbert Class Library (HCL), a C++ software package for optimization. The HCL operator so produced links directly with any of the HCL optimization algorithms. Moreover the performance of simulators constructed in this way is equivalent to that of optimized Fortran implementations.
ACM Transactions on Mathematical Software
Symes, W. W.
Efficient and automatic implementation of the adjoint state method.
ACM Transactions on Mathematical Software,
Retrieved from: https://digitalcommons.mtu.edu/math-fp/30