11 #ifndef QG_MODEL_GEOMETRYQG_H_
12 #define QG_MODEL_GEOMETRYQG_H_
19 #include "atlas/field.h"
20 #include "atlas/functionspace.h"
22 #include "eckit/mpi/Comm.h"
24 #include "oops/util/ObjectCounter.h"
25 #include "oops/util/parameters/Parameter.h"
26 #include "oops/util/parameters/Parameters.h"
27 #include "oops/util/parameters/RequiredParameter.h"
28 #include "oops/util/Printable.h"
30 #include "oops/qg/GeometryQGIterator.h"
31 #include "oops/qg/QgFortran.h"
44 oops::RequiredParameter<int>
nx{
"nx",
this};
45 oops::RequiredParameter<int>
ny{
"ny",
this};
47 oops::RequiredParameter<std::vector<float>>
depths{
"depths",
this};
49 oops::Parameter<bool>
heating{
"heating",
true,
this};
52 class GeometryQGIterator;
58 private util::ObjectCounter<GeometryQG> {
62 static const std::string
classname() {
return "qg::GeometryQG";}
81 void print(std::ostream &)
const;
GeometryQG handles geometry for QG model.
GeometryQgParameters Parameters_
const F90geom & toFortran() const
atlas::FieldSet * atlasFieldSet() const
std::unique_ptr< atlas::functionspace::PointCloud > atlasFunctionSpace_
const eckit::mpi::Comm & getComm() const
std::vector< double > verticalCoord(std::string &) const
GeometryQGIterator begin() const
GeometryQG & operator=(const GeometryQG &)
std::unique_ptr< atlas::FieldSet > atlasFieldSet_
static const std::string classname()
std::vector< size_t > variableSizes(const oops::Variables &vars) const
GeometryQGIterator end() const
atlas::FunctionSpace * atlasFunctionSpace() const
void print(std::ostream &) const
const eckit::mpi::Comm & comm_
GeometryQG(const GeometryQgParameters &, const eckit::mpi::Comm &)
oops::Parameter< bool > heating
Heating option (AS: should it be in geometry or model?)
oops::RequiredParameter< std::vector< float > > depths
Depths.
oops::RequiredParameter< int > nx
Domain size.
oops::RequiredParameter< int > ny
The namespace for the main oops code.
The namespace for the qg model.