1 |
francois |
1053 |
#ifndef __MAILLEUR2D_STRUCTURE_ |
2 |
|
|
#define __MAILLEUR2D_STRUCTURE_ |
3 |
|
|
#include "mailleur.h" |
4 |
|
|
|
5 |
|
|
|
6 |
|
|
/*! |
7 |
|
|
* \brief Note |
8 |
|
|
* |
9 |
|
|
* Pour utliser le mailleur structuré avec la densité variable il faut fournir des fonctions écart nodale dans chaque direction parametrée entre [0 1]. |
10 |
|
|
*/ |
11 |
|
|
|
12 |
|
|
|
13 |
|
|
class MG_GESTIONNAIRE; |
14 |
|
|
class MAILLEUR2D_STRUCTURE:public MAILLEUR |
15 |
|
|
{ |
16 |
|
|
public: |
17 |
|
|
MAILLEUR2D_STRUCTURE( double xmintmp, double xmaxtmp, double ymintmp, double ymaxtmp, int ntmp, int mtmp, MG_GESTIONNAIRE* gesttmp,int avecgeo=false,double unit=1.); |
18 |
|
|
MAILLEUR2D_STRUCTURE( double xmintmp, double xmaxtmp, double ymintmp, double ymaxtmp,double (*fx)(double),double (*fy)(double),MG_GESTIONNAIRE* gesttmp,int avecgeo=false,double unit=1.); |
19 |
|
|
MAILLEUR2D_STRUCTURE( MAILLEUR2D_STRUCTURE &mdd); |
20 |
|
|
virtual ~MAILLEUR2D_STRUCTURE(); |
21 |
|
|
virtual int maille(class MG_GROUPE_TOPOLOGIQUE* mggt=NULL) ; |
22 |
|
|
virtual void ajuste(class MG_MAILLAGE *mai,MG_MAILLAGE* maibase,int nb) ; |
23 |
|
|
virtual void ajouter_fonction_geometrie(int nb); |
24 |
|
|
|
25 |
|
|
private: |
26 |
|
|
virtual void discretise(std::vector<double> &tab,double min,double max,int &nb,double (*en)(double)); |
27 |
|
|
double xmin; |
28 |
|
|
double xmax; |
29 |
|
|
double ymin; |
30 |
|
|
double ymax; |
31 |
|
|
int n; |
32 |
|
|
int m; |
33 |
|
|
MG_GESTIONNAIRE* gest; |
34 |
|
|
bool geovirtuel; |
35 |
|
|
bool densitevariable; |
36 |
|
|
double (*enx)(double); |
37 |
|
|
double (*eny)(double); |
38 |
|
|
double unite; |
39 |
|
|
int nbfonction; |
40 |
|
|
}; |
41 |
|
|
#endif |