atlas::interpolation::method::ConservativeSphericalPolygonInterpolation class

Base classes

class atlas::interpolation::Method

Public types

class Cache
struct InterpolationParameters
struct Statistics
using Config = eckit::Parametrisation
using Metadata = util::Metadata

Constructors, destructors, conversion operators

ConservativeSphericalPolygonInterpolation(const Config& = util::NoConfig())

Public functions

void do_setup(const FunctionSpace& src_fs, const FunctionSpace& tgt_fs) override
void do_setup(const Grid& src_grid, const Grid& tgt_grid, const interpolation::Cache&) override
void do_execute(const Field& src_field, Field& tgt_field, Metadata&) const override
void do_execute(const FieldSet& src_fields, FieldSet& tgt_fields, Metadata&) const override
void print(std::ostream& out) const override
auto source() const -> const FunctionSpace& override
auto target() const -> const FunctionSpace& override
auto src_points(size_t id) const -> const PointXYZ&
auto tgt_points(size_t id) const -> const PointXYZ&
auto createCache() const -> interpolation::Cache override
void setup(const FunctionSpace& source, const FunctionSpace& target)
Setup the interpolator relating two functionspaces.
void setup(const Grid& source, const Grid& target)
void setup(const FunctionSpace& source, const Field& target)
void setup(const FunctionSpace& source, const FieldSet& target)
void setup(const Grid& source, const Grid& target, const Cache&)
auto execute(const FieldSet& source, FieldSet& target) const -> Metadata
auto execute(const Field& source, Field& target) const -> Metadata
auto execute_adjoint(FieldSet& source, const FieldSet& target) const -> Metadata
execute_adjoint
auto execute_adjoint(Field& source, const Field& target) const -> Metadata

Typedef documentation

using atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::Config = eckit::Parametrisation

using atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::Metadata = util::Metadata

Function documentation

void atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::setup(const FunctionSpace& source, const FunctionSpace& target)

Setup the interpolator relating two functionspaces.

Parameters
source functionspace containing source elements
target functionspace containing target points

void atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::setup(const Grid& source, const Grid& target)

void atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::setup(const FunctionSpace& source, const Field& target)

void atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::setup(const FunctionSpace& source, const FieldSet& target)

void atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::setup(const Grid& source, const Grid& target, const Cache&)

Metadata atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::execute(const FieldSet& source, FieldSet& target) const

Metadata atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::execute(const Field& source, Field& target) const

Metadata atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::execute_adjoint(FieldSet& source, const FieldSet& target) const

execute_adjoint

Parameters
source - it is either a FieldSet or a Field
target - it is either a FieldSet or a Field Note that formally in an adjoint operation of this type we should be setting the values in the target to zero. This is not done for efficiency reasons and because in most cases it is not necessary.

Metadata atlas::interpolation::method::ConservativeSphericalPolygonInterpolation::execute_adjoint(Field& source, const Field& target) const