11 #ifndef OOPS_ASSIMILATION_PLANCZOSMINIMIZER_H_
12 #define OOPS_ASSIMILATION_PLANCZOSMINIMIZER_H_
40 const std::string
classname()
const override {
return "PLanczosMinimizer";}
48 const int,
const double)
override;
53 template<
typename MODEL,
typename OBS>
56 const int ninner,
const double gnreduc) {
58 double reduc =
PLanczos(dx, rhs, hessian, B, ninner, gnreduc);
Preconditioned Lanczos solver.
double solve(CtrlInc_ &, const CtrlInc_ &, const Hessian_ &, const Bmat_ &, const int, const double) override
const std::string classname() const override
BMatrix< MODEL, OBS > Bmat_
HessianMatrix< MODEL, OBS > Hessian_
ControlIncrement< MODEL, OBS > CtrlInc_
CostFunction< MODEL, OBS > CostFct_
PLanczosMinimizer(const eckit::Configuration &, const CostFct_ &J)
The namespace for the main oops code.
double PLanczos(VECTOR &xx, const VECTOR &bb, const AMATRIX &A, const PMATRIX &precond, const int maxiter, const double tolerance)