11 #ifndef OOPS_ASSIMILATION_COSTJCDFI_H_
12 #define OOPS_ASSIMILATION_COSTJCDFI_H_
17 #include "eckit/config/LocalConfiguration.h"
31 #include "oops/util/DateTime.h"
32 #include "oops/util/Duration.h"
33 #include "oops/util/Logger.h"
56 const util::Duration &,
const util::Duration & tstep = util::Duration(0));
75 void computeCostAD(std::shared_ptr<const GeneralizedDepartures>,
80 std::unique_ptr<GeneralizedDepartures>
82 std::unique_ptr<GeneralizedDepartures>
86 std::unique_ptr<GeneralizedDepartures>
newDualVector()
const override;
89 std::unique_ptr<GeneralizedDepartures>
newGradientFG()
const override;
98 std::unique_ptr<WeightingFct>
wfct_;
104 mutable std::shared_ptr<WeightedDiff<MODEL, Increment_, State_> >
filter_;
105 mutable std::shared_ptr<WeightedDiffTLAD<MODEL> >
ftlad_;
111 template<
typename MODEL,
typename OBS>
113 const util::DateTime & vt,
const util::Duration & span,
114 const util::Duration & tstep)
115 : vt_(vt), span_(span), alpha_(0), wfct_(), gradFG_(),
116 resol_(resol), tstep_(tstep), tlres_(), tlstep_(), filter_(), vars_(conf,
"filtered variables")
118 alpha_ = conf.getDouble(
"alpha");
119 if (conf.has(
"ftime"))
vt_ = util::DateTime(conf.getString(
"ftime"));
120 if (conf.has(
"span"))
span_ = util::Duration(conf.getString(
"span"));
123 Log::trace() <<
"CostJcDFI created" << std::endl;
128 template<
typename MODEL,
typename OBS>
132 tstep_, resol_, *wfct_));
138 template<
typename MODEL,
typename OBS>
140 double zz = 0.5 * alpha_;
141 std::unique_ptr<Increment_> dx(filter_->releaseDiff());
142 zz *= dot_product(*dx, *dx);
143 Log::test() <<
"CostJcDFI: Nonlinear Jc = " << zz << std::endl;
149 template<
typename MODEL,
typename OBS>
153 tlstep_ = util::Duration(conf.getString(
"linear model.tstep", tstep_.toString()));
160 template<
typename MODEL,
typename OBS>
162 gradFG_.reset(ftlad_->releaseDiff());
168 template<
typename MODEL,
typename OBS>
170 ftlad_->setupTL(*tlres_);
176 template<
typename MODEL,
typename OBS>
178 Log::trace() <<
"CostJcDFI::computeCostTL start" << std::endl;
180 ftlad_->finalTL(ydep);
181 Log::trace() <<
"CostJcDFI::computeCostTL done" << std::endl;
186 template<
typename MODEL,
typename OBS>
189 Log::trace() <<
"CostJcDFI::computeCostAD start" << std::endl;
190 std::shared_ptr<const Increment_> dx = std::dynamic_pointer_cast<const Increment_>(pv);
193 Log::trace() <<
"CostJcDFI::computeCostAD done" << std::endl;
198 template<
typename MODEL,
typename OBS>
199 std::unique_ptr<GeneralizedDepartures>
202 std::unique_ptr<Increment_> dx2(
new Increment_(dx1));
203 const double za = 1.0/alpha_;
205 return std::move(dx2);
210 template<
typename MODEL,
typename OBS>
211 std::unique_ptr<GeneralizedDepartures>
214 std::unique_ptr<Increment_> dx2(
new Increment_(dx1));
216 return std::move(dx2);
221 template<
typename MODEL,
typename OBS>
223 std::unique_ptr<Increment_> dx(
new Increment_(*tlres_, vars_, vt_));
224 return std::move(dx);
229 template<
typename MODEL,
typename OBS>
231 return std::unique_ptr<Increment_>(
new Increment_(*gradFG_));
236 template<
typename MODEL,
typename OBS>
void computeCostTraj() override
Finish cost computation and trajectory handling after nonlinear model integration.
void setPostProc(const CtrlVar_ &, const eckit::Configuration &, PostProc_ &) override
Nonlinear Jc DFI computation.
void setPostProcTL(const CtrlInc_ &, PostProcTLAD_ &) const override
TL Jc DFI computation.
Geometry< MODEL > Geometry_
ControlIncrement< MODEL, OBS > CtrlInc_
std::unique_ptr< GeneralizedDepartures > multiplyCoInv(const GeneralizedDepartures &) const override
std::unique_ptr< GeneralizedDepartures > multiplyCovar(const GeneralizedDepartures &) const override
Multiply by and .
ControlVariable< MODEL, OBS > CtrlVar_
CostJcDFI(const eckit::Configuration &, const Geometry_ &, const util::DateTime &, const util::Duration &, const util::Duration &tstep=util::Duration(0))
Construct .
std::shared_ptr< WeightedDiffTLAD< MODEL > > ftlad_
virtual ~CostJcDFI()
Destructor.
std::shared_ptr< WeightedDiff< MODEL, Increment_, State_ > > filter_
std::unique_ptr< Increment_ > gradFG_
const util::Duration tstep_
PostProcessorTLAD< MODEL > PostProcTLAD_
void computeCostAD(std::shared_ptr< const GeneralizedDepartures >, CtrlInc_ &, PostProcTLAD_ &) const override
Adjoint Jc DFI computation.
void resetLinearization() override
Reset trajectory.
void computeCostTL(const CtrlInc_ &, GeneralizedDepartures &) const override
Finish cost computation after TL model integration.
void setPostProcTraj(const CtrlVar_ &, const eckit::Configuration &, const Geometry_ &, PostProcTLAD_ &) override
Linearization trajectory for Jc DFI computation.
Increment< MODEL > Increment_
std::unique_ptr< GeneralizedDepartures > newDualVector() const override
Provide new increment.
double computeCost() override
Finish computation of cost function term after nonlinear model integration.
PostProcessor< State_ > PostProc_
std::unique_ptr< GeneralizedDepartures > newGradientFG() const override
Gradient of at first guess.
std::unique_ptr< Geometry_ > tlres_
std::unique_ptr< WeightingFct > wfct_
void setPostProcAD() const override
Adjoint ot setPostProcTL (clean-up)
Base Class for Cost Function Terms.
Abstract base class for quantities.
Geometry class used in oops; subclass of interface class interface::Geometry.
Increment class used in oops.
Control model post processing.
void enrollProcessor(PostBase_ *pp)
Control model post processing.
void enrollProcessor(PostBaseTLAD_ *pp)
State class used in oops; subclass of interface class interface::State.
Compute time average of states or increments during model run.
Compute time average of states or increments during linear model run.
The namespace for the main oops code.