ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
Relaxation.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 RELAXATION_H
32#define RELAXATION_H
33
34class Relaxation; //Predeclaration of class Relaxation to include Cell.h
35
36#include "../libTierces/tinyxml2.h"
37#include "../Errors.h"
38#include "../Tools.h"
39#include "../Order1/Cell.h"
40#include "../libTierces/svd.h"
41
45{
46public:
47 Relaxation();
48 virtual ~Relaxation();
49
51 virtual int getType() const { Errors::errorMessage("getType not available for required relaxation"); return 0; }
52
58 virtual void relaxation(Cell* /*cell*/, const double& /*dt*/, Prim /*type*/ = vecPhases) { Errors::errorMessage("relaxation not available for required relaxation"); };
59
63 virtual void initializeCriticalPressure(Cell* /*cell*/) {};
64
65private:
66};
67
68#endif // RELAXATION_H
Prim
Enumeration for the primitive-variable type (usefull for second order, slopes, etc....
Definition Tools.h:39
@ vecPhases
Definition Tools.h:39
Base class for a mesh cell.
Definition Cell.h:59
static void errorMessage(const std::string &message)
Definition Errors.cpp:56
Abstract class for Relaxations.
Definition Relaxation.h:45
virtual void initializeCriticalPressure(Cell *)
Initialize the theoritical critical pressure of the fluid (only required for PTMu relax)
Definition Relaxation.h:63
virtual void relaxation(Cell *, const double &, Prim=vecPhases)
Stiff relaxation methods.
Definition Relaxation.h:58
virtual int getType() const
Return the type of the corresponding relaxation method.
Definition Relaxation.h:51
Relaxation()
Definition Relaxation.cpp:35
virtual ~Relaxation()
Definition Relaxation.cpp:39