10#ifndef DUMUX_VTKSEQUENCEWRITER_HH
11#define DUMUX_VTKSEQUENCEWRITER_HH
20#include <dune/grid/io/file/vtk/common.hh>
21#include <dune/common/path.hh>
38 template<
class VTKWriter>
41 std::shared_ptr<VTKWriter > vtkWriter_;
42 std::vector<double> timesteps_;
43 std::string name_,path_,extendpath_;
64 const std::string& name,
65 const std::string& path,
66 const std::string& extendpath,
69 : vtkWriter_(vtkWriter),
70 name_(name), path_(path),
71 extendpath_(extendpath),
84 void write (
double time, Dune::VTK::OutputType type = Dune::VTK::ascii)
87 unsigned int count = timesteps_.size();
88 timesteps_.push_back(time);
92 vtkWriter_->write(Dune::concatPaths(path_,seqName(count)),type);
94 vtkWriter_->pwrite(seqName(count), path_,extendpath_,type);
98 std::ofstream pvdFile;
99 pvdFile.exceptions(std::ios_base::badbit | std::ios_base::failbit |
100 std::ios_base::eofbit);
101 std::string pvdname = name_ +
".pvd";
102 pvdFile.open(pvdname.c_str());
103 pvdFile <<
"<?xml version=\"1.0\"?> \n"
104 <<
"<VTKFile type=\"Collection\" version=\"0.1\" byte_order=\"" << Dune::VTK::getEndiannessString() <<
"\"> \n"
105 <<
"<Collection> \n";
106 for (
unsigned int i=0; i<=count; i++)
109 std::string piecepath;
110 std::string fullname;
113 fullname = vtkWriter_->getSerialPieceName(seqName(i), piecepath);
116 piecepath = Dune::concatPaths(path_, extendpath_);
117 fullname = vtkWriter_->getParallelHeaderName(seqName(i), piecepath, size_);
119 pvdFile <<
"<DataSet timestep=\"" << timesteps_[i]
120 <<
"\" group=\"\" part=\"0\" name=\"\" file=\""
121 << fullname <<
"\"/> \n";
123 pvdFile <<
"</Collection> \n"
124 <<
"</VTKFile> \n" << std::flush;
131 std::string seqName(
unsigned int count)
const
135 n << name_ <<
"-" << std::setw(5) << count;
make the local view function available whenever we use the grid geometry
Definition: adapt.hh:29
Base class to write pvd-files which contains a list of all collected vtk-files. This is a modified ve...
Definition: vtksequencewriter.hh:40
~VTKSequenceWriter()
Definition: vtksequencewriter.hh:76
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:63
void write(double time, Dune::VTK::OutputType type=Dune::VTK::ascii)
Writes VTK data for the given time,.
Definition: vtksequencewriter.hh:84