00001 #ifdef CH_LANG_CC
00002
00003
00004
00005
00006
00007
00008
00009 #endif
00010
00011 #ifndef _LEVELDATA_H_
00012 #define _LEVELDATA_H_
00013
00014 #include "IntVect.H"
00015 #include "BoxLayoutData.H"
00016 #include "DisjointBoxLayout.H"
00017 #include "Copier.H"
00018 #include "SPMD.H"
00019 #include "NamespaceHeader.H"
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 template <class T>
00036 void aliasLevelData(LevelData<T>& a_alias,
00037 LevelData<T>* a_original,
00038 const Interval& a_interval);
00039
00040 template<class T> class LevelData : public BoxLayoutData<T>
00041 {
00042 public:
00043
00044
00045 LevelData();
00046
00047
00048 LevelData(const DisjointBoxLayout& dp, int comps,
00049 const IntVect& ghost = IntVect::Zero,
00050 const DataFactory<T>& a_factory = DefaultDataFactory<T>());
00051
00052
00053 virtual ~LevelData();
00054
00055
00056 virtual void define(const DisjointBoxLayout& dp, int comps,
00057 const IntVect& ghost = IntVect::Zero,
00058 const DataFactory<T>& a_factory = DefaultDataFactory<T>());
00059
00060
00061
00062
00063
00064 virtual void define(const LevelData<T>& da,
00065 const DataFactory<T>& a_factory = DefaultDataFactory<T>());
00066
00067
00068
00069
00070
00071
00072
00073 virtual void define(const LevelData<T>& da, const Interval& comps,
00074 const DataFactory<T>& a_factory = DefaultDataFactory<T>());
00075
00076
00077 virtual void copyTo(const Interval& srcComps,
00078 BoxLayoutData<T>& dest,
00079 const Interval& destComps) const;
00080
00081
00082
00083 virtual void localCopyTo(const Interval& srcComps,
00084 LevelData<T> & dest,
00085 const Interval& destComps) const;
00086
00087
00088 virtual void localCopyTo(LevelData<T> & dest) const;
00089
00090
00091
00092 virtual void copyTo(BoxLayoutData<T>& dest) const;
00093
00094
00095
00096 virtual void copyTo(const Interval& srcComps,
00097 BoxLayoutData<T>& dest,
00098 const Interval& destComps,
00099 const Copier& copier) const;
00100
00101
00102 virtual void copyTo(BoxLayoutData<T>& dest,
00103 const Copier& copier) const;
00104 */
00105
00106
00107
00108
00109
00110 virtual void copyTo(const Interval& srcComps,
00111 BoxLayoutData<T>& dest,
00112 const Interval& destComps,
00113 const Copier& copier,
00114 const LDOperator<T>& a_op = LDOperator<T>()) const;
00115
00116
00117 virtual void copyTo(BoxLayoutData<T>& dest,
00118 const Copier& copier,
00119 const LDOperator<T>& a_op = LDOperator<T>()) const;
00120
00121
00122
00123
00124
00125 virtual void copyTo(const Interval& srcComps,
00126 LevelData<T>& dest,
00127 const Interval& destComps) const;
00128
00129
00130 virtual void copyTo(LevelData<T>& dest) const;
00131
00132
00133
00134
00135
00136 virtual void copyTo(const Interval& srcComps,
00137 LevelData<T>& dest,
00138 const Interval& destComps,
00139 const Copier& copier,
00140 const LDOperator<T>& a_op = LDOperator<T>()) const;
00141
00142
00143 virtual void copyTo(LevelData<T>& dest,
00144 const Copier& copier,
00145 const LDOperator<T>& a_op = LDOperator<T>()) const;
00146
00147
00148 virtual void exchange(void);
00149
00150
00151 virtual void exchange(const Copier& copier);
00152
00153
00154 virtual void exchange(const Interval& comps);
00155
00156
00157
00158 virtual void exchange(const Interval& comps,
00159 const Copier& copier,
00160 const LDOperator<T>& a_op = LDOperator<T>());
00161
00162
00163 virtual void exchangeBegin(const Copier& copier);
00164
00165 virtual void exchangeEnd();
00166
00167 virtual void exchangeNoOverlap(const Copier& copier);
00168
00169
00170 const IntVect& ghostVect() const
00171 {
00172 return m_ghost;
00173 }
00174
00175
00176
00177
00178
00179
00180
00181
00182
00183
00184
00185
00186
00187
00188 virtual void define(const BoxLayout& dp, int comps,
00189 const DataFactory<T>& factory);
00190
00191
00192 virtual void define(const BoxLayoutData<T>& da,
00193 const DataFactory<T>& factory = DefaultDataFactory<T>());
00194
00195
00196 virtual void define(const BoxLayoutData<T>& da, const Interval& comps,
00197 const DataFactory<T>& factory = DefaultDataFactory<T>());
00198
00199 virtual void define(const BoxLayout& deadFunction);
00200
00201
00202
00203 const DisjointBoxLayout& getBoxes() const
00204 {
00205 return m_disjointBoxLayout;
00206 }
00207
00208
00209 const DisjointBoxLayout& disjointBoxLayout() const
00210 {
00211 return m_disjointBoxLayout;
00212 }
00213
00214
00215
00216
00217
00218
00219
00220
00221
00222
00223
00224
00225
00226
00227
00228
00229
00230
00231
00232
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245 virtual void apply( void (*a_Function)(const Box&, int, T&) );
00246
00247
00248 struct ApplyFunctor
00249 {
00250 virtual ~ApplyFunctor()
00251 {
00252 }
00253
00254 virtual void operator()( const Box&, int, T& ) const = 0;
00255 };
00256
00257
00258
00259
00260
00261
00262
00263
00264
00265
00266
00267
00268
00269
00270
00271
00272
00273
00274
00275
00276
00277
00278
00279
00280
00281
00282
00283
00284
00285
00286
00287 virtual void apply( const ApplyFunctor& );
00288
00289 void degenerate( LevelData<T>& a_to, const SliceSpec& a_ss ) const;
00290
00291
00292
00293
00294 void degenerateLocalOnly( LevelData<T>& a_to, const SliceSpec& a_ss ) const;
00295
00296 protected:
00297 DisjointBoxLayout m_disjointBoxLayout;
00298
00299 IntVect m_ghost;
00300
00301 friend void aliasLevelData<T>(LevelData<T>& a_alias,
00302 LevelData<T>* a_original,
00303 const Interval& a_interval);
00304
00305 Copier m_exchangeCopier;
00306 };
00307
00308
00309
00310
00311
00312
00313
00314
00315
00316
00317
00318
00319
00320
00321
00322
00323
00324
00325
00326
00327
00328
00329
00330
00331
00332
00333
00334
00335
00336 template <class T>
00337 void aliasLevelData(LevelData<T>& a_alias, LevelData<T>* a_original,
00338 const Interval& a_interval)
00339 {
00340 AliasDataFactory<T> factory(a_original, a_interval);
00341 a_alias.define(a_original->disjointBoxLayout(), a_interval.size(), a_original->ghostVect(), factory);
00342 }
00343
00344
00345
00346
00347
00348
00349
00350 #include "NamespaceFooter.H"
00351 #include "LevelDataI.H"
00352
00353 #endif