ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
GradMixture.h
Go to the documentation of this file.
1//
2// ,---. ,--, .---. ,--, ,---. .-. .-.
3// | .-' .' .') / .-. ) .' .' | .-' | \| |
4// | `-. | |(_) | | |(_) | | __ | `-. | | |
5// | .-' \ \ | | | | \ \ ( _) | .-' | |\ |
6// | `--. \ `-. \ `-' / \ `-) ) | `--. | | |)|
7// /( __.' \____\ )---' )\____/ /( __.' /( (_)
8// (__) (_) (__) (__) (__)
9// Official webSite: https://code-mphi.github.io/ECOGEN/
10//
11// This file is part of ECOGEN.
12//
13// ECOGEN is the legal property of its developers, whose names
14// are listed in the copyright file included with this source
15// distribution.
16//
17// ECOGEN is free software: you can redistribute it and/or modify
18// it under the terms of the GNU General Public License as published
19// by the Free Software Foundation, either version 3 of the License,
20// or (at your option) any later version.
21//
22// ECOGEN is distributed in the hope that it will be useful,
23// but WITHOUT ANY WARRANTY; without even the implied warranty of
24// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25// GNU General Public License for more details.
26//
27// You should have received a copy of the GNU General Public License
28// along with ECOGEN (file LICENSE).
29// If not, see <http://www.gnu.org/licenses/>.
30
31#ifndef GRADMIXTURE_H
32#define GRADMIXTURE_H
33
34#include "../Tools.h"
35
36class Cell;
37class Mixture;
38
39#include "../Maths/Coord.h"
40
43
45{
46public:
48 virtual ~GradMixture();
49
50 virtual void initializeGradientVectors() { Errors::errorMessage("initializeGradientVectors not available for required GradMixture"); };
51
52 virtual void computeGradients(Cell* cell);
53 virtual void computeDistanceGradientScalarProduct(Coord const& /*distance*/, Mixture* /*mixture*/) const { Errors::errorMessage("computeDistanceGradientScalarProduct not available for required GradMixture"); };
54 virtual void limitGradients(const Mixture& /*gradientLimiter*/) { Errors::errorMessage("limitGradients not available for required GradMixture"); };
55
56 // -- O2 parallel --
57 virtual int numberOfTransmittedGradients() const { Errors::errorMessage("numberOfTransmittedGradients not available for required GradMixture"); return Errors::defaultInt; };
58 virtual void getBufferGradients(double * buffer, int& counter);
59 virtual void fillBufferGradients(double * buffer, int& counter);
60
61protected:
63
64 std::vector<Coord> m_grads;
65};
66
67extern std::vector<Variable> variableNamesMixture;
68extern std::vector<int> numeratorMixture;
69
70#endif
std::vector< Variable > variableNamesMixture
Variable names of the corresponding gradients (for mixture)
Definition GradMixture.cpp:4
std::vector< int > numeratorMixture
Default number (not used for mixture variables)
Definition GradMixture.cpp:5
Base class for a mesh cell.
Definition Cell.h:59
Class for a coordinate system object such as coordinates of the vertex or a vector.
Definition Coord.h:43
static constexpr int defaultInt
Definition Errors.h:91
static void errorMessage(const std::string &message)
Definition Errors.cpp:56
Mixture variable gradients. Stored for 2nd-order computation on unstructured mesh (O2 NS)
Definition GradMixture.h:45
GradMixture()
Definition GradMixture.cpp:9
virtual ~GradMixture()
Definition GradMixture.cpp:13
virtual void computeGradients(Cell *cell)
Definition GradMixture.cpp:33
void initializeGradsVariablesNamesNumerators()
Definition GradMixture.cpp:17
virtual void computeDistanceGradientScalarProduct(Coord const &, Mixture *) const
Definition GradMixture.h:53
virtual int numberOfTransmittedGradients() const
Definition GradMixture.h:57
virtual void fillBufferGradients(double *buffer, int &counter)
Definition GradMixture.cpp:53
virtual void getBufferGradients(double *buffer, int &counter)
Definition GradMixture.cpp:42
virtual void initializeGradientVectors()
Definition GradMixture.h:50
virtual void limitGradients(const Mixture &)
Definition GradMixture.h:54
std::vector< Coord > m_grads
Vector of gradients of the mixture flow variables.
Definition GradMixture.h:64
Abstract class for mixture variables.
Definition Mixture.h:43