pickle mesh-load also via ngsolve.Mesh('filename.vol.bin')

This commit is contained in:
Joachim Schoeberl 2021-06-17 07:58:17 +02:00
parent 4b40a7eb31
commit b51df253fd

View File

@ -146,28 +146,38 @@ void Ng_LoadMesh (const char * filename, ngcore::NgMPI_Comm comm)
if( id == 0) { if( id == 0) {
string fn(filename);
if (fn.substr (fn.length()-3, 3) == ".gz")
infile = new igzstream (filename);
else
infile = new ifstream (filename);
mesh.reset (new Mesh()); mesh.reset (new Mesh());
mesh->SetCommunicator(comm); mesh->SetCommunicator(comm);
mesh -> Load(*infile);
SetGlobalMesh (mesh); string fn(filename);
if (fn.substr (fn.length()-8, 8) == ".vol.bin")
// make string from rest of file (for geometry info!) {
// (this might be empty, in which case we take the global ng_geometry) mesh -> Load(fn);
stringstream geom_part; SetGlobalMesh (mesh);
geom_part << infile->rdbuf(); }
string geom_part_string = geom_part.str(); else
strs = geom_part_string.size(); {
// buf = new char[strs]; if (fn.substr (fn.length()-3, 3) == ".gz")
buf.SetSize(strs); infile = new igzstream (filename);
memcpy(&buf[0], geom_part_string.c_str(), strs*sizeof(char)); else
infile = new ifstream (filename);
delete infile; mesh -> Load(*infile);
SetGlobalMesh (mesh);
// make string from rest of file (for geometry info!)
// (this might be empty, in which case we take the global ng_geometry)
stringstream geom_part;
geom_part << infile->rdbuf();
string geom_part_string = geom_part.str();
strs = geom_part_string.size();
// buf = new char[strs];
buf.SetSize(strs);
memcpy(&buf[0], geom_part_string.c_str(), strs*sizeof(char));
delete infile;
}
if (ntasks > 1) if (ntasks > 1)
{ {