1 |
#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 |