13 #include "atlas/field.h"
14 #include "atlas/functionspace.h"
15 #include "atlas/grid.h"
16 #include "atlas/util/Config.h"
19 #include "oops/util/abor1_cpp.h"
20 #include "oops/util/Logger.h"
29 const eckit::mpi::Comm & comm) : comm_(comm) {
30 ASSERT(
comm_.size() == 1);
50 ASSERT(
comm_.size() == 1);
62 for (
int jfield = 0; jfield < other.
atlasFieldSet_->size(); ++jfield) {
94 std::vector<double> vc(nz);
95 if (vcUnits ==
"levels") {
96 for (
int i=0; i < nz; ++i) {vc[i]=i+1;}
98 std::stringstream errorMsg;
99 errorMsg <<
"Uknown vertical coordinate unit " << vcUnits << std::endl;
100 ABORT(errorMsg.str());
102 oops::Log::debug() <<
"QG vert coord: " << vc << std::endl;
109 std::vector<size_t> sizes(vars.
size(), 1);
120 os <<
"Geometry:" << std::endl;
121 os <<
"nx = " << nx <<
", ny = " << ny <<
", nz = " << nz << std::endl;
122 os <<
"deltax = " << deltax <<
", deltay = " << deltay;
GeometryQG handles geometry for QG model.
std::unique_ptr< atlas::functionspace::PointCloud > atlasFunctionSpace_
std::vector< double > verticalCoord(std::string &) const
GeometryQGIterator begin() const
std::unique_ptr< atlas::FieldSet > atlasFieldSet_
std::vector< size_t > variableSizes(const oops::Variables &vars) const
GeometryQGIterator end() const
void print(std::ostream &) const
const eckit::mpi::Comm & comm_
GeometryQG(const GeometryQgParameters &, const eckit::mpi::Comm &)
The namespace for the qg model.
void qg_geom_setup_f90(F90geom &, const eckit::Configuration &)
void qg_geom_set_atlas_functionspace_pointer_f90(const F90geom &, atlas::functionspace::FunctionSpaceImpl *)
void qg_geom_fill_atlas_fieldset_f90(const F90geom &, atlas::field::FieldSetImpl *)
void qg_geom_delete_f90(F90geom &)
void qg_geom_info_f90(const F90geom &, int &, int &, int &, double &, double &)
void qg_geom_set_atlas_lonlat_f90(const F90geom &, atlas::field::FieldSetImpl *)
void qg_geom_clone_f90(F90geom &, const F90geom &)