Alsvinn  0.5.3
The fast FVM simulator with UQ support
TimeIntegratedWriter.hpp
Go to the documentation of this file.
1 /* Copyright (c) 2018 ETH Zurich, Kjetil Olsen Lye
2  * This program is free software: you can redistribute it and/or modify
3  * it under the terms of the GNU General Public License as published by
4  * the Free Software Foundation, either version 3 of the License, or
5  * (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program. If not, see <http://www.gnu.org/licenses/>.
14  */
15 
16 #pragma once
19 #include "alsuq/types.hpp"
20 namespace alsuq {
21 namespace stats {
22 
28 public:
29 
35  TimeIntegratedWriter(alsfvm::shared_ptr<Statistics>& writer, real time,
36  real timeRadius);
37  \
38 
40  virtual void combineStatistics() override;
41 
46  virtual void addWriter(const std::string& name,
47  std::shared_ptr<alsfvm::io::Writer>& writer) override;
48 
51  virtual std::vector<std::string> getStatisticsNames() const override;
52 
53  void writeStatistics(const alsfvm::grid::Grid& grid) override;
54 
55 
58  virtual void finalizeStatistics() override;
59 
60 protected:
61  virtual void computeStatistics(const alsfvm::volume::Volume& conservedVariables,
62  const alsfvm::grid::Grid& grid,
63  const alsfvm::simulator::TimestepInformation& timestepInformation) override;
64 
65 private:
66  alsfvm::shared_ptr<Statistics> statistics;
67 
68 };
69 } // namespace stats
70 } // namespace alsuq
TimeIntegratedWriter(alsfvm::shared_ptr< Statistics > &writer, real time, real timeRadius)
Definition: TimeIntegratedWriter.cpp:24
Definition: Grid.hpp:27
The Volume class represents a volume (a collection of cells with values for each cell (eg...
Definition: Volume.hpp:30
virtual void computeStatistics(const alsfvm::volume::Volume &conservedVariables, const alsfvm::grid::Grid &grid, const alsfvm::simulator::TimestepInformation &timestepInformation) override
Definition: TimeIntegratedWriter.cpp:53
virtual std::vector< std::string > getStatisticsNames() const override
Definition: TimeIntegratedWriter.cpp:41
double real
Definition: types.hpp:65
virtual void combineStatistics() override
To be called when the statistics should be combined.
Definition: TimeIntegratedWriter.cpp:32
std::string name
Definition: EquationParameterFactory.cpp:39
const grid::Grid & grid
Definition: NumericalFluxFactory.cpp:104
Definition: TimeIntegratedWriter.hpp:27
Definition: Statistics.hpp:25
void writeStatistics(const alsfvm::grid::Grid &grid) override
Definition: TimeIntegratedWriter.cpp:45
virtual void addWriter(const std::string &name, std::shared_ptr< alsfvm::io::Writer > &writer) override
Definition: TimeIntegratedWriter.cpp:36
virtual void finalizeStatistics() override
Definition: TimeIntegratedWriter.cpp:49
Definition: Setup.hpp:22
Definition: TimestepInformation.hpp:22