11 #ifndef OOPS_ASSIMILATION_SADDLEPOINTMATRIX_H_
12 #define OOPS_ASSIMILATION_SADDLEPOINTMATRIX_H_
17 #include <boost/noncopyable.hpp>
33 template<
typename MODEL,
typename OBS>
49 template<
typename MODEL,
typename OBS>
59 j_.jb().initializeAD(z.
dx(), x.
lambda().
dx(), costad);
60 for (
unsigned jj = 0; jj < j_.nterms(); ++jj) {
61 j_.jterm(jj).computeCostAD(x.
lambda().
getv(jj), ww, costad);
63 j_.runADJ(ww, costad);
65 for (
unsigned jj = 0; jj < j_.nterms(); ++jj) {
66 j_.jterm(jj).setPostProcAD();
72 for (
unsigned jj = 0; jj < j_.nterms(); ++jj) {
73 j_.jterm(jj).setPostProcTL(x.
dx(), costtl);
76 j_.runTLM(mdx, costtl);
80 for (
unsigned jj = 0; jj < j_.nterms(); ++jj) {
81 std::unique_ptr<GeneralizedDepartures> ztmp(j_.jterm(jj).newDualVector());
82 j_.jterm(jj).computeCostTL(x.
dx(), *ztmp);
90 for (
unsigned jj = 0; jj < j_.nterms(); ++jj) {
Container of dual space vectors for all terms of the cost function.
void append(std::unique_ptr< GeneralizedDepartures > &&)
std::shared_ptr< const GeneralizedDepartures > getv(const unsigned) const
Control model post processing.
void initializeTL(const Increment_ &dx, const util::DateTime &end, const util::Duration &step)
Tangent linear methods.
ControlIncrement< MODEL, OBS > CtrlInc_
void multiply(const SPVector_ &, SPVector_ &) const
CostFunction< MODEL, OBS > CostFct_
SaddlePointMatrix(const CostFct_ &j)
SaddlePointVector< MODEL, OBS > SPVector_
Control vector for the saddle point formulation.
const Multipliers_ & lambda() const
Accessor method to get the lambda_ component.
const CtrlInc_ & dx() const
Accessor method to get the dx_ component.
The namespace for the main oops code.