/*! \file axis_algorithm_reduce_domain.hpp \author Ha NGUYEN \since 23 June 2016 \date 23 June 2016 \brief Algorithm for reduce an axis to a axis */ #ifndef __XIOS_AXIS_ALGORITHM_DUPLICATE_SCALAR_HPP__ #define __XIOS_AXIS_ALGORITHM_DUPLICATE_SCALAR_HPP__ #include "algorithm_transformation_transfer.hpp" #include "transformation.hpp" namespace xios { class CAxis; class CScalar; class CDuplicateScalarToAxis; /*! \class CAxisAlgorithmDuplicateScalar Duplicate scalar into axis destination */ class CAxisAlgorithmDuplicateScalar : public CAlgorithmTransformationTransfer { public: CAxisAlgorithmDuplicateScalar(bool isSource, CAxis* axisDestination, CScalar* scalarSource, CDuplicateScalarToAxis* algo); virtual ~CAxisAlgorithmDuplicateScalar(); static bool registerTrans(); virtual StdString getAlgoName() {return "\\nduplicate_scalar";} static CGenericAlgorithmTransformation* create(bool isSource, CGrid* gridDst, CGrid* gridSrc, CTransformation* transformation, int elementPositionInGrid, std::map& elementPositionInGridSrc2ScalarPosition, std::map& elementPositionInGridSrc2AxisPosition, std::map& elementPositionInGridSrc2DomainPosition, std::map& elementPositionInGridDst2ScalarPosition, std::map& elementPositionInGridDst2AxisPosition, std::map& elementPositionInGridDst2DomainPosition); static bool dummyRegistered_; }; } #endif // __XIOS_AXIS_ALGORITHM_DUPLICATE_SCALAR_HPP__