11 #ifndef OOPS_ASSIMILATION_HMATRIX_H_
12 #define OOPS_ASSIMILATION_HMATRIX_H_
17 #include <boost/noncopyable.hpp>
36 template<
typename MODEL,
typename OBS>
class HMatrix :
private boost::noncopyable {
48 for (
unsigned jj = 0; jj <
j_.
nterms(); ++jj) {
55 for (
unsigned jj = 0; jj <
j_.
nterms(); ++jj) {
58 dy.
append(std::move(dytmp));
virtual void runTLM(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 computeCostTL(const ControlIncrement< MODEL, OBS > &, GeneralizedDepartures &) const =0
Finish cost computation after TL model integration.
virtual std::unique_ptr< GeneralizedDepartures > newDualVector() const =0
Provide new dual space vector (for example a Departure for Jo).
virtual void setPostProcTL(const ControlIncrement< MODEL, OBS > &, PostProcTLAD_ &) const =0
Initialize and set TL post-processors to collect data during TL model integration.
Container of dual space vectors for all terms of the cost function.
void append(std::unique_ptr< GeneralizedDepartures > &&)
CostFunction< MODEL, OBS > CostFct_
Increment< MODEL > Increment_
HMatrix(const CostFct_ &j)
ControlIncrement< MODEL, OBS > CtrlInc_
void multiply(CtrlInc_ &dx, DualVector< MODEL, OBS > &dy, 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.