source: XIOS/dev/dev_ym/XIOS_COUPLING/src/node/interpolate_axis.hpp @ 2230

Last change on this file since 2230 was 2011, checked in by ymipsl, 3 years ago
  • bug fix when createing mask on server side when overlapping grid
  • implement axis interpolation on pressure coordinate
  • big cleaning in transformation

YM

File size: 3.5 KB
Line 
1#ifndef __XIOS_CInterpolateAxis__
2#define __XIOS_CInterpolateAxis__
3
4/// xios headers ///
5#include "xios_spl.hpp"
6#include "attribute_enum.hpp"
7#include "attribute_enum_impl.hpp"
8#include "attribute_array.hpp"
9#include "declare_attribute.hpp"
10#include "object_template.hpp"
11#include "group_factory.hpp"
12#include "declare_group.hpp"
13#include "transformation.hpp"
14#include "axis.hpp"
15
16namespace xios {
17  /// ////////////////////// Déclarations ////////////////////// ///
18  class CInterpolateAxisGroup;
19  class CInterpolateAxisAttributes;
20  class CInterpolateAxis;
21  class CAxis;
22  class CGenericAlgorithmTransformation ;
23  class CGrid;
24  ///--------------------------------------------------------------
25
26  // Declare/Define CFileAttribute
27  BEGIN_DECLARE_ATTRIBUTE_MAP(CInterpolateAxis)
28#include "interpolate_axis_attribute.conf"
29  END_DECLARE_ATTRIBUTE_MAP(CInterpolateAxis)
30
31  ///--------------------------------------------------------------
32  /*!
33    \class CInterpolateAxis
34    This class describes interpolate_axis in xml file.
35  */
36  class CInterpolateAxis
37    : public CObjectTemplate<CInterpolateAxis>
38    , public CInterpolateAxisAttributes
39    , public CTransformation<CAxis>
40  {
41    public :
42      typedef CObjectTemplate<CInterpolateAxis> SuperClass;
43      typedef CInterpolateAxisAttributes SuperClassAttribute;
44      typedef CInterpolateAxis MyClass ;
45      typedef CTransformation<CAxis> SuperTransform ;
46
47    public :
48      /// Constructeurs ///
49      CInterpolateAxis(void);
50      explicit CInterpolateAxis(const StdString& id);
51
52      /// Destructeur ///
53      virtual ~CInterpolateAxis(void);
54
55      virtual void checkValid(CAxis* axisDest);
56
57      std::vector<StdString> checkAuxInputs_();
58
59      /// Accesseurs statiques ///
60      static StdString GetName(void);
61      static StdString GetDefName(void);
62      static ENodeType GetType(void);
63      const string& getId(void) { return this->SuperClass::getId();}
64      ETranformationType getTransformationType(void) { return TRANS_INTERPOLATE_AXIS ;}
65      static CTransformation<CAxis>* getTransformation(const StdString& id) { return SuperClass::get(id);}
66      virtual void inheritFrom(SuperTransform* srcTransform) { solveDescInheritance(true, this->SuperClass::get((MyClass*)srcTransform)) ;}
67      virtual CGenericAlgorithmTransformation* createAlgorithm(bool isSource,
68                                                               CGrid* gridDst, CGrid* gridSrc,
69                                                               int elementPositionInGrid,
70                                                               std::map<int, int>& elementPositionInGridSrc2ScalarPosition,
71                                                               std::map<int, int>& elementPositionInGridSrc2AxisPosition,
72                                                               std::map<int, int>& elementPositionInGridSrc2DomainPosition,
73                                                               std::map<int, int>& elementPositionInGridDst2ScalarPosition,
74                                                               std::map<int, int>& elementPositionInGridDst2AxisPosition,
75                                                               std::map<int, int>& elementPositionInGridDst2DomainPosition)  ;
76    private:
77      static bool registerTrans();
78      static CTransformation<CAxis>* create(const StdString& id, xml::CXMLNode* node);
79      static bool _dummyRegistered;
80  }; // class CInterpolateAxis
81
82  DECLARE_GROUP(CInterpolateAxis);
83} // namespace xios
84
85#endif // __XIOS_CInterpolateAxis__
Note: See TracBrowser for help on using the repository browser.