CoDiPack  2.3.0
A Code Differentiation Package
SciComp TU Kaiserslautern
Loading...
Searching...
No Matches
Example 8 - Generalized adjoint vector interface

Goal: Use the generialized interface for the adjoint vector access.

Prerequisite: Example 2 - Custom adjoint vector evaluation

Function: Simple vector valued function

template<typename Real>
void func(const Real* x, size_t l, Real* y) {
y[0] = 0.0;
y[1] = 1.0;
for(size_t i = 0; i < l; ++i) {
y[0] += x[i];
y[1] *= x[i];
}
}

Full code:

#include <codi.hpp>
#include <iostream>
template<typename Real>
void func(const Real* x, size_t l, Real* y) {
y[0] = 0.0;
y[1] = 1.0;
for(size_t i = 0; i < l; ++i) {
y[0] += x[i];
y[1] *= x[i];
}
}
int main(int nargs, char** args) {
using Tape = typename Real::Tape;
Real x[5];
Real y[2];
x[0] = 1.0;
x[1] = 2.0;
x[2] = 3.0;
x[3] = 4.0;
x[4] = 5.0;
// Step 1: Perform a regular recording
Tape& tape = Real::getTape();
tape.setActive();
for(size_t i = 0; i < 5; ++i) {
tape.registerInput(x[i]);
}
func(x, 5, y);
tape.registerOutput(y[0]);
tape.registerOutput(y[1]);
tape.setPassive();
// Step 1: Create the helper and the get access to the vector interface
for(size_t dim = 0; dim < ai->getVectorSize(); ++dim) {
ai->updateAdjoint(y[dim].getIdentifier(), dim, 1.0); // Step 2: Set the seeding with the interface
}
vh->evaluate(); // Step 3: Call evaluate on the vector helper.
// Step 4: Get the gradients from the interface.
codi::Jacobian<double> jacobian(2,5);
for(size_t i = 0; i < 5; ++i) {
for(size_t dim = 0; dim < ai->getVectorSize(); ++dim) {
jacobian(dim,i) = ai->getAdjoint(x[i].getIdentifier(), dim);
}
}
std::cout << "Custom adjoint vector interface:" << std::endl;
std::cout << "f(1 .. 5) = (" << y[0] << ", " << y[1] << ")" << std::endl;
std::cout << "df/dx (1 .. 5) = \n" << jacobian << std::endl;
tape.reset();
delete vh;
return 0;
}
size_t constexpr dim()
Number of dimensions this gradient value has.
Definition gradientTraits.hpp:96
General interface for an arbitrary adjoint evaluation.
Definition customAdjointVectorHelper.hpp:61
virtual VectorAccessInterface< Real, Identifier > * getVectorInterface()=0
Get a new general interface to the adjoint vector.
virtual void evaluate(Position const &start, Position const &end)=0
Perform a reverse evaluation for a part of the tape. It hast to hold start >= end.
Unified access to the adjoint vector and primal vector in a tape evaluation.
Definition vectorAccessInterface.hpp:91

Since the (CustomAdjointVectorHelper) is hardcoded to the adjoint vector type, there is also a codi::CustomAdjointVectorInterface definition. This interface allows to program for an arbitrary vector dimension. In order to access the vector with this interface the codi::VectorAccessInterface needs to be used. It can be obtained via the method getVectorInterface.