8 #ifndef OOPS_BASE_STATE_H_
9 #define OOPS_BASE_STATE_H_
31 template <
typename MODEL>
33 typedef typename MODEL::State
State_;
49 void print(std::ostream &)
const override;
54 template<
typename MODEL>
56 const util::DateTime & time) :
57 interface::
State<MODEL>(resol, vars, time), commTime_(&resol.timeComm())
62 template<
typename MODEL>
64 interface::
State<MODEL>(resol, conf), commTime_(&resol.timeComm())
69 template<
typename MODEL>
71 interface::
State<MODEL>(resol, other), commTime_(&resol.timeComm())
76 template<
typename MODEL>
80 commTime_->allReduceInPlace(zz, eckit::mpi::Operation::SUM);
87 template<
typename MODEL>
89 if (commTime_->size() > 1) {
90 gatherPrint(os, this->state(), *commTime_);
Geometry class used in oops; subclass of interface class interface::Geometry.
State class used in oops; subclass of interface class interface::State.
double norm() const
Norm (used in tests)
State(const Geometry_ &resol, const Variables &vars, const util::DateTime &time)
Constructor for specified resol, with vars, valid at time.
const eckit::mpi::Comm * commTime_
Geometry< MODEL > Geometry_
void print(std::ostream &) const override
pointer to the MPI communicator in time
Encapsulates the model state.
double norm() const
Norm (used in tests)
The namespace for the main oops code.