18#include <boost/filesystem.hpp>
23 const h5_int64_t H5TypesCHAR = H5_STRING_T;
24 const h5_int64_t H5TypesFLOAT = H5_FLOAT32_T;
25 const h5_int64_t H5TypesDOUBLE = H5_FLOAT64_T;
26 const h5_int64_t H5TypesINT32 = H5_INT32_T;
27 const h5_int64_t H5TypesINT64 = H5_INT64_T;
35 predecessorOPALFlavour_m(
"NOT SET"),
37 startedFromExistingFile_m(false)
45 predecessorOPALFlavour_m(
"NOT SET"),
47 startedFromExistingFile_m(true)
49 if (sourceFile.empty()) {
53 copyFile(sourceFile, restartStep, flags);
75 h5_prop_t props = H5CreateFileProp ();
77 h5_err_t h5err = H5SetPropFileMPIOCollective (props, &comm);
90 h5_int64_t nFormerlySavedAutoPhaseCavities = 0;
91 bool fileWasClosed = (
file_m == 0);
93 if (nAutoPhaseCavities == 0)
return;
94 if (fileWasClosed)
open(H5_O_APPENDONLY);
95 if (!H5HasFileAttrib(
file_m,
"nAutoPhaseCavities") ||
96 H5ReadFileAttribInt64(
file_m,
"nAutoPhaseCavities", &nFormerlySavedAutoPhaseCavities) != H5_SUCCESS) {
97 nFormerlySavedAutoPhaseCavities = 0;
99 if (nFormerlySavedAutoPhaseCavities == nAutoPhaseCavities) {
100 if (fileWasClosed)
close();
106 unsigned int elementNumber = 1;
109 for(; it <
end; ++ it, ++ elementNumber) {
110 if (elementNumber <= nFormerlySavedAutoPhaseCavities)
continue;
112 std::string nameAttributeName =
"Cav-" + std::to_string(elementNumber) +
"-name";
113 std::string valueAttributeName =
"Cav-" + std::to_string(elementNumber) +
"-value";
115 std::string elementName = (*it).first;
116 h5_float64_t elementPhase = (*it).second;
121 INFOMSG(
"Saved phases in the h5 file: "
122 << nameAttributeName <<
" -> " << elementName <<
" --- "
123 << valueAttributeName <<
" -> " << elementPhase <<
endl);
126 if (fileWasClosed)
close();
131 namespace fs = boost::filesystem;
132 if (!fs::exists(sourceFile)) {
134 "source file '" + sourceFile +
"' does not exist");
138 h5_prop_t props = H5CreateFileProp ();
140 h5_err_t h5err = H5SetPropFileMPIOCollective (props, &comm);
145 h5_file_t source = H5OpenFile (sourceFile.c_str(), H5_O_RDONLY, props);
146 PAssert (source != (h5_file_t)H5_ERR);
148 h5_ssize_t numStepsInSource = H5GetNumSteps(source);
150 if (lastStep == -1 || lastStep >= numStepsInSource) {
153 char opalFlavour[128];
175 props = H5CreateFileProp ();
177 h5err = H5SetPropFileMPIOCollective (props, &comm);
179 source = H5OpenFile (sourceFileName.c_str(), H5_O_RDONLY, props);
180 PAssert (source != (h5_file_t)H5_ERR);
185 if (-lastStep > numStepsInSource) {
188 lastStep = numStepsInSource + lastStep;
199 fs::remove(sourceFileName);
207 h5_prop_t props = H5CreateFileProp ();
209 h5_err_t h5err = H5SetPropFileMPIOCollective (props, &comm);
214 h5_file_t source = H5OpenFile (sourceFile.c_str(), H5_O_RDONLY, props);
215 PAssert (source != (h5_file_t)H5_ERR);
217 h5_ssize_t numStepsInSource = H5GetNumSteps(source);
219 if (lastStep == -1 || lastStep >= numStepsInSource) {
222 char opalFlavour[128];
237 if (-lastStep > numStepsInSource) {
240 lastStep = numStepsInSource + lastStep;
270 std::ifstream source(sourceFile, std::ios::binary);
271 std::ofstream dest(
fileName_m, std::ios::binary);
273 std::istreambuf_iterator<char> begin_source(source);
274 std::istreambuf_iterator<char> end_source;
275 std::ostreambuf_iterator<char> begin_dest(dest);
276 std::copy(begin_source, end_source, begin_dest);
281 "H5PartWrapper::copyFile",
282 "could not copy file " + sourceFile);
286 "H5PartWrapper::copyFile",
287 "received message to throw exception from node 0");
294 h5_int64_t numFileAttributes = H5GetNumFileAttribs(source);
296 const h5_size_t lengthAttributeName = 256;
298 h5_int64_t attributeType;
299 h5_size_t numAttributeElements;
300 std::vector<char> buffer(256);
301 h5_float32_t *f32buffer =
reinterpret_cast<h5_float32_t*
>(&buffer[0]);
302 h5_float64_t *f64buffer =
reinterpret_cast<h5_float64_t*
>(&buffer[0]);
303 h5_int32_t *i32buffer =
reinterpret_cast<h5_int32_t*
>(&buffer[0]);
304 h5_int64_t *i64buffer =
reinterpret_cast<h5_int64_t*
>(&buffer[0]);
306 for (h5_int64_t i = 0; i < numFileAttributes; ++ i) {
312 &numAttributeElements));
314 if (attributeType == H5_STRING_T) {
315 if (buffer.size() < numAttributeElements) {
316 buffer.resize(numAttributeElements);
322 }
else if (attributeType == H5_FLOAT32_T) {
323 if (buffer.size() < numAttributeElements *
sizeof(h5_float32_t)) {
324 buffer.resize(numAttributeElements *
sizeof(h5_float32_t));
330 }
else if (attributeType == H5_FLOAT64_T) {
331 if (buffer.size() < numAttributeElements *
sizeof(h5_float64_t)) {
332 buffer.resize(numAttributeElements *
sizeof(h5_float64_t));
338 }
else if (attributeType == H5_INT32_T) {
339 if (buffer.size() < numAttributeElements *
sizeof(h5_int32_t)) {
340 buffer.resize(numAttributeElements *
sizeof(h5_int32_t));
346 }
else if (attributeType == H5_INT64_T) {
347 if (buffer.size() < numAttributeElements *
sizeof(h5_int64_t)) {
348 buffer.resize(numAttributeElements *
sizeof(h5_int64_t));
356 "unknown data type: " + std::to_string(attributeType));
375 h5_int64_t numStepAttributes = H5GetNumStepAttribs(source);
377 h5_size_t lengthAttributeName = 256;
379 h5_int64_t attributeType;
380 h5_size_t numAttributeElements;
382 std::vector<char> buffer(256);
383 h5_float32_t *f32buffer =
reinterpret_cast<h5_float32_t*
>(&buffer[0]);
384 h5_float64_t *f64buffer =
reinterpret_cast<h5_float64_t*
>(&buffer[0]);
385 h5_int32_t *i32buffer =
reinterpret_cast<h5_int32_t*
>(&buffer[0]);
386 h5_int64_t *i64buffer =
reinterpret_cast<h5_int64_t*
>(&buffer[0]);
391 for (h5_int64_t i = 0; i < numStepAttributes; ++ i) {
397 &numAttributeElements));
399 if (attributeType == H5TypesCHAR) {
400 if (buffer.size() < numAttributeElements) {
401 buffer.resize(numAttributeElements);
407 }
else if (attributeType == H5TypesFLOAT) {
408 if (buffer.size() < numAttributeElements *
sizeof(h5_float32_t)) {
409 buffer.resize(numAttributeElements *
sizeof(h5_float32_t));
415 }
else if (attributeType == H5TypesDOUBLE) {
416 if (buffer.size() < numAttributeElements *
sizeof(h5_float64_t)) {
417 buffer.resize(numAttributeElements *
sizeof(h5_float64_t));
423 }
else if (attributeType == H5TypesINT32) {
424 if (buffer.size() < numAttributeElements *
sizeof(h5_int32_t)) {
425 buffer.resize(numAttributeElements *
sizeof(h5_int32_t));
431 }
else if (attributeType == H5TypesINT64) {
432 if (buffer.size() < numAttributeElements *
sizeof(h5_int64_t)) {
433 buffer.resize(numAttributeElements *
sizeof(h5_int64_t));
441 "unknown data type: " + std::to_string(attributeType));
449 h5_size_t lengthSetName = 256;
450 char setName[lengthSetName];
452 h5_size_t numSetElements;
454 h5_ssize_t numParticles = H5PartGetNumParticles(source);
457 h5_ssize_t firstParticle = numParticlesPerNode *
Ippl::myNode();
458 h5_ssize_t lastParticle = firstParticle + numParticlesPerNode - 1;
460 lastParticle = numParticles - 1;
462 REPORTONERROR(H5PartSetView(source, firstParticle, lastParticle));
464 numParticles = lastParticle - firstParticle + 1;
467 std::vector<char> buffer(numParticles *
sizeof(h5_float64_t));
469 h5_float32_t *f32buffer =
reinterpret_cast<h5_float32_t*
>(buffer_ptr);
470 h5_float64_t *f64buffer =
reinterpret_cast<h5_float64_t*
>(buffer_ptr);
471 h5_int32_t *i32buffer =
reinterpret_cast<h5_int32_t*
>(buffer_ptr);
472 h5_int64_t *i64buffer =
reinterpret_cast<h5_int64_t*
>(buffer_ptr);
474 h5_ssize_t numDatasets = H5PartGetNumDatasets(source);
476 for (h5_ssize_t i = 0; i < numDatasets; ++ i) {
477 REPORTONERROR(H5PartGetDatasetInfo(source, i, setName, lengthSetName, &setType, &numSetElements));
479 if (setType == H5TypesFLOAT) {
480 READDATA(Float32, source, setName, f32buffer);
482 }
else if (setType == H5TypesDOUBLE) {
483 READDATA(Float64, source, setName, f64buffer);
485 }
else if (setType == H5TypesINT32) {
486 READDATA(Int32, source, setName, i32buffer);
488 }
else if (setType == H5TypesINT64) {
489 READDATA(Int64, source, setName, i64buffer);
493 "unknown data type: " + std::to_string(setType));
497 numParticles = H5PartGetNumParticles(
file_m);
502 const std::string &
where,
503 const std::string &what) {
514 const std::string &
where,
515 const std::string &what) {
532 h5_ssize_t numParticles = H5PartGetNumParticles(
file_m);
PartBunchBase< T, Dim >::ConstIterator end(PartBunchBase< T, Dim > const &bunch)
#define WRITESTRINGFILEATTRIB(file, name, value)
#define WRITESTEPATTRIB(type, file, name, value, length)
#define REPORTONERROR(rc)
#define READSTEPATTRIB(type, file, name, value)
#define WRITEDATA(type, file, name, value)
#define WRITEFILEATTRIB(type, file, name, value, length)
#define WRITESTRINGSTEPATTRIB(file, name, value)
#define READDATA(type, file, name, value)
#define READFILEATTRIB(type, file, name, value)
void putMessage(Message &m, const T &t)
void getMessage(Message &m, T &t)
PETE_TTTree< OpWhere, typename Cond_t::PETE_Expr_t, typename True_t::PETE_Expr_t, PETE_Scalar< Vektor< T, Dim > > > where(const PETE_Expr< Cond_t > &c, const PETE_Expr< True_t > &t, const Vektor< T, Dim > &f)
Inform & endl(Inform &inf)
std::map< AttributeType, std::string > attributeName
std::string::iterator iterator
T * c_data(std::vector< T, A > &v)
int getNumberOfMaxPhases()
std::vector< MaxPhasesT >::iterator getLastMaxPhases()
std::vector< MaxPhasesT >::iterator getFirstMaxPhases()
static OpalData * getInstance()
size_t getNumParticles() const
void receiveFailureMessage(int sourceNode, const std::string &where, const std::string &what)
void copyStepData(h5_file_t source)
void copyFile(const std::string &sourceFile, int lastStep=-1, h5_int32_t flags=H5_O_WRONLY)
void open(h5_int32_t flags)
void copyFileSystem(const std::string &sourceFile)
H5PartWrapper(const std::string &fileName, h5_int32_t flags=H5_O_WRONLY)
void copyHeader(h5_file_t source)
std::string predecessorOPALFlavour_m
void storeCavityInformation()
void copyStepHeader(h5_file_t source)
void copyStep(h5_file_t source, int step)
static std::string copyFilePrefix_m
void sendFailureMessage(bool failed, const std::string &where, const std::string &what)
The base class for all OPAL exceptions.
Message * receive_block(int &node, int &tag)
virtual int broadcast_all(Message *, int)
static MPI_Comm getComm()
static Communicate * Comm