source: XIOS/dev/dev_ym/XIOS_COUPLING/src/node/reduce_domain_to_scalar.cpp @ 2011

Last change on this file since 2011 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.0 KB
Line 
1#include "reduce_domain_to_scalar.hpp"
2#include "scalar_algorithm_reduce_domain.hpp"
3#include "type.hpp"
4
5namespace xios {
6
7  /// ////////////////////// Définitions ////////////////////// ///
8
9  CReduceDomainToScalar::CReduceDomainToScalar(void)
10    : CObjectTemplate<CReduceDomainToScalar>(), CReduceDomainToScalarAttributes(), CTransformation<CScalar>()
11  { /* Ne rien faire de plus */ }
12
13  CReduceDomainToScalar::CReduceDomainToScalar(const StdString & id)
14    : CObjectTemplate<CReduceDomainToScalar>(id), CReduceDomainToScalarAttributes(), CTransformation<CScalar>()
15  { /* Ne rien faire de plus */ }
16
17  CReduceDomainToScalar::~CReduceDomainToScalar(void)
18  {}
19
20  CTransformation<CScalar>* CReduceDomainToScalar::create(const StdString& id, xml::CXMLNode* node)
21  {
22    CReduceDomainToScalar* reduceDomain = CReduceDomainToScalarGroup::get("reduce_domain_to_scalar_definition")->createChild(id);
23    if (node) reduceDomain->parse(*node);
24    return static_cast<CTransformation<CScalar>*>(reduceDomain);
25  }
26
27  bool CReduceDomainToScalar::registerTrans()
28  {
29    return registerTransformation(TRANS_REDUCE_DOMAIN_TO_SCALAR, {create, getTransformation});
30  }
31
32  bool CReduceDomainToScalar::_dummyRegistered = CReduceDomainToScalar::registerTrans();
33
34  //----------------------------------------------------------------
35
36  StdString CReduceDomainToScalar::GetName(void)    { return StdString("reduce_domain_to_scalar"); }
37  StdString CReduceDomainToScalar::GetDefName(void) { return StdString("reduce_domain_to_scalar"); }
38  ENodeType CReduceDomainToScalar::GetType(void)    { return eReduceDomainToScalar; }
39
40  void CReduceDomainToScalar::checkValid(CScalar* scalarDst, CDomain* domainSrc)
41  {
42    if (this->local.isEmpty()) local=false ;
43  }
44
45  CGenericAlgorithmTransformation* CReduceDomainToScalar::createAlgorithm(bool isSource,
46                                                        CGrid* gridDst, CGrid* gridSrc,
47                                                        int elementPositionInGrid,
48                                                        std::map<int, int>& elementPositionInGridSrc2ScalarPosition,
49                                                        std::map<int, int>& elementPositionInGridSrc2AxisPosition,
50                                                        std::map<int, int>& elementPositionInGridSrc2DomainPosition,
51                                                        std::map<int, int>& elementPositionInGridDst2ScalarPosition,
52                                                        std::map<int, int>& elementPositionInGridDst2AxisPosition,
53                                                        std::map<int, int>& elementPositionInGridDst2DomainPosition)
54  {
55    return CScalarAlgorithmReduceDomain::create(isSource, gridDst,  gridSrc, this, elementPositionInGrid,
56                       elementPositionInGridSrc2ScalarPosition, elementPositionInGridSrc2AxisPosition, elementPositionInGridSrc2DomainPosition,
57                       elementPositionInGridDst2ScalarPosition, elementPositionInGridDst2AxisPosition, elementPositionInGridDst2DomainPosition) ;
58  }
59}
Note: See TracBrowser for help on using the repository browser.