source: XIOS/dev/dev_ym/XIOS_COUPLING/src/transformation/generic_algorithm_transformation.hpp @ 2291

Last change on this file since 2291 was 2270, checked in by ymipsl, 3 years ago

Tracking memory leak :
Tranformations and algorithms are now managed with shared_ptr.

YM

File size: 2.1 KB
Line 
1/*!
2   \file generic_algorithm_transformation.hpp
3   \author Ha NGUYEN
4   \since 14 May 2015
5   \date 29 June 2015
6
7   \brief Interface for all transformation algorithms.
8 */
9#ifndef __XIOS_GENERIC_ALGORITHM_TRANSFORMATION_HPP__
10#define __XIOS_GENERIC_ALGORITHM_TRANSFORMATION_HPP__
11
12#include <map>
13#include <set>
14#include "array_new.hpp"
15#include "client_client_dht_template.hpp"
16#include "local_view.hpp"
17#include "transform_connector.hpp"
18#include "weight_transform_connector.hpp"
19
20namespace xios
21{
22  class CGrid;
23  class CDomain;
24  class CAxis;
25  class CScalar;
26  class CGridAlgorithm ;
27  class CTransformFilter ;
28  class CGarbageCollector ;
29
30  /*!
31  \class CGenericAlgorithmTransformation
32  This class defines the interface for all other inherited algorithms class
33  */
34class CGenericAlgorithmTransformation : public std::enable_shared_from_this<CGenericAlgorithmTransformation>
35{
36  public : 
37    CGenericAlgorithmTransformation(bool isSource) ;
38    virtual shared_ptr<CGridAlgorithm> createGridAlgorithm(CGrid* gridSrc, CGrid* newGrid, int pos) ;
39    virtual CTransformFilter* createTransformFilter(CGarbageCollector& gc, shared_ptr<CGridAlgorithm> algo, bool detectMissingValues, double defaultValue) ;
40    virtual void apply(int dimBefore, int dimAfter, const CArray<double,1>& dataIn, CArray<double,1>& dataOut) { abort() ;} //=0
41    virtual void apply(int dimBefore, int dimAfter, const CArray<double,1>& dataIn, const vector<CArray<double,1>>& auxData, CArray<double,1>& dataOut) { abort() ;} //=0
42    virtual bool isGenerateTransformation(void) { return false ;}
43    virtual StdString getAlgoName() { return "\\nGeneric algorithm transformation";}
44    virtual bool transformAuxField(int pos) { return true ;}
45    virtual vector<string> getAuxFieldId(void) ;
46  protected :
47    typedef std::unordered_map<int, std::vector<int> > TransformationIndexMap;
48    typedef std::unordered_map<int, std::vector<double> > TransformationWeightMap;
49 
50    shared_ptr<CLocalElement> recvElement_ ;
51    bool isSource_ ;
52
53  public:
54    shared_ptr<CLocalElement> getRecvElement(void) { return recvElement_ ;}
55 
56};
57
58}
59#endif // __XIOS_GENERIC_ALGORITHM_TRANSFORMATION_HPP__
Note: See TracBrowser for help on using the repository browser.