[1985] | 1 | /*! |
---|
| 2 | \file axis_algorithm_temporal_splitting.cpp |
---|
| 3 | |
---|
| 4 | \brief Algorithm to split scalar into axis by temporal accumulation |
---|
| 5 | */ |
---|
| 6 | #include "axis_algorithm_temporal_splitting.hpp" |
---|
| 7 | #include "temporal_splitting.hpp" |
---|
| 8 | #include "axis.hpp" |
---|
| 9 | #include "scalar.hpp" |
---|
| 10 | #include "grid.hpp" |
---|
| 11 | #include "grid_transformation_factory_impl.hpp" |
---|
[2007] | 12 | #include "temporal_transform_filter.hpp" |
---|
[1985] | 13 | |
---|
| 14 | namespace xios { |
---|
[2270] | 15 | shared_ptr<CGenericAlgorithmTransformation> CAxisAlgorithmTemporalSplitting::create(bool isSource, CGrid* gridDst, CGrid* gridSrc, |
---|
[1985] | 16 | CTransformation<CAxis>* transformation, |
---|
| 17 | int elementPositionInGrid, |
---|
| 18 | std::map<int, int>& elementPositionInGridSrc2ScalarPosition, |
---|
| 19 | std::map<int, int>& elementPositionInGridSrc2AxisPosition, |
---|
| 20 | std::map<int, int>& elementPositionInGridSrc2DomainPosition, |
---|
| 21 | std::map<int, int>& elementPositionInGridDst2ScalarPosition, |
---|
| 22 | std::map<int, int>& elementPositionInGridDst2AxisPosition, |
---|
| 23 | std::map<int, int>& elementPositionInGridDst2DomainPosition) |
---|
| 24 | TRY |
---|
| 25 | { |
---|
| 26 | std::vector<CAxis*> axisListDestP = gridDst->getAxis(); |
---|
| 27 | std::vector<CScalar*> scalarListSrcP = gridSrc->getScalars(); |
---|
| 28 | |
---|
| 29 | CTemporalSplitting* temporalSplitting = dynamic_cast<CTemporalSplitting*> (transformation); |
---|
| 30 | int axisDstIndex = elementPositionInGridDst2AxisPosition[elementPositionInGrid]; |
---|
| 31 | int scalarSrcIndex = elementPositionInGridSrc2ScalarPosition[elementPositionInGrid]; |
---|
| 32 | |
---|
[2270] | 33 | return make_shared<CAxisAlgorithmTemporalSplitting>(isSource, axisListDestP[axisDstIndex], scalarListSrcP[scalarSrcIndex], temporalSplitting); |
---|
[1985] | 34 | } |
---|
| 35 | CATCH |
---|
| 36 | |
---|
| 37 | bool CAxisAlgorithmTemporalSplitting::dummyRegistered_ = CAxisAlgorithmTemporalSplitting::registerTrans(); |
---|
| 38 | bool CAxisAlgorithmTemporalSplitting::registerTrans() |
---|
| 39 | TRY |
---|
| 40 | { |
---|
| 41 | return CGridTransformationFactory<CAxis>::registerTransformation(TRANS_TEMPORAL_SPLITTING, create); |
---|
| 42 | } |
---|
| 43 | CATCH |
---|
| 44 | |
---|
[1988] | 45 | CAxisAlgorithmTemporalSplitting::CAxisAlgorithmTemporalSplitting(bool isSource, CAxis* axisDestination, CScalar* scalarSource, CTemporalSplitting* algo) |
---|
[2007] | 46 | : CAlgorithmTransformationNoDataModification(isSource) |
---|
[1985] | 47 | { |
---|
[2007] | 48 | nrecords_ = axisDestination->n_glo ; // also axis must not be distributed, make more test later |
---|
| 49 | } |
---|
[1985] | 50 | |
---|
[2270] | 51 | CTransformFilter* CAxisAlgorithmTemporalSplitting::createTransformFilter(CGarbageCollector& gc, shared_ptr<CGridAlgorithm> algo, bool detectMissingValues, double defaultValue) |
---|
[2007] | 52 | { |
---|
[2011] | 53 | return new CTemporalTransformFilter(gc, 1, algo, nrecords_, detectMissingValues, defaultValue) ; |
---|
[1985] | 54 | } |
---|
| 55 | |
---|
| 56 | CAxisAlgorithmTemporalSplitting::~CAxisAlgorithmTemporalSplitting() |
---|
| 57 | { |
---|
| 58 | } |
---|
| 59 | |
---|
| 60 | |
---|
| 61 | } |
---|