source: XIOS/dev/dev_ym/XIOS_COUPLING/src/node/interpolate_domain.hpp @ 2247

Last change on this file since 2247 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_CInterpolateDomain__
2#define __XIOS_CInterpolateDomain__
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 "domain.hpp"
15
16namespace xios {
17  /// ////////////////////// Déclarations ////////////////////// ///
18  class CInterpolateDomainGroup;
19  class CInterpolateDomainAttributes;
20  class CInterpolateDomain;
21  class CDomain;
22  class CGenericAlgorithmTransformation ;
23  class CGrid;
24  ///--------------------------------------------------------------
25
26  // Declare/Define CFileAttribute
27  BEGIN_DECLARE_ATTRIBUTE_MAP(CInterpolateDomain)
28#include "interpolate_domain_attribute.conf"
29  END_DECLARE_ATTRIBUTE_MAP(CInterpolateDomain)
30
31  ///--------------------------------------------------------------
32  /*!
33    \class CInterpolateDomain
34    This class describes interpolate_from_file_domain in xml file.
35  */
36  class CInterpolateDomain
37    : public CObjectTemplate<CInterpolateDomain>
38    , public CInterpolateDomainAttributes
39    , public CTransformation<CDomain>
40  {
41    public :
42      typedef CObjectTemplate<CInterpolateDomain> SuperClass;
43      typedef CInterpolateDomainAttributes SuperClassAttribute;
44      typedef CInterpolateDomain MyClass ;
45      typedef CTransformation<CDomain> SuperTransform ;
46
47    public :
48      /// Constructeurs ///
49      CInterpolateDomain(void);
50      explicit CInterpolateDomain(const StdString& id);
51
52      /// Destructeur ///
53      virtual ~CInterpolateDomain(void);
54
55      virtual void checkValid(CDomain* domainSource);
56
57      /// Accesseurs statiques ///
58      static StdString GetName(void);
59      static StdString GetDefName(void);
60      static ENodeType GetType(void);
61      const string& getId(void) { return this->SuperClass::getId();}
62      ETranformationType getTransformationType(void) { return TRANS_INTERPOLATE_DOMAIN ;}
63      static CTransformation<CDomain>* getTransformation(const StdString& id) { return SuperClass::get(id);}
64      virtual void inheritFrom(SuperTransform* srcTransform) { solveDescInheritance(true, this->SuperClass::get((MyClass*)srcTransform)) ;}
65      virtual CGenericAlgorithmTransformation* createAlgorithm(bool isSource,
66                                                               CGrid* gridDst, CGrid* gridSrc,
67                                                               int elementPositionInGrid,
68                                                               std::map<int, int>& elementPositionInGridSrc2ScalarPosition,
69                                                               std::map<int, int>& elementPositionInGridSrc2AxisPosition,
70                                                               std::map<int, int>& elementPositionInGridSrc2DomainPosition,
71                                                               std::map<int, int>& elementPositionInGridDst2ScalarPosition,
72                                                               std::map<int, int>& elementPositionInGridDst2AxisPosition,
73                                                               std::map<int, int>& elementPositionInGridDst2DomainPosition)  ;
74    private:
75      static bool registerTrans();
76      static CTransformation<CDomain>* create(const StdString& id, xml::CXMLNode* node);
77      static bool _dummyRegistered;
78  }; // class CInterpolateDomain
79
80  DECLARE_GROUP(CInterpolateDomain);
81} // namespace xios
82
83#endif // __XIOS_CInterpolateDomain__
Note: See TracBrowser for help on using the repository browser.