OOPS
|
Jb Cost Function. More...
#include <CostJb3D.h>
Public Member Functions | |
CostJb3D (const eckit::Configuration &, const Geometry_ &, const Variables &, const util::Duration &, const State_ &) | |
Construct \( J_b\). More... | |
virtual | ~CostJb3D () |
Destructor. More... | |
void | computeIncrement (const State_ &, const State_ &, const State_ &, Increment_ &) const override |
Get increment from state (usually first guess). More... | |
void | linearize (const State_ &, const Geometry_ &) override |
Linearize before the linear computations. More... | |
void | addGradient (const Increment_ &, Increment_ &, Increment_ &) const override |
Add Jb gradient. More... | |
JqTermTLAD< MODEL > * | initializeJqTLAD () const override |
Empty Jq observer. More... | |
JqTermTLAD< MODEL > * | initializeJqTL () const override |
Empty TL Jq observer. More... | |
JqTermTLAD< MODEL > * | initializeJqAD (const Increment_ &) const override |
Empty AD Jq observer. More... | |
void | Bmult (const Increment_ &, Increment_ &) const override |
Multiply by \( B\) and \( B^{-1}\). More... | |
void | Bminv (const Increment_ &, Increment_ &) const override |
void | randomize (Increment_ &) const override |
Randomize. More... | |
Increment_ * | newStateIncrement () const override |
Create new increment (set to 0). More... | |
![]() | |
CostJbState () | |
Constructor. More... | |
virtual | ~CostJbState () |
Destructor. More... | |
Private Types | |
typedef Geometry< MODEL > | Geometry_ |
typedef Increment< MODEL > | Increment_ |
typedef State< MODEL > | State_ |
Private Attributes | |
const State_ & | xb_ |
std::unique_ptr< ModelSpaceCovarianceBase< MODEL > > | B_ |
const util::Duration | winLength_ |
const Variables | controlvars_ |
std::unique_ptr< const Geometry_ > | resol_ |
const util::DateTime | time_ |
const eckit::LocalConfiguration | conf_ |
Jb Cost Function.
The CostJb3D encapsulates the Jb term of the cost function for a 3 dimensional background.
This class is not really necessary since it is only a special case of the more general CostJbJq weak constraint term with one sub-window. It is provided for readability.
Definition at line 43 of file CostJb3D.h.
|
private |
Definition at line 44 of file CostJb3D.h.
|
private |
Definition at line 45 of file CostJb3D.h.
|
private |
Definition at line 46 of file CostJb3D.h.
oops::CostJb3D< MODEL >::CostJb3D | ( | const eckit::Configuration & | config, |
const Geometry_ & | , | ||
const Variables & | ctlvars, | ||
const util::Duration & | len, | ||
const State_ & | xb | ||
) |
Construct \( J_b\).
Definition at line 101 of file CostJb3D.h.
|
inlinevirtual |
Destructor.
Definition at line 54 of file CostJb3D.h.
|
overridevirtual |
|
overridevirtual |
Implements oops::CostJbState< MODEL >.
Definition at line 144 of file CostJb3D.h.
|
overridevirtual |
Multiply by \( B\) and \( B^{-1}\).
Implements oops::CostJbState< MODEL >.
Definition at line 137 of file CostJb3D.h.
|
overridevirtual |
Get increment from state (usually first guess).
Implements oops::CostJbState< MODEL >.
Definition at line 121 of file CostJb3D.h.
|
inlineoverridevirtual |
Empty AD Jq observer.
Implements oops::CostJbState< MODEL >.
Definition at line 73 of file CostJb3D.h.
|
inlineoverridevirtual |
Empty TL Jq observer.
Implements oops::CostJbState< MODEL >.
Definition at line 70 of file CostJb3D.h.
|
inlineoverridevirtual |
|
overridevirtual |
Linearize before the linear computations.
Implements oops::CostJbState< MODEL >.
Definition at line 113 of file CostJb3D.h.
|
overridevirtual |
Create new increment (set to 0).
Implements oops::CostJbState< MODEL >.
Definition at line 159 of file CostJb3D.h.
|
overridevirtual |
|
private |
Definition at line 87 of file CostJb3D.h.
|
private |
Definition at line 92 of file CostJb3D.h.
|
private |
Definition at line 89 of file CostJb3D.h.
|
private |
Definition at line 90 of file CostJb3D.h.
|
private |
Definition at line 91 of file CostJb3D.h.
|
private |
Definition at line 88 of file CostJb3D.h.
|
private |
Definition at line 86 of file CostJb3D.h.