11 #ifndef OOPS_ASSIMILATION_RINVMATRIX_H_
12 #define OOPS_ASSIMILATION_RINVMATRIX_H_
14 #include <boost/noncopyable.hpp>
29 template<
typename MODEL,
typename OBS>
class RinvMatrix :
private boost::noncopyable {
38 for (
unsigned jj = 0; jj <
j_.
nterms(); ++jj) {
const CostBase_ & jterm(const size_t ii) const
Access terms of the cost function other than .
virtual std::unique_ptr< GeneralizedDepartures > multiplyCoInv(const GeneralizedDepartures &) const =0
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
void multiply(const Dual_ &dx, Dual_ &dy) const
CostFunction< MODEL, OBS > CostFct_
RinvMatrix(const CostFct_ &j)
DualVector< MODEL, OBS > Dual_
The namespace for the main oops code.