00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #ifndef NODEAMRIO_H
00033 #define NODEAMRIO_H
00034 #include "REAL.H"
00035
00036 #ifndef WRAPPER
00037
00038 #include "LevelData.H"
00039 #include "REAL.H"
00040 #include "Vector.H"
00041 #include "NodeFArrayBox.H"
00042 #include <string>
00043
00044 #include "IntVect.H"
00045 using std::string;
00046 using std::istream;
00047 #endif
00048
00050
00056 void
00057 WriteAMRHierarchyHDF5(
00058 const string& filename,
00060 const Vector<DisjointBoxLayout>& a_vectGrids,
00062 const Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00064 const Vector<string>& a_vectNames,
00066 const Box& a_domain,
00068 const Real& a_dx,
00070 const Real& a_dt,
00072 const Real& a_time,
00074 const Vector<int>& a_vectRatio,
00076 const int& a_numLevels,
00078 const RealVect& a_origin = RealVect::Zero,
00080 const Interval& a_comps = Interval() );
00081
00083
00094 void
00095 WriteAMRHierarchyHDF5(
00096 const string& filename,
00098 const Vector<DisjointBoxLayout>& a_vectGrids,
00100 const Vector<Vector<LevelData<NodeFArrayBox>* > >& a_vectData,
00102 const Vector<string>& a_vectNames,
00104 const Box& a_domain,
00106 const Real& a_dx,
00108 const Real& a_dt,
00110 const Real& a_time,
00112 const Vector<int>& a_vectRatio,
00114 const int& a_numLevels);
00115
00117
00123 void
00124 WriteAMRHierarchyHDF5(
00125 HDF5Handle& handle,
00127 const Vector<DisjointBoxLayout>& a_vectGrids,
00129 const Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00131 const Vector<string>& a_vectNames,
00133 const Box& a_domain,
00135 const Real& a_dx,
00137 const Real& a_dt,
00139 const Real& a_time,
00141 const Vector<int>& a_vectRatio,
00143 const int& a_numLevels,
00145 const RealVect& a_origin = RealVect::Zero,
00147 const Interval& a_comps = Interval() );
00148
00150
00156 void
00157 WriteAMRHierarchyHDF5(
00158 const string& filename,
00160 const Vector<DisjointBoxLayout>& a_vectGrids,
00162 const Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00164 const Box& a_domain,
00166 const Vector<int>& a_vectRatio,
00168 const int& a_numLevels);
00169
00171
00177 void
00178 WriteAMRHierarchyHDF5(
00179 HDF5Handle& handle,
00181 const Vector<DisjointBoxLayout>& a_vectGrids,
00183 const Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00185 const Box& a_domain,
00187 const Vector<int>& a_vectRatio,
00189 const int& a_numLevels);
00190
00191 #ifndef WRAPPER
00192
00193
00206 int
00207 ReadAMRHierarchyHDF5(
00208 const string& filename,
00210 Vector<DisjointBoxLayout>& a_vectGrids,
00212 Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00214 Vector<string>& a_vectNames,
00216 Box& a_domain,
00218 Real& a_dx,
00220 Real& a_dt,
00222 Real& a_time,
00224 Vector<int>& a_refRatio,
00226 int& a_numLevels,
00228 const IntVect& a_ghostVector = IntVect::TheZeroVector());
00229
00231
00244 int
00245 ReadAMRHierarchyHDF5(
00246 HDF5Handle& handle,
00248 Vector<DisjointBoxLayout>& a_vectGrids,
00250 Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00252 Vector<string>& a_vectNames,
00254 Box& a_domain,
00256 Real& a_dx,
00258 Real& a_dt,
00260 Real& a_time,
00262 Vector<int>& a_refRatio,
00264 int& a_numLevels,
00266 const IntVect& a_ghostVector = IntVect::TheZeroVector());
00267
00268
00270
00283 int
00284 ReadAMRHierarchyHDF5(
00285 const string& filename,
00287 Vector<DisjointBoxLayout>& a_vectGrids,
00289 Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00291 Box& a_domain,
00293 Vector<int>& a_refRatio,
00295 int& a_numLevels,
00297 const IntVect& a_ghostVector = IntVect::TheZeroVector());
00298
00300
00313 int
00314 ReadAMRHierarchyHDF5(
00315 HDF5Handle& handle,
00317 Vector<DisjointBoxLayout>& a_vectGrids,
00319 Vector<LevelData<NodeFArrayBox>* > & a_vectData,
00321 Box& a_domain,
00323 Vector<int>& a_refRatio,
00325 int& a_numLevels,
00327 const IntVect& a_ghostVector = IntVect::TheZeroVector());
00328
00329 #endif
00330
00332
00337 void
00338 writeNFAB(const NodeFArrayBox* a_dataPtr);
00339
00341
00348 void
00349 viewNFAB(const NodeFArrayBox* a_dataPtr);
00350
00352
00357 void
00358 writeNFABname(const NodeFArrayBox* a_dataPtr,
00359 const char* a_filename);
00360
00362
00367 void
00368 writeNodeLevel(const LevelData<NodeFArrayBox>* a_dataPtr);
00369
00371
00378 void
00379 viewNodeLevel(const LevelData<NodeFArrayBox>* a_dataPtr);
00380
00382
00387 void
00388 writeNodeLevelname(const LevelData<NodeFArrayBox>* a_dataPtr,
00389 const char* a_filename);
00390
00392
00401 void
00402 WritePartialAMRHierarchyHDF5(
00403 const string& filename,
00405 const Vector<DisjointBoxLayout>& a_vectGrids,
00407 const Vector<LevelData<FArrayBox>* > & a_vectData,
00409 const Vector<string>& a_vectNames,
00411 const Box& a_baseDomain,
00413 const Real& a_baseDx,
00415 const Real& a_dt,
00417 const Real& a_time,
00419 const Vector<int>& a_vectRatio,
00421 const Interval& a_levels);
00422
00424
00438 void
00439 WritePartialAMRHierarchyHDF5(
00440 const string& filename,
00442 const Vector<DisjointBoxLayout>& a_vectGrids,
00444 const Vector<Vector<LevelData<NodeFArrayBox>* > >& a_vectData,
00446 const Vector<string>& a_vectNames,
00448 const Box& a_baseDomain,
00450 const Real& a_baseDx,
00452 const Real& a_dt,
00454 const Real& a_time,
00456 const Vector<int>& a_vectRatio,
00458 const Interval& a_levels);
00459
00460 #endif