11 #ifndef OOPS_ASSIMILATION_HTMATRIX_H_
12 #define OOPS_ASSIMILATION_HTMATRIX_H_
14 #include <boost/noncopyable.hpp>
33 template<
typename MODEL,
typename OBS>
class HtMatrix :
private boost::noncopyable {
41 const bool idModel =
false)
const {
45 for (
unsigned jj = 0; jj <
j_.
nterms(); ++jj) {
49 for (
unsigned jj = 0; jj <
j_.
nterms(); ++jj) {
virtual void runADJ(CtrlInc_ &, PostProcessorTLAD< MODEL > &, PostProcessor< Increment_ > post=PostProcessor< Increment_ >(), const bool idModel=false) const =0
const CostBase_ & jterm(const size_t ii) const
Access terms of the cost function other than .
virtual void computeCostAD(std::shared_ptr< const GeneralizedDepartures >, ControlIncrement< MODEL, OBS > &, PostProcTLAD_ &) const =0
Adjoint of computeCostTL (initialize and set post-processors adjoint to force AD model)
virtual void setPostProcAD() const =0
Adjoint ot setPostProcTL (clean-up)
Container of dual space vectors for all terms of the cost function.
std::shared_ptr< const GeneralizedDepartures > getv(const unsigned) const
HtMatrix(const CostFct_ &j)
CostFunction< MODEL, OBS > CostFct_
Increment< MODEL > Increment_
void multiply(const DualVector< MODEL, OBS > &dy, ControlIncrement< MODEL, OBS > &dx, const bool idModel=false) const
Increment class used in oops.
Control model post processing.
Control model post processing.
The namespace for the main oops code.