11 #ifndef QG_MODEL_STATEQG_H_
12 #define QG_MODEL_STATEQG_H_
19 #include "oops/util/DateTime.h"
20 #include "oops/util/ObjectCounter.h"
21 #include "oops/util/Printable.h"
23 #include "oops/qg/FieldsQG.h"
42 private util::ObjectCounter<StateQG> {
44 static const std::string
classname() {
return "qg::StateQG";}
61 void read(
const eckit::Configuration &);
62 void write(
const eckit::Configuration &)
const;
71 std::shared_ptr<const GeometryQG>
geometry()
const {
78 void serialize(std::vector<double> &)
const;
79 void deserialize(
const std::vector<double> &,
size_t &);
86 void print(std::ostream &)
const;
Class to represent a Fields for the QG model.
GeometryQG handles geometry for QG model.
Increment Class: Difference between two states.
void print(std::ostream &) const
void write(const eckit::Configuration &) const
StateQG & operator+=(const IncrementQG &)
Interactions with Increment.
std::shared_ptr< const GeometryQG > geometry() const
void accumul(const double &, const StateQG &)
StateQG & operator=(const StateQG &)
Basic operators.
static const std::string classname()
void changeResolution(const StateQG &xx)
Interpolate full fields.
FieldsQG & fields()
Access to fields.
const util::DateTime & validTime() const
void updateTime(const util::Duration &dt)
std::unique_ptr< FieldsQG > fields_
void read(const eckit::Configuration &)
I/O and diagnostics.
void serialize(std::vector< double > &) const
size_t serialSize() const
Serialization.
void deserialize(const std::vector< double > &, size_t &)
const FieldsQG & fields() const
StateQG(const GeometryQG &, const oops::Variables &, const util::DateTime &)
Constructor, destructor.
util::DateTime & validTime()
const oops::Variables & variables() const
The namespace for the main oops code.
The namespace for the qg model.