22#ifndef ASTSHIM_UNITNORMMAP_H
23#define ASTSHIM_UNITNORMMAP_H
67 :
Mapping(reinterpret_cast<AstMapping *>(
68 astUnitNormMap(centre.size(), centre.data(),
"%s", options.c_str()))) {
87 return copyImpl<UnitNormMap, AstUnitNormMap>();
94 os <<
"this is a " <<
getClassName() <<
", which is not a UnitNormMap";
An abstract base class for objects which transform one set of coordinates to another.
Abstract base class for all AST objects.
std::string getClassName() const
Get Class: the name of the class (e.g.
AstObject const * getRawPtr() const
Get the raw AST pointer.
The forward transformation of a UnitNormMap subtracts the specified centre and then transforms the re...
virtual std::shared_ptr< Object > copyPolymorphic() const override
Return a deep copy of this object.
UnitNormMap(UnitNormMap const &)=default
Copy constructor: make a deep copy.
UnitNormMap(UnitNormMap &&)=default
UnitNormMap(AstUnitNormMap *rawptr)
Construct a UnitNormMap from a raw AST pointer.
UnitNormMap(std::vector< double > const ¢re, std::string const &options="")
Construct a UnitNormMap.
UnitNormMap & operator=(UnitNormMap const &)=delete
std::shared_ptr< UnitNormMap > copy() const
Return a deep copy of this object.
UnitNormMap & operator=(UnitNormMap &&)=default
AST wrapper classes and functions.
void assertOK(AstObject *rawPtr1=nullptr, AstObject *rawPtr2=nullptr)
Throw std::runtime_error if AST's state is bad.