ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
stretchZone.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 STRETCHZONE_H
32#define STRETCHZONE_H
33
34#include <vector>
35#include <string>
36
39
41{
42 public:
44 stretchZone(double startAt, double endtAt, double factor, int numberCells);
45 virtual ~stretchZone();
46
47 int stretching(std::vector<double>& dX, std::vector<double>& posX);
48
49 static int verifyStretching(std::vector<stretchZone>& tabStretch, const double l, std::string fileName = "");
50
51 private:
52 double m_startAt;
53 double m_endAt;
54 double m_factor;
56};
57
58#endif // STRETCHZONE_H
managing a stretched zone in Cartesian meshes
Definition stretchZone.h:41
double m_startAt
zone starting position along corresponding axis
Definition stretchZone.h:52
int m_numberCells
number of cells in the stretched zone
Definition stretchZone.h:55
int stretching(std::vector< double > &dX, std::vector< double > &posX)
Definition stretchZone.cpp:47
static int verifyStretching(std::vector< stretchZone > &tabStretch, const double l, std::string fileName="")
Definition stretchZone.cpp:72
double m_factor
stretching factor (1. is no stretching)
Definition stretchZone.h:54
virtual ~stretchZone()
Definition stretchZone.cpp:43
double m_endAt
zone ending position along corresponding axis
Definition stretchZone.h:53