14#ifndef DUMUX_VTKSEQUENCEWRITER_HH
15#define DUMUX_VTKSEQUENCEWRITER_HH
24#include <dune/grid/io/file/vtk/common.hh>
25#include <dune/common/path.hh>
42 template<
class VTKWriter>
45 std::shared_ptr<VTKWriter > vtkWriter_;
46 std::vector<double> timesteps_;
47 std::string name_,path_,extendpath_;
68 const std::string& name,
69 const std::string& path,
70 const std::string& extendpath,
73 : vtkWriter_(vtkWriter),
74 name_(name), path_(path),
75 extendpath_(extendpath),
88 void write (
double time, Dune::VTK::OutputType type = Dune::VTK::ascii)
91 unsigned int count = timesteps_.size();
92 timesteps_.push_back(time);
96 vtkWriter_->write(Dune::concatPaths(path_,seqName(count)),type);
98 vtkWriter_->pwrite(seqName(count), path_,extendpath_,type);
102 std::ofstream pvdFile;
103 pvdFile.exceptions(std::ios_base::badbit | std::ios_base::failbit |
104 std::ios_base::eofbit);
105 std::string pvdname = name_ +
".pvd";
106 pvdFile.open(pvdname.c_str());
107 pvdFile <<
"<?xml version=\"1.0\"?> \n"
108 <<
"<VTKFile type=\"Collection\" version=\"0.1\" byte_order=\"" << Dune::VTK::getEndiannessString() <<
"\"> \n"
109 <<
"<Collection> \n";
110 for (
unsigned int i=0; i<=count; i++)
113 std::string piecepath;
114 std::string fullname;
117 fullname = vtkWriter_->getSerialPieceName(seqName(i), piecepath);
120 piecepath = Dune::concatPaths(path_, extendpath_);
121 fullname = vtkWriter_->getParallelHeaderName(seqName(i), piecepath, size_);
123 pvdFile <<
"<DataSet timestep=\"" << timesteps_[i]
124 <<
"\" group=\"\" part=\"0\" name=\"\" file=\""
125 << fullname <<
"\"/> \n";
127 pvdFile <<
"</Collection> \n"
128 <<
"</VTKFile> \n" << std::flush;
135 std::string seqName(
unsigned int count)
const
139 n << name_ <<
"-" << std::setw(5) << count;
Base class to write pvd-files which contains a list of all collected vtk-files. This is a modified ve...
Definition: vtksequencewriter.hh:44
~VTKSequenceWriter()
Definition: vtksequencewriter.hh:80
VTKSequenceWriter(std::shared_ptr< VTKWriter > vtkWriter, const std::string &name, const std::string &path, const std::string &extendpath, int rank, int size)
Set up the VTKSequenceWriter class.
Definition: vtksequencewriter.hh:67
void write(double time, Dune::VTK::OutputType type=Dune::VTK::ascii)
Writes VTK data for the given time,.
Definition: vtksequencewriter.hh:88