ecfvbaseoutputmodule.hh
Go to the documentation of this file.
1 // -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 // vi: set et ts=4 sw=4 sts=4:
3 /*
4  Copyright (C) 2013 by Andreas Lauser
5 
6  This file is part of the Open Porous Media project (OPM).
7 
8  OPM is free software: you can redistribute it and/or modify
9  it under the terms of the GNU General Public License as published by
10  the Free Software Foundation, either version 2 of the License, or
11  (at your option) any later version.
12 
13  OPM is distributed in the hope that it will be useful,
14  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  GNU General Public License for more details.
17 
18  You should have received a copy of the GNU General Public License
19  along with OPM. If not, see <http://www.gnu.org/licenses/>.
20 */
26 #ifndef EWOMS_ECFV_VTK_BASE_OUTPUT_MODULE_HH
27 #define EWOMS_ECFV_VTK_BASE_OUTPUT_MODULE_HH
28 
29 #include "ecfvproperties.hh"
30 
32 
33 namespace Ewoms {
39 template<class TypeTag>
41 {
42 public:
48 
53  static void attachScalarDofData_(BaseOutputWriter &baseWriter,
54  ScalarBuffer &buffer,
55  const std::string &name)
56  { baseWriter.attachScalarElementData(buffer, name.c_str()); }
57 
62  static void attachVectorDofData_(BaseOutputWriter &baseWriter,
63  VectorBuffer &buffer,
64  const std::string &name)
65  { baseWriter.attachVectorElementData(buffer, name.c_str()); }
66 
71  static void attachTensorDofData_(BaseOutputWriter &baseWriter,
72  TensorBuffer &buffer,
73  const std::string &name)
74  { baseWriter.attachTensorElementData(buffer, name.c_str()); }
75 };
76 
77 } // namespace Ewoms
78 
79 #endif
virtual void attachVectorElementData(VectorBuffer &buf, std::string name)=0
Add a vectorial element centered quantity to the output.
BaseOutputWriter::VectorBuffer VectorBuffer
Definition: ecfvbaseoutputmodule.hh:46
std::vector< Vector > VectorBuffer
Definition: baseoutputwriter.hh:48
std::vector< Scalar > ScalarBuffer
Definition: baseoutputwriter.hh:47
std::vector< Tensor > TensorBuffer
Definition: baseoutputwriter.hh:49
static void attachVectorDofData_(BaseOutputWriter &baseWriter, VectorBuffer &buffer, const std::string &name)
Add a buffer where the data is associated with the degrees of freedom to the current VTK output file...
Definition: ecfvbaseoutputmodule.hh:62
BaseOutputWriter::Vector Vector
Definition: ecfvbaseoutputmodule.hh:44
double Scalar
Definition: baseoutputwriter.hh:44
Implements the discretization specific parts of writing files.
Definition: ecfvbaseoutputmodule.hh:40
static void attachScalarDofData_(BaseOutputWriter &baseWriter, ScalarBuffer &buffer, const std::string &name)
Add a buffer where the data is associated with the degrees of freedom to the current VTK output file...
Definition: ecfvbaseoutputmodule.hh:53
The base class for all output writers.
Definition: baseoutputwriter.hh:41
static void attachTensorDofData_(BaseOutputWriter &baseWriter, TensorBuffer &buffer, const std::string &name)
Add a buffer where the data is associated with the degrees of freedom to the current VTK output file...
Definition: ecfvbaseoutputmodule.hh:71
BaseOutputWriter::Scalar Scalar
Definition: ecfvbaseoutputmodule.hh:43
Simplifies writing multi-file VTK datasets.
Definition: baseauxiliarymodule.hh:35
BaseOutputWriter::TensorBuffer TensorBuffer
Definition: ecfvbaseoutputmodule.hh:47
Declare the basic properties used by the common infrastructure of the element-centered finite volume ...
virtual void attachTensorElementData(TensorBuffer &buf, std::string name)=0
Add a tensorial element centered quantity to the output.
virtual void attachScalarElementData(ScalarBuffer &buf, std::string name)=0
Add a scalar element centered quantity to the output.
BaseOutputWriter::ScalarBuffer ScalarBuffer
Definition: ecfvbaseoutputmodule.hh:45
Dune::DynamicVector< double > Vector
Definition: baseoutputwriter.hh:45