14 #include "atlas/field.h"
15 #include "atlas/functionspace.h"
16 #include "eckit/config/Configuration.h"
20 #include "oops/util/abor1_cpp.h"
21 #include "oops/util/ObjectCounter.h"
32 private util::ObjectCounter<InterpolatorUnstructured> {
34 static const std::string
classname() {
return "oops::InterpolatorUnstructured";}
37 const atlas::FunctionSpace &,
38 const atlas::field::FieldSetImpl * =
nullptr,
42 void apply(
const atlas::Field &, atlas::Field &)
override;
43 void apply(
const atlas::FieldSet &, atlas::FieldSet &)
override;
45 void apply_ad(
const atlas::Field &, atlas::Field &);
46 void apply_ad(
const atlas::FieldSet &, atlas::FieldSet &)
override;
48 int write(
const eckit::Configuration &)
override;
54 void print(std::ostream &)
const override;
Base class for Generic interpolation.
Interface for Unstructured interpolation.
const atlas::FunctionSpace * out_fspace_
InterpolatorUnstructured(const eckit::Configuration &, const atlas::FunctionSpace &, const atlas::FunctionSpace &, const atlas::field::FieldSetImpl *=nullptr, const eckit::mpi::Comm &=oops::mpi::world())
const atlas::FunctionSpace * in_fspace_
void print(std::ostream &) const override
int keyUnstructuredInterpolator_
int write(const eckit::Configuration &) override
void apply_ad(const atlas::Field &, atlas::Field &)
~InterpolatorUnstructured()
static const std::string classname()
void apply(const atlas::Field &, atlas::Field &) override
const eckit::mpi::Comm & world()
Default communicator with all MPI tasks (ie MPI_COMM_WORLD)
The namespace for the main oops code.