Alsvinn  0.5.3
The fast FVM simulator with UQ support
InitialData.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
17 #include "alsfvm/volume/Volume.hpp"
18 #include "alsfvm/grid/Grid.hpp"
21 #include <boost/property_tree/ptree.hpp>
22 namespace alsfvm {
23 namespace init {
24 
25 class InitialData {
26 public:
27  virtual ~InitialData() {}
39  virtual void setInitialData(volume::Volume& conservedVolume,
40  volume::Volume& primitiveVolume,
41  equation::CellComputer& cellComputer,
42  grid::Grid& grid) = 0;
43 
44 
45  virtual void setParameters(const Parameters& parameters) = 0;
46 
50  virtual boost::property_tree::ptree getDescription() const = 0;
51 };
52 } // namespace alsfvm
53 } // namespace init
Definition: Grid.hpp:27
The CellComputer class defines some useful per cell computations.
Definition: CellComputer.hpp:25
virtual void setInitialData(volume::Volume &conservedVolume, volume::Volume &primitiveVolume, equation::CellComputer &cellComputer, grid::Grid &grid)=0
setInitialData sets the initial data
simulator::SimulatorParameters & parameters
Definition: CellComputerFactory.cpp:60
virtual ~InitialData()
Definition: InitialData.hpp:27
The Volume class represents a volume (a collection of cells with values for each cell (eg...
Definition: Volume.hpp:30
Definition: Parameters.hpp:27
virtual void setParameters(const Parameters &parameters)=0
Definition: InitialData.hpp:25
const grid::Grid & grid
Definition: NumericalFluxFactory.cpp:104
Various utility functions to implement the tecno flux.
Definition: types.hpp:30
virtual boost::property_tree::ptree getDescription() const =0