Alsvinn  0.5.3
The fast FVM simulator with UQ support
Uniform1D.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
18 namespace alsuq {
19 namespace distribution {
20 
22 class Uniform1D : public Distribution {
23 public:
24  Uniform1D(size_t numberOfSamples, real a, real b);
27  virtual real generate(generator::Generator& generator, size_t component,
28  size_t sample) override;
29 private:
30 
31  real deltaX;
32  real a;
33 };
34 } // namespace generator
35 } // namespace alsuq
Uniform1D(size_t numberOfSamples, real a, real b)
Definition: Uniform1D.cpp:22
virtual real generate(generator::Generator &generator, size_t component, size_t sample) override
Definition: Uniform1D.cpp:29
Definition: Distribution.hpp:21
double real
Definition: types.hpp:65
Uses the midpoint rule of integration.
Definition: Uniform1D.hpp:22
Definition: Generator.hpp:27
Definition: Setup.hpp:22