source: XIOS/dev/dev_trunk_graph/src/transformation/axis_algorithm/axis_algorithm_extract.cpp @ 2019

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

Graph intermedia commit to a tmp branch

  • Property svn:executable set to *
File size: 4.5 KB
Line 
1/*!
2   \file axis_algorithm_extract.cpp
3   \brief Algorithm for extracting an axis.
4 */
5#include "axis_algorithm_extract.hpp"
6#include "axis.hpp"
7#include "grid.hpp"
8#include "grid_transformation_factory_impl.hpp"
9#include "extract_axis.hpp"
10
11namespace xios {
12CGenericAlgorithmTransformation* CAxisAlgorithmExtract::create(bool isSource, CGrid* gridDst, CGrid* gridSrc,
13                                                           CTransformation<CAxis>* transformation,
14                                                           int elementPositionInGrid,
15                                                           std::map<int, int>& elementPositionInGridSrc2ScalarPosition,
16                                                           std::map<int, int>& elementPositionInGridSrc2AxisPosition,
17                                                           std::map<int, int>& elementPositionInGridSrc2DomainPosition,
18                                                           std::map<int, int>& elementPositionInGridDst2ScalarPosition,
19                                                           std::map<int, int>& elementPositionInGridDst2AxisPosition,
20                                                           std::map<int, int>& elementPositionInGridDst2DomainPosition)
21TRY
22{
23  std::vector<CAxis*> axisListDestP = gridDst->getAxis();
24  std::vector<CAxis*> axisListSrcP  = gridSrc->getAxis();
25
26  CExtractAxis* extractAxis = dynamic_cast<CExtractAxis*> (transformation);
27  int axisDstIndex = elementPositionInGridDst2AxisPosition[elementPositionInGrid];
28  int axisSrcIndex = elementPositionInGridSrc2AxisPosition[elementPositionInGrid];
29
30  return (new CAxisAlgorithmExtract(isSource, axisListDestP[axisDstIndex], axisListSrcP[axisSrcIndex], extractAxis));
31}
32CATCH
33
34bool CAxisAlgorithmExtract::dummyRegistered_ = CAxisAlgorithmExtract::registerTrans();
35bool CAxisAlgorithmExtract::registerTrans()
36TRY
37{
38  return CGridTransformationFactory<CAxis>::registerTransformation(TRANS_EXTRACT_AXIS, create);
39}
40CATCH
41
42CAxisAlgorithmExtract::CAxisAlgorithmExtract(bool isSource, CAxis* axisDestination, CAxis* axisSource, CExtractAxis* extractAxis)
43: CAlgorithmTransformationTransfer(isSource), axisDest_(axisDestination), axisSrc_(axisSource)
44TRY
45{
46  extractAxis->checkValid(axisSource);
47  extractBegin_ = extractAxis->begin.getValue();
48  extractN_  = extractAxis->n.getValue();
49  extractEnd_   = extractBegin_ + extractN_ - 1;
50
51  if (extractN_ > axisSource->n_glo.getValue())
52  {
53    ERROR("CAxisAlgorithmExtract::CAxisAlgorithmExtract(CAxis* axisDestination, CAxis* axisSource, CExtractAxis* extractAxis)",
54           << "Extract size is greater than global size of source axis"
55           << "Global size of source axis " <<axisSource->getId() << " is " << axisSource->n_glo.getValue()  << std::endl
56           << "Extract size is " << extractN_ );
57  }
58
59  int idxSrc, nDest = 0, beginDestLoc, beginDestGlo = 0 ;
60  int indGloDest, indGloSrc, iSrc;
61  for (int i = 0; i < axisSrc_->n.getValue(); i++)
62  {
63    idxSrc = axisSrc_->index(i);
64    if ((idxSrc >= extractBegin_) && (idxSrc <= extractEnd_))
65    {
66      if (nDest == 0) beginDestLoc = i;
67      ++nDest;
68    }
69  }
70  beginDestGlo = beginDestLoc + axisSrc_->begin - extractBegin_;
71  axisDest_->n_glo.setValue(extractN_);
72  axisDest_->n.setValue(nDest);
73  axisDest_->begin.setValue(beginDestGlo);
74  axisDest_->index.resize(nDest);
75
76  axisDest_->data_n.setValue(nDest);
77  axisDest_->data_begin.setValue(0);
78  axisDest_->data_index.resize(nDest);
79
80  axisDest_->mask.resize(nDest);
81  if (axisSrc_->hasValue) axisDest_->value.resize(nDest);
82  if (axisSrc_->hasLabel) axisDest_->label.resize(nDest);
83  if (axisSrc_->hasBounds) axisDest_->bounds.resize(2,nDest);
84
85  auto& transMap = this->transformationMapping_;
86
87  for (int iDest = 0; iDest < nDest; iDest++)
88  {
89    iSrc = iDest + beginDestLoc;
90    axisDest_->index(iDest) = iDest + beginDestGlo;
91    axisDest_->data_index(iDest) = axisSrc_->data_index(iSrc) - beginDestLoc;
92    axisDest_->mask(iDest) = axisSrc_->mask(iSrc);
93
94    if (axisSrc_->hasValue)
95      axisDest_->value(iDest) = axisSrc_->value(iSrc);
96    if (axisSrc_->hasLabel)
97      axisDest_->label(iDest) = axisSrc_->label(iSrc);
98    if (axisSrc_->hasBounds)
99    {
100      axisDest_->bounds(0,iDest) = axisSrc_->bounds(0,iSrc);
101      axisDest_->bounds(1,iDest) = axisSrc_->bounds(1,iSrc);
102    }
103    indGloDest = axisDest_->index(iDest);
104    indGloSrc = axisSrc_->index(iSrc);
105   
106    transMap[indGloDest]=indGloSrc;
107
108  }
109
110  axisDestination->checkAttributes() ;
111
112  this->computeAlgorithm(axisSource->getLocalView(CElementView::WORKFLOW), axisDestination->getLocalView(CElementView::WORKFLOW)) ;
113}
114CATCH
115
116
117
118}
Note: See TracBrowser for help on using the repository browser.