10#ifndef EIGEN_ADLOC_FORWARD_MODULE_H
11#define EIGEN_ADLOC_FORWARD_MODULE_H
25#ifndef NUMBER_DIRECTIONS
26#define NUMBER_DIRECTIONS 2
28#include <adolc/adtl.h>
43#include "../../Eigen/Core"
71inline const adouble& conj(
const adouble& x) {
return x; }
72inline const adouble& real(
const adouble& x) {
return x; }
73inline adouble imag(
const adouble&) {
return 0.; }
74inline adouble abs(
const adouble& x) {
return fabs(x); }
75inline adouble abs2(
const adouble& x) {
return x * x; }
77inline bool(isinf)(
const adouble& x) {
return (Eigen::numext::isinf)(x.getValue()); }
78inline bool(isnan)(
const adouble& x) {
return (Eigen::numext::isnan)(x.getValue()); }
86 typedef adtl::adouble Real;
87 typedef adtl::adouble NonInteger;
88 typedef adtl::adouble Nested;
93 RequireInitialization = 1,
100template <
typename Functor>
101class AdolcForwardJacobian :
public Functor {
102 typedef adtl::adouble ActiveScalar;
105 AdolcForwardJacobian() : Functor() {}
106 AdolcForwardJacobian(
const Functor& f) : Functor(f) {}
109 template <
typename T0>
110 AdolcForwardJacobian(
const T0& a0) : Functor(a0) {}
111 template <
typename T0,
typename T1>
112 AdolcForwardJacobian(
const T0& a0,
const T1& a1) : Functor(a0, a1) {}
113 template <
typename T0,
typename T1,
typename T2>
114 AdolcForwardJacobian(
const T0& a0,
const T1& a1,
const T1& a2) : Functor(a0, a1, a2) {}
116 typedef typename Functor::InputType InputType;
117 typedef typename Functor::ValueType ValueType;
118 typedef typename Functor::JacobianType JacobianType;
120 typedef Matrix<ActiveScalar, InputType::SizeAtCompileTime, 1> ActiveInput;
121 typedef Matrix<ActiveScalar, ValueType::SizeAtCompileTime, 1> ActiveValue;
123 void operator()(
const InputType& x, ValueType* v, JacobianType* _jac)
const {
124 eigen_assert(v != 0);
126 Functor::operator()(x, v);
130 JacobianType& jac = *_jac;
132 ActiveInput ax = x.template cast<ActiveScalar>();
133 ActiveValue av(jac.rows());
135 for (
int j = 0; j < jac.cols(); j++)
136 for (
int i = 0; i < jac.cols(); i++) ax[i].setADValue(j, i == j ? 1 : 0);
138 Functor::operator()(ax, &av);
140 for (
int i = 0; i < jac.rows(); i++) {
141 (*v)[i] = av[i].getValue();
142 for (
int j = 0; j < jac.cols(); j++) jac.coeffRef(i, j) = av[i].getADValue(j);
Namespace containing all symbols from the Eigen library.