1 |
francois |
283 |
//------------------------------------------------------------ |
2 |
|
|
//------------------------------------------------------------ |
3 |
|
|
// MAGiC |
4 |
|
|
// Jean Christophe Cuilli�re et Vincent FRANCOIS |
5 |
|
|
// D�partement de G�nie M�canique - UQTR |
6 |
|
|
//------------------------------------------------------------ |
7 |
|
|
// Le projet MAGIC est un projet de recherche du d�partement |
8 |
|
|
// de g�nie m�canique de l'Universit� du Qu�bec � |
9 |
|
|
// Trois Rivi�res |
10 |
|
|
// Les librairies ne peuvent �tre utilis�es sans l'accord |
11 |
|
|
// des auteurs (contact : francois@uqtr.ca) |
12 |
|
|
//------------------------------------------------------------ |
13 |
|
|
//------------------------------------------------------------ |
14 |
|
|
// |
15 |
|
|
// geom.h |
16 |
|
|
// |
17 |
|
|
//------------------------------------------------------------ |
18 |
|
|
//------------------------------------------------------------ |
19 |
|
|
// COPYRIGHT 2000 |
20 |
|
|
// Version du 02/03/2006 � 11H22 |
21 |
|
|
//------------------------------------------------------------ |
22 |
|
|
//------------------------------------------------------------ |
23 |
|
|
#ifndef __MAGIC_ |
24 |
|
|
#define __MAGIC_ |
25 |
|
|
|
26 |
|
|
|
27 |
|
|
|
28 |
|
|
|
29 |
|
|
#ifdef BORLANDCPP |
30 |
|
|
#include <set.h> |
31 |
|
|
#else |
32 |
|
|
#include <set> |
33 |
|
|
|
34 |
|
|
#endif |
35 |
|
|
|
36 |
|
|
#include <functional> |
37 |
|
|
|
38 |
|
|
const int MEME_SENS=1; |
39 |
|
|
const int SENS_CONTRAIRE=-1; |
40 |
|
|
|
41 |
|
|
const int OK=1; |
42 |
|
|
const int FAIL=0; |
43 |
|
|
|
44 |
francois |
375 |
|
45 |
|
|
const int MAX_TYPE_SOLUTION=9; |
46 |
francois |
410 |
const int MAX_ETAT=2; |
47 |
francois |
375 |
|
48 |
francois |
283 |
template <class T> |
49 |
|
|
struct inf : std::binary_function<T, T, bool> { |
50 |
|
|
bool operator() ( const T& x, const T& y) const { |
51 |
|
|
return x->get_id() < y->get_id(); |
52 |
|
|
} |
53 |
|
|
}; |
54 |
|
|
|
55 |
francois |
791 |
/*#define MAILLEUR_AUTO 1000 |
56 |
|
|
#define TRIANGULATION 1010 |
57 |
|
|
#define IMPOSE 1020 |
58 |
|
|
#define DUPLIQUER 1030 |
59 |
|
|
#define MODIFICATION 1040 |
60 |
|
|
#define OPTIMISE 1050 |
61 |
|
|
#define DEFORME 1060 |
62 |
|
|
#define GMSH 1070 |
63 |
|
|
#define SQUELETTE 1080*/ |
64 |
francois |
283 |
|
65 |
francois |
791 |
|
66 |
francois |
375 |
namespace MAGIC |
67 |
|
|
{ |
68 |
francois |
1150 |
|
69 |
|
|
class TYPE_ENTITE |
70 |
|
|
{ |
71 |
|
|
public: |
72 |
|
|
enum mgelement {IDMG_NOEUD=100,IDM3D_NOEUD=110,IDMG_SEGMENT=200,IDMG_TRIANGLE=300,IDMG_QUADRANGLE=360,IDMG_TETRA=400,IDMG_HEXA=460,IDMG_PENTA=470,IDMG_PYRAMIDE=480,IDM3D_TRIANGLE=310,IDM3D_TETRA=410}; |
73 |
|
|
enum femelement {IDFEM_NOEUD=1000,IDFEM_MINISEGMENT2=11102,IDFEM_SEGMENT2=1102,IDFEM_SEGMENT3=1103,IDFEM_TRIANGLE3=1203,IDFEM_TRIANGLE6=1206,IDFEM_QUADRANGLE4=1204,IDFEM_QUADRANGLE8=1208,IDFEM_TETRA4=1304,IDFEM_TETRA10=1310,IDFEM_HEXA8=1308,IDFEM_HEXA20=1320,IDFEM_PENTA6=1356,IDFEM_PENTA15=1365 |
74 |
|
|
}; |
75 |
|
|
|
76 |
|
|
|
77 |
|
|
|
78 |
|
|
}; |
79 |
|
|
|
80 |
|
|
|
81 |
francois |
791 |
class ORIGINE |
82 |
|
|
{ |
83 |
|
|
public: |
84 |
francois |
902 |
enum origine {MAILLEUR_AUTO=1000,TRIANGULATION=1010,IMPOSE=1020,DUPLIQUER=1030,MODIFICATION=1040,OPTIMISE=1050,DEFORME=1060,GMSH=1070,SQUELETTE=1080,TRIANGULATION_ARETE=1090,TRIANGULATION_ARETEORIGINE=1091,DISCONTINUITE=1100,DISCONTINUITE2=1110,SECTION=1120}; |
85 |
francois |
791 |
}; |
86 |
|
|
|
87 |
|
|
|
88 |
francois |
375 |
class ENTITE_SOLUTION |
89 |
|
|
{ |
90 |
|
|
public: |
91 |
francois |
767 |
enum entite_solution {ENTITE_NOEUD=1,ENTITE_ELEMENT1, ENTITE_ELEMENT2,ENTITE_ELEMENT3,ENTITE_ELEMENT1_NOEUD,ENTITE_ELEMENT2_NOEUD, ENTITE_ELEMENT3_NOEUD,ENTITE_ELEMENT1_GAUSS,ENTITE_ELEMENT2_GAUSS, ENTITE_ELEMENT3_GAUSS,ENTITE_ELEMENTND, ENTITE_ELEMENTND_NOEUD}; |
92 |
francois |
375 |
|
93 |
|
|
}; |
94 |
francois |
283 |
|
95 |
francois |
375 |
class TYPE_SOLUTION |
96 |
|
|
{ |
97 |
|
|
public: |
98 |
|
|
enum type_solution {SCALAIRE=1,VECTEUR=3, TENSEUR_SYM=6 ,TENSEUR=9}; |
99 |
|
|
|
100 |
|
|
}; |
101 |
francois |
551 |
|
102 |
francois |
1149 |
|
103 |
|
|
|
104 |
|
|
|
105 |
|
|
|
106 |
|
|
class MAILLEURFRONTALETAT |
107 |
|
|
{ |
108 |
|
|
public: |
109 |
francois |
1150 |
|
110 |
|
|
|
111 |
|
|
enum m2detat {CAS_FRONT_3=1,CAS_FRONT_4=2,CAS_FERME_CAVITE_P=3,CAS_FERME_CAVITE_S=4,CAS_FERME_CAVITE=5,CAS_GENERAL=6,PASTROUVE=10,TROUVE=11,TOUS_SEGMENT=20,TOUS_FRONT=21,RIEN=22,NOEUD_CREE=30,FRONT_RENCONTRE=31,ERREUR=32}; |
112 |
|
|
|
113 |
|
|
|
114 |
|
|
enum m3detat {DETRUIT=345,ACTIF=346,INACTIF=347,FRONT_NONACTIF=507,FRONT_ACTIF=508,FRONT_PASSE=509,FRONT_A_INVERSE=510,FRONT_PAS_A_INVERSE=511}; |
115 |
|
|
|
116 |
|
|
enum m3dcas {ADJACENT3=0,ADJACENT2=1,ADJACENT1=2,LIE3=3,LIE2=4,LIE1=5,GENERAL=6,AUTRECAS=7,ADJACENT=8,LIE=9,DESTRUCTION=-15,PASTRAITE=-20,TRAITE=-15,AUTRECASATRAITER=-25}; |
117 |
|
|
|
118 |
|
|
|
119 |
|
|
enum m3dprogression {NONFORCE=159,ATTENTE=160,PRIORITAIRE=160,GENERATION_NOEUD=505,NOEUD_EXISTANT=506,FACE_EXISTANTE=506,EXISTE=700,MULTIEXISTE=701,CREATION=702,FRONTAL=1000,OCTAL=1001,TOUTDETRUIRE=2000,LIMITEDETRUIRE=2001}; |
120 |
|
|
|
121 |
francois |
1149 |
}; |
122 |
|
|
|
123 |
|
|
|
124 |
francois |
551 |
class VERSION_CARTE_TAILLE |
125 |
|
|
{ |
126 |
|
|
public: |
127 |
|
|
enum version_carte_taille {ANCIENNE=0,NOUVELLE=1}; |
128 |
francois |
581 |
}; |
129 |
|
|
|
130 |
francois |
876 |
class OPERATION_FEM_SOLUTION |
131 |
|
|
{ |
132 |
|
|
public: |
133 |
francois |
902 |
enum operateur {ADDITION=0,SOUSTRACTION=1,MULTIPLICATION=2,DIVISION=3,VALEUR_ABSOLUE=50,COMPARAISON=51,COMPARAISON_RELATIVE=52,GRAD=53,EXTRAPOLATION=54,NORMESUP=55}; |
134 |
francois |
876 |
}; |
135 |
francois |
581 |
|
136 |
|
|
class CALCUL_ASTER |
137 |
|
|
{ |
138 |
|
|
public: |
139 |
couturad |
719 |
enum typecalcul {ELASTIQUE=0, |
140 |
francois |
721 |
PLASTIQUE=1, |
141 |
couturad |
719 |
OPTIMISATIONTOPOLOGIQUE=2, |
142 |
|
|
THERMIQUE=3, |
143 |
|
|
CONTRAINTE_PLANE=4, |
144 |
|
|
DEFORMATION_PLANE=5, |
145 |
francois |
786 |
RIGIDITE=6, |
146 |
|
|
RIGIDITE_CONTRAINTE_PLANE=7, |
147 |
|
|
RIGIDITE_DEFORMATION_PLANE=8, |
148 |
couturad |
719 |
ELASTIQUE_3D=100, |
149 |
|
|
ELASTIQUE_PLAQUE=101, |
150 |
|
|
ELASTIQUE_COQUE=102, |
151 |
|
|
THERMIQUE_3D=200, |
152 |
|
|
ELASTIQUE_GROT_GDEF=103, |
153 |
francois |
721 |
PLASTIQUE_BILINEAIRE=104, |
154 |
sattarpa |
849 |
PLASTIQUE_BILINEAIRE_PLAQUE=1044, |
155 |
|
|
PLASTIQUE_BILINEAIRE_COQUE=1045, |
156 |
francois |
767 |
PLASTIQUE_COURBE=105, |
157 |
francois |
786 |
ELASTIQUE_MIXTE_1D3D=106, |
158 |
|
|
RIGIDITE_3D=107, |
159 |
|
|
RIGIDITE_PLAQUE=108, |
160 |
|
|
RIGIDITE_COQUE=109, |
161 |
francois |
787 |
RIGIDITE_MIXTE_1D3D=110, |
162 |
|
|
ELASTIQUE_GROT_GDEF_3D=111, |
163 |
|
|
ELASTIQUE_GROT_GDEF_PLAQUE=112, |
164 |
mejri |
888 |
ELASTIQUE_GROT_GDEF_COQUE=113, |
165 |
mejri |
932 |
ELASTIQUE_NON_LINEAIRE_3D=114, |
166 |
|
|
ELASTIQUE_NON_LINEAIRE_3D_FATIGUE=115 |
167 |
francois |
721 |
}; |
168 |
francois |
375 |
}; |
169 |
francois |
635 |
|
170 |
|
|
|
171 |
|
|
class PROJECTION |
172 |
|
|
{ |
173 |
|
|
public: |
174 |
|
|
enum RESULTAT {SUCCES=0,TYPE_SOLUTION_INCORRECT=1,DIMENSION_MAILLAGE_INCOMPATIBLE=2,NON_IMPLEMENTER=3}; |
175 |
|
|
}; |
176 |
francois |
686 |
|
177 |
|
|
|
178 |
|
|
|
179 |
|
|
class SEMANTIQUECSG |
180 |
|
|
{ |
181 |
|
|
public: |
182 |
couturad |
951 |
enum semantiquecsg {SANS=100,UNION,SOUSTRACTION,INTERSECTION,FRAGMENT,ROTATION,ECHELLE,PERCAGE,CONGE,CHAMFREIN,EXTRUSION,DECALLAGE,ERREUR=1000}; |
183 |
francois |
551 |
}; |
184 |
francois |
686 |
|
185 |
|
|
|
186 |
|
|
}; |
187 |
francois |
283 |
#endif |
188 |
|
|
|
189 |
|
|
|