source: XIOS/trunk/src/transformation/domain_algorithm_extract.hpp @ 1982

Last change on this file since 1982 was 1982, checked in by yushan, 3 years ago

trunk : workflow graph big fixed for chained spatial filters. Filter name simplified for graph

File size: 2.0 KB
Line 
1
2#ifndef __XIOS_DOMAIN_ALGORITHM_EXTRACT_HPP__
3#define __XIOS_DOMAIN_ALGORITHM_EXTRACT_HPP__
4
5#include "domain_algorithm_transformation.hpp"
6#include "transformation.hpp"
7
8namespace xios {
9
10class CDomain;
11class CExtractDomain;
12
13/*!
14  \class CDomainAlgorithmExtract
15  Implementing extract (alternative zoom) on domain
16*/
17class CDomainAlgorithmExtract : public CDomainAlgorithmTransformation
18{
19public:
20  CDomainAlgorithmExtract(CDomain* domainDestination, CDomain* domainSource, CExtractDomain* extractDomain);
21
22  virtual ~CDomainAlgorithmExtract() {}
23
24  static bool registerTrans();
25
26  virtual StdString getName() {return "extract_domain";}
27protected:
28  void updateDomainAttributes();
29  void computeIndexSourceMapping_(const std::vector<CArray<double,1>* >& dataAuxInputs);
30
31private:
32  void updateExtract();
33
34private:
35  //! Global extract begin on domain
36  int extractIBegin_;
37  int extractJBegin_;
38
39  //! Global extract end on domain
40  int extractIEnd_;
41  int extractJEnd_;
42
43  //! Global extract size on domain
44  int extractNi_;
45  int extractNj_;
46
47private:
48
49  static CGenericAlgorithmTransformation* create(CGrid* gridDst, CGrid* gridSrc,
50                                                CTransformation<CDomain>* transformation,
51                                                int elementPositionInGrid,
52                                                std::map<int, int>& elementPositionInGridSrc2ScalarPosition,
53                                                std::map<int, int>& elementPositionInGridSrc2AxisPosition,
54                                                std::map<int, int>& elementPositionInGridSrc2DomainPosition,
55                                                std::map<int, int>& elementPositionInGridDst2ScalarPosition,
56                                                std::map<int, int>& elementPositionInGridDst2AxisPosition,
57                                                std::map<int, int>& elementPositionInGridDst2DomainPosition);
58};
59
60}
61#endif // __XIOS_DOMAIN_ALGORITHM_EXTRACT_HPP__
Note: See TracBrowser for help on using the repository browser.