2017-04-20 13:18:15 +01:00
|
|
|
#ifndef _STENCIL_SIMPLE_COMPRESSOR_H_
|
|
|
|
#define _STENCIL_SIMPLE_COMPRESSOR_H_
|
|
|
|
|
2018-01-13 00:11:30 +00:00
|
|
|
NAMESPACE_BEGIN(Grid);
|
2017-04-20 13:18:15 +01:00
|
|
|
|
|
|
|
template<class vobj>
|
|
|
|
class SimpleCompressor {
|
|
|
|
public:
|
|
|
|
void Point(int) {};
|
|
|
|
inline int CommDatumSize(void) { return sizeof(vobj); }
|
|
|
|
inline bool DecompressionStep(void) { return false; }
|
|
|
|
inline void Compress(vobj *buf,int o,const vobj &in) { buf[o]=in; }
|
|
|
|
inline void Exchange(vobj *mp,vobj *vp0,vobj *vp1,Integer type,Integer o){
|
|
|
|
exchange(mp[2*o],mp[2*o+1],vp0[o],vp1[o],type);
|
|
|
|
}
|
|
|
|
inline void Decompress(vobj *out,vobj *in, int o){ assert(0); }
|
|
|
|
inline void CompressExchange(vobj *out0,vobj *out1,const vobj *in,
|
|
|
|
int j,int k, int m,int type){
|
|
|
|
exchange(out0[j],out1[j],in[k],in[m],type);
|
|
|
|
}
|
|
|
|
// For cshift. Cshift should drop compressor coupling altogether
|
|
|
|
// because I had to decouple the code from the Stencil anyway
|
|
|
|
inline vobj operator() (const vobj &arg) {
|
|
|
|
return arg;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-01-13 00:11:30 +00:00
|
|
|
NAMESPACE_END(Grid);
|
|
|
|
|
2017-04-20 13:18:15 +01:00
|
|
|
#endif
|