14 #include "atlas/field.h"
15 #include "atlas/functionspace.h"
16 #include "atlas/interpolation.h"
17 #include "eckit/config/Configuration.h"
18 #include "eckit/exception/Exceptions.h"
21 #include "oops/util/ObjectCounter.h"
32 private util::ObjectCounter<InterpolatorAtlas> {
34 static const std::string
classname() {
return "oops::InterpolatorAtlas";}
37 const atlas::FunctionSpace &,
38 const atlas::field::FieldSetImpl * =
nullptr);
41 void apply(
const atlas::Field &, atlas::Field &)
override;
42 void apply(
const atlas::FieldSet &, atlas::FieldSet &)
override;
44 void apply_ad(
const atlas::FieldSet &, atlas::FieldSet &)
override {
45 throw eckit::NotImplemented(
"Interpolator Adjoint not yet implemented for Atlas", Here());
49 void print(std::ostream &)
const override;
Interface for Atlas interpolation.
InterpolatorAtlas(const eckit::Configuration &, const atlas::FunctionSpace &, const atlas::FunctionSpace &, const atlas::field::FieldSetImpl *=nullptr)
static const std::string classname()
void apply_ad(const atlas::FieldSet &, atlas::FieldSet &) override
void apply(const atlas::Field &, atlas::Field &) override
std::unique_ptr< atlas::Interpolation > interpolator_
void print(std::ostream &) const override
Base class for Generic interpolation.
The namespace for the main oops code.