ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/REPOS_ERICCA/magic/app/aide/aide.h
Revision: 1171
Committed: Wed Jul 31 15:43:57 2024 UTC (12 months, 4 weeks ago) by francois
Content type: text/plain
File size: 40721 byte(s)
Log Message:
correction de quelques bug de compilation + misea jour aide + gestion automatique des numéros de version

File Contents

# Content
1 //####//------------------------------------------------------------
2 //####//------------------------------------------------------------
3 //####// MAGiC
4 //####// Jean Christophe Cuilliere et Vincent FRANCOIS
5 //####// Departement de Genie Mecanique - UQTR
6 //####//------------------------------------------------------------
7 //####// MAGIC est un projet de recherche de l equipe ERICCA
8 //####// du departement de genie mecanique de l Universite du Quebec a Trois Rivieres
9 //####// http://www.uqtr.ca/ericca
10 //####// http://www.uqtr.ca/
11 //####//------------------------------------------------------------
12 //####//------------------------------------------------------------
13 //####//
14 //####// aide.h
15 //####//
16 //####//------------------------------------------------------------
17 //####//------------------------------------------------------------
18 //####// COPYRIGHT 2000-2024
19 //####// Derniere modification par francois
20 //####// mer 24 jui 2024 18:48:56 EDT
21 //####//------------------------------------------------------------
22 //####//------------------------------------------------------------
23 /*! \page Aide Info MAGiC
24 Informations diverses
25
26 - \subpage infodiv
27
28 Configuration de MAGiC
29
30 - \subpage Configuration
31
32
33 Description du format du fichier script MAGiC\n
34 - \subpage Script
35
36 Description de la procédure de reconstruction d'un modèle structurel après optimisation topologique\n
37 - \subpage Reconstruction
38
39 Faire une étude SiDolo
40
41 - \subpage SiDolo
42
43 Microstucture de matériaux hétérogénes
44
45 - \subpage microstructre
46
47 \image html testmagic150.png
48 */
49
50 /*! \mainpage
51
52 <H1><B><center>Bienvenue sur le site de documentation du laboratoire <A HREF=http://www.uqtr.ca/ericca>ERICCA</A> de l'<A HREF=http://www.uqtr.ca/>UQTR</a></center></B></H1>
53 <table border="0">
54 <tr>
55 <td>
56 \image html viewvc-logo.png <br>
57 <a HREF=http://ericca.uqtr.ca/cgi-bin/viewvc.cgi/REPOS_ERICCA/>Vue de la derniere version</a><br>
58 \image html testmagic150.png <br>
59 <a HREF=http://ericca.uqtr.ca/webmagic/index_text.html>État de la derniere version</a>
60
61
62 </td>
63 <td>
64 <div style="text-align:center">
65 \image html magicexemple.jpg width=800px
66 </div>
67 </td>
68 </tr>
69 </table>
70 */
71
72
73 /*! \page infodiv Informations diverses sur le projet MAGiC
74 Le projet MAGiC est un projet des professeurs Jean-Christophe Cuillière et Vincent Francois de l'Équipe de Recherche en Intégration CAO-CAlcul du département de génie mécanique de l'UQTR.\n\n
75 Cette page résume les différents liens pour les outils disponibles : \n\n
76 <ul>
77 <li><a href="http://ericca.uqtr.ca/cgi-bin/viewvc.cgi"> Web SVN </a></li>
78 <li><a href="http://ericca.uqtr.ca/biblio"> Biblio ERICCA </a></li>
79 <li><a href="http://ericca.uqtr.ca/cas_test"> Cas test d'optimisation de topologie </a></li>
80 <li><a href="http://ericca.uqtr.ca/webmagic/index_text.html"> Tests journaliers du code </a></li>
81
82 <li>Documentation de Code ASTER</li>
83 <ul>
84 <li><a href="http://ericca.uqtr.ca/fr11.7"> 11.7 </a></li>
85 <li><a href="http://ericca.uqtr.ca/fr12.4"> 12.4 </a></li>
86 <li><a href="http://ericca.uqtr.ca/fr13.6"> 13.6 </a></li>
87 <li><a href="http://ericca.uqtr.ca/fr14.4"> 14.4 </a></li>
88 <li><a href="http://ericca.uqtr.ca/fr14.6"> 14.6 </a></li>
89 <li><a href="https://code-aster.org/doc/v15/fr/index.php"> 15.6 </a></li>
90 </ul>
91 <li>Modification dans Code ASTER</li>
92 <ul>
93 <li>\subpage ExtraireK </a></li>
94 <li>\subpage CalcParal </a></li>
95 </ul>
96
97 <li>Script d'installation de l'environnement ERICCA : Downloader les fichiers suivants ./instal_magic.bash [tout]. L'option installe les outils de développements. Il faut s'assurer que les scripts soient exécutables. Ensuite il faut faire ./instal_asterv15plus.bash numversion. Ensuite si necessaire ./instal_chrono.bash</li>
98 <ul>
99 <li><a href="http://ericca.uqtr.ca/linux/instal_magic.bash"> Script d'installation de MAGiC </a></li>
100 <li><a href="http://ericca.uqtr.ca/linux/instal_aster.bash"> Script d'installation de code ASTER (version&lt;15)</a></li>
101 <li><a href="http://ericca.uqtr.ca/linux/instal_asterv15plus.bash"> Script d'installation de code ASTER (version&ge;15)</a></li>
102 <li><a href="http://ericca.uqtr.ca/linux/instal_chrono.bash"> Script d'installation de Project Chrono</a></li>
103 </ul>
104 <li>Script d'environnement de MAGIC</li>
105 <ul>
106 <li><a href="http://ericca.uqtr.ca/linux/bash.bashrc"> Fichier a concatener avec le fichier /etc/bash.bashrc </a></li>
107 <li><a href="http://ericca.uqtr.ca/linux/home.bashrc"> Fichier a concatener avec le fichier .bashrc dans chaque home</a></li>
108 </ul>
109
110 </ul>
111 */
112
113
114 /*! \page ExtraireK Extraire matrice de raideur
115 Pour extraire le matrice de rigidité lors d'un calcul de Code Aster dans un fichier en format MATLAB, Il faut utiliser une routine Fortran pour cela (matimp.f) que l'on vient appeler au bon endroit (par exemple dans "op0012.F90"). \n
116 Pour la version 12.4 de Code Aster, il faut faire la modification suivant dans "op0012.F90". On le trouve dans le paquet d'installation de Code Aster à cet endroit: "aster-full-src-12.4.0/SRC/aster-12.4.0/bibfor/op/op0012.F90". \n
117 On édite "op0012.F90" on ajoutant "call matimp(matas,29,'MATLAB')" à la lieu montrée. \n
118
119 \verbatim
120 ! -- SI MATAS N'EST PAS MPI_COMPLET, ON LA COMPLETE :
121 call dismoi('MPI_COMPLET', matas, 'MATR_ASSE', repk=kmpic)
122 ASSERT((kmpic.eq.'OUI').or.(kmpic.eq.'NON'))
123 if (kmpic .eq. 'NON') call sdmpic('MATR_ASSE', matas)
124 !
125 !
126 !
127 call matimp(matas,29,'MATLAB') << On appel matimp ICI <<
128 !
129 ! -- MENAGE :
130 call jedetr(lchci)
131 call jedetr(lmatel)
132 !
133 call jedema()
134 end subroutine
135 \endverbatim \n
136 Et puis, on compile Code ASTER: sudo python setup.py install\n
137 Pour etre capable de sauvegarder le matrice de rigidité dans le fichier MATLAB, il faut editer le fichier .export de Code ASTER comme montré ci dessous: \n
138 \verbatim
139 F comm /home/..../filename.comm D 1
140 F mail /home/..../filename.mail D 20
141 F mess /home/..../filename.mess R 6
142 F m /home/..../filename.m R 29 << On ajoute cette ligne ICI <<
143 \endverbatim \n
144 */
145
146
147 /*! \page CalcParal Calcul parallèle dans Code ASTER
148 Référence: <a href="https://sites.google.com/site/codeastersalomemeca/home/code_asterno-heiretuka/parallel-code_aster-12-4-english"> Parallel Code_Aster 12.4 </a>\n\n
149 <B>Version</B>\n
150 OS:Ubuntu 14.04 \n
151 Code_Aster : ver.12.4\n
152 -----------------------------------------------------------\n\n
153 <B>Telecharger des fichiers</B>\n
154 Les fichier sont enregistrés dans: ~/Install_Files\n
155 Ils sont installé dans : /opt and /opt/aster\n\n
156 Télécharger les fichier suivant:\n
157 aster-full-src-12.4.0-1.noarch.tar.gz (Code_Aster)\n
158 OpenBLAS-0.2.15.tar.gz (OpenBLAS)\n
159 scalapack_installer.tgz (ScaLAPACK)\n
160 petsc-3.4.5.tar.gz (PETSc)\n\n
161 Modifier le propriétaire d'installation par: $ sudo chown username /opt/\n
162 Installez les bibliothèques pour Code_Aster par: \n
163 $ sudo apt-get install gfortran g++ python-dev python-qt4 python-numpy liblapack-dev libblas-dev tcl tk zlib1g-dev bison flex checkinstall openmpi-bin libopenmpi-dev libx11-dev cmake qt4-dev-tools libmotif-dev \n
164 -----------------------------------------------------------\n\n
165 <B>Compiler OpenBLAS (Math LIbrary pour Code_Aster)</B>\n
166 $ cd ~/Install_Files/\n
167 $ tar xfvz OpenBLAS-0.2.15..tar.gz\n
168 $ cd OpenBLAS-0.2.15\n
169 $ make NO_AFFINITY=1 USE_OPENMP=1\n
170 $ make PREFIX=/opt/OpenBLAS install\n
171 $ echo /opt/OpenBLAS/lib | sudo tee -a /etc/ld.so.conf.d/openblas.conf\n
172 $ sudo ldconfig\n
173 -----------------------------------------------------------\n\n
174 <B>Compiler Code_Aster (séquentiel) avec OpenBLAS.</B>\n
175 $ cd ~/Install_Files\n
176 $ tar xfvz aster-full-src-12.4.0-1.noarch.tar.gz\n
177 $ cd aster-full-src-12.4.0/\n
178 $ sed -i "s:PREFER_COMPILER\ =\ 'GNU':PREFER_COMPILER\ =\'GNU_without_MATH'\nMATHLIB=\ '/opt/OpenBLAS/lib/libopenblas.a':g" setup.cfg\n
179 $ python setup.py install\n
180 <EM>Faire host-file pour calcul parallèle par:</EM>\n
181 $ echo "$HOSTNAME cpu=$(cat /proc/cpuinfo | grep processor | wc -l)" > /opt/aster/etc/codeaster/mpi_hostfile\n
182 -----------------------------------------------------------\n\n
183 <B>Compiler ScaLAPACK</B>\n
184 $ cd ~/Install_Files\n
185 $ tar xfvz scalapack_installer.tgz\n
186 $ cd scalapack_installer_1.0.2\n
187 $ ./setup.py --lapacklib=/opt/OpenBLAS/lib/libopenblas.a --mpicc=mpicc --mpif90=mpif90 --mpiincdir=/usr/lib/openmpi/include --ldflags_c=-fopenmp --ldflags_fc=-fopenmp --prefix=/opt/scalapack\n
188 <EM>Une message d'erreur "BLACS: error running BLACS test routines xCbtest" apparaîtra après la compilation, mais vous réussissez, s'il existe le fichier dans "/opt/scalapack/lib/libscalapack.a"</EM> \n
189 -----------------------------------------------------------\n\n
190 <B>Compiler MUMPS</B>\n
191 Copier mumps-4.10.0 dans fichiers source de Code_Aster dans '/opt.\n
192 Compiler par mpi-compiler\n
193 $ cp ~/Install_Files/aster-full-src-12.4.0/SRC/mumps-4.10.0-aster3.tar.gz /opt/\n
194 $ cd /opt\n
195 $ tar xfvz mumps-4.10.0-aster3.tar.gz\n
196 $ mv mumps-4.10.0 mumps-4.10.0_mpi\n
197 $ cd mumps-4.10.0_mpi/\n
198 Changer 'Makefile.inc.in' pour MUMPS4.10.0 Makefile.inc\n
199 $ make all \n
200 -----------------------------------------------------------\n\n
201 <B>Compiler PETSc avec HYPRE et ML</B>\n
202 $ cp ~/Install_Files/petsc-3.4.5.tar.gz /opt\n
203 $ cd /opt\n
204 $ tar xfvz petsc-3.4.5.tar.gz\n
205 $ cd petsc-3.4.5\n
206 $ ./config/configure.py --with-mpi-dir=/usr/lib/openmpi --with-blas-lapack-lib=/opt/OpenBLAS/lib/libopenblas.a --download-hypre=yes --download-ml=yes --with-debugging=0 COPTFLAGS=-O1 CXXOPTFLAGS=-O1 FOPTFLAGS=-O1 --configModules=PETSc.Configure --optionsModule=PETSc.compilerOptions --with-x=0 --with-shared-libraries=0 \n
207 $ make PETSC_DIR=/opt/petsc-3.4.5 PETSC_ARCH=arch-linux2-c-opt all\n
208 $ make PETSC_DIR=/opt/petsc-3.4.5 PETSC_ARCH=arch-linux2-c-opt test\n
209 -----------------------------------------------------------\n\n
210 <B>Compiler Code_Aster (parallèle)</B>\n
211 <EM>Changer un partie de 'mpi_get_procid_cmd' de '/opt/aster/etc/codeaster/asrun' par:\n
212 mpi_get_procid_cmd : echo $OMPI_COMM_WORLD_RANK\n
213 <EM>Changer 32 a 64 pour les processeur 64 bit: </B>\n
214 batch_mpi_nbpmax : 32 (ou 64)\n
215 interactif_mpi_nbpmax : 32 (ou 64)\n
216 <EM>Décompresser Code_Aster</B>\n
217 $ cd ~/Install_Files\n
218 $ cd aster-full-src-12.4.0/SRC\n
219 $ tar xfvz aster-12.4.0.tgz\n
220 $ cd aster-12.4.0\n
221 <EM>Mettre les fichiers de configuration pour calcul parallèle: <a href="https://sites.google.com/site/codeastersalomemeca/home/code_asterno-heiretuka/code_asterno-heiretuka-12-4/Ubuntu_gnu_mpi.py?attredirects=0&d=1"> Ubuntu_gnu_mpi.py </a> et <a href="https://sites.google.com/site/codeastersalomemeca/home/code_asterno-heiretuka/code_asterno-heiretuka-12-4/Ubuntu_gnu.py?attredirects=0&d=1"> Ubuntu_gnu.py </a> dans cette dossier et compiler Code_Aster.</B>\n
222 $ export ASTER_ROOT=/opt/aster\n
223 $ ./waf configure --use-config-dir=$ASTER_ROOT/12.4/share/aster --use-config=Ubuntu_gnu_mpi --prefix=$ASTER_ROOT/PAR12.4\n
224 $ ./waf install -p\n
225 <EM>Ajouter 'vers : PAR12.4:/opt/aster/PAR12.4/share/aster' en dessous de 'vers : testing' in '/opt/aster/etc/codeaster/aster' et puis 'PAR12.4' est enregistré dans ASTK.</B>\n
226
227 */
228
229
230
231 /*! \page Script Description du contenu du fichier script
232 Un fichier script est composé de commandes exécutées en séquences depuis le début du fichier jusqu'à la fin.\n
233 Toute ligne commence par une variable suivie d'un espace suivi d'un signe egal suivi d'un espace et suivi de la commande et de ses arguments.\n
234 Si le premier caractère de la ligne est le caractère # alors la ligne est ignorée.\n\n
235 Les commandes disponibles dans le script MAGiC:
236 - \subpage ajoutass
237 - \subpage brepassemblage
238 - \subpage creemodele
239 - \subpage creeassemblage
240 - \subpage diff
241 - \subpage enregistrer
242 - \subpage export_mg_gmsh
243 - \subpage export_fem_gmsh
244 - \subpage fichier
245 - \subpage importstepocc
246 - \subpage inter
247 - \subpage p_cylindre
248 - \subpage p_cone
249 - \subpage p_boite
250 - \subpage p_sphere
251 - \subpage p_ellipsoide
252 - \subpage p_tore
253 - \subpage union
254 - \subpage fragment
255 - \subpage tristlmodele
256 - \subpage tristlassemblage
257 */
258
259
260 /*! \page Configuration Configuration de MAGiC
261 Dans chaque compte utilisateur ou MAGiC est utilisé un fichier .magic dans le home directory permet de regler quelques parametres de l'application :\n\n
262 Version_gmsh = 2.0000 //Version de gmsh utilisée\n
263 Affiche_Code_Aster = 0.000000 //0. Affichage redirigé vers le fichier aster.log 1 affichage dans un terminal\n
264 Container_singularity_aster = ~/containers/salome_meca-lgpl-2022.1.0-1-20221225-scibian-9.sif //Proprietes aster : Fichier du container code-aster (version >15)\n
265 Convergence_mailleur3d_frontal = 200.000000 //Nombre de front restant à partir duquel la destruction est obligatoire\n
266 Echantillon_face = 20.000000 //Nombre d'échantillon pour le calcul de la boite englobante des faces\n
267 Epsilon_face = 1.000000 //Distance entre la triangulation et la face pour les algos qui echantillonnent les faces (en mm)\n
268 Angle_dev_face = 0.500000 //Angle entre deux elements de la triangulation pour les algos qui echantillonnent les faces\n
269 Verification_coin_face_mailleur2D = 0.000000 //0. Ne fais pas la vérification 1. Fait la vérification qu'un sommet de face partage au moins deux triangles\n
270 Optimisation_2D = 1 //Nombre de bits = nombre de passe d'optimisation. Pour chaque bit 1=bouge de noeud 2=inverse diagonale 3=bouge de noeud inserse diagonale simultane 4=inverse diagonale bouge de noeud simulatane\n
271 Quadratisation_jmin = 1.000000 //Garantir des tetras quadratiques avec jaconien minimum positif : 1=oui 2=non\n
272 Quadratisation_pas = 100.000000 //Nombre de pas pour recaler les noeuds et obtenir un jmin positif\n
273 Quadratisation_dis = 0.100000 //Valeur de la distortion du jacobien minimale à atteindre\n
274 Quadratisation_nbpassemax = 4.000000 //Nombre de passe maximale pour obtenir un jmin positif\n
275 Nb_iteration_max_mailleur2d = 1000000.000000 //Nombre d'iteration maximale pour le mailleur 2D\n
276 Nb_front_max_mailleur3d = 10000000.000000 //Nombre de front maximale pour le mailleur 3D\n
277 Separateur_decimale = , //Seprateur décimale pour l'exportation des fichiers excel\n
278 */
279
280
281
282 /*! \page Reconstruction Description de la procédure de reconstruction d'un modèle structurel après optimisation topologique
283
284 Description de la reconstruction
285
286 - \subpage Description_reconstruction
287
288 Commandes de la reconstruction version thèse A.Nana
289
290 - \subpage Commande_reconstruction
291
292 Commandes de la reconstruction version thèse A. Amroune
293
294 - \subpage Commande_reconstruction2
295
296 */
297
298 /*! \page Description_reconstruction Description de la reconstruction
299 La squelettisation consiste à extraire le squelette d’un modèle. Le modèle est supposé structurel, c’est-à-dire contenant des éléments de type poutre. Pour utiliser l’algorithme de squelettisation, l’on a besoin de 2 fichiers .magic et 2 fichiers .txt. Il s’agit du fichier résultant de l’optimisation topologique, du fichier obtenu après lissage (partie de non_design exclue), et les 2 fichiers .txt provenant de MatLab et contenant les coordonnées des points du squelette et les connectivités entre les points de la courbe-squelette.
300 L’étape 5 ci-dessus résulte en 6 fichiers qui sont : 3 fichiers de squelette (en .magic) et 3 fichiers de solutions (en .sol) sur le calcul des sections.\n\n\n
301 <B>nomfichier_squelette1.magic</B> est le fichier contenant la courbe-squelette sous forme de ligne. Il est accompagné du fichier Carte_section1.sol qui est le fichier de solution pour la taille des sections en mètre (m).\n\n\n
302 <B>nomfichier_squelette2.magic</B> est le fichier contenant le squelette après transformation des segments de chaque branche de la courbe squelette en poutre droite. Il est lui aussi accompagné du fichier Carte_section2.sol qui est le fichier de solution pour la taille des sections des poutres droites en mètre (m). Ce squelette est connecté au non_design à l’aide des segments.\n\n\n
303 <B>nomfichier_squelette3.magic</B> le fichier final de travail. C’est ce fichier qui est utilisé dans la suite pour les calculs. Ce dernier fichier contient le squelette sous forme de poutres droites, est connecté directement au non_design à l’aide des mini-poutres et contient les conditions aux limites et de chargement. Il est accompagné du fichier Carte_section3.sol qui est le fichier de solution pour la taille des sections en mètre (m).
304 */
305 /*! \page Commande_reconstruction Commandes de la reconstruction A Nana (non fonctionnel aujourd'hui)
306
307 <span style="text-decoration: underline;"><B>Etape 1 :</B> </span> Optimisation topologique\n <i>topo_optis.exe
308 -optimise -design nom_fichier.magic -nondesign nom_fichier_bloc.magic -out nom_fichier_resu.magic -param nom_fichier_param.txt -paramaster aster.txt</i>\n\n
309 Si on a déjà un résultat optimal on peut directement passer à l'étape 2.
310 <BR><BR>
311
312 <span style="text-decoration: underline;"><B>Etape 2 :</B> </span> Lissage du résultat optimal (sans la partie de non_design) \n
313 <i>post_optis.exe -creepeau -in nom_fichier_resu.magic -out nom_fichier_lisse.magic -param paramliss.txt</i>\n\n
314 Dans le fichier paramliss, mettre à 1 le paramètre rmimpose_debut pour supprimer le non_design et donner un nom de fichier pour le résultat de la peau sans non_design avec le paramètre nomfichpeau.
315 <BR><BR>
316
317
318 <span style="text-decoration: underline;"><B>Etape 3</B> </span> : Transformation en .off \n
319 <i>mgoperation.exe -offout -in nom_fichier_lisse_peau.magic</i>\n\n
320 (Utiliser le fichier de la peau qui ne contient pas le non_design)
321 <BR><BR>
322
323
324 <span style="text-decoration: underline;"><B>Etape 4 </B> </span> : Squelettisation sous MatLab\n
325
326 Partie 1 : génération du squelette\n
327 Mettre le fichier .off précédent dans le dossier « data » et aller dans le logiciel MatLab. Choisir le chemin vers le dossier « matlab » qui est dans le même répertoire que « data »\n
328 Ouvrir eg_skeleton_laplacian_rosa.m\n
329 Mettre le nom (sans son extension) du fichier .off obtenu à l’Étape 3 dans eg_skeleton_laplacian_rosa.m à la ligne 16.\n
330 executer eg_skeleton_laplacian_rosa.m\n
331 Des figures (en particulier la figure 4) sont générées.\n\n
332
333 Partie 2 : extraction des données\n
334 Ouvrir maintenant Entxt.m qui est également dans le dossier « matlab »\n
335 Donner les noms de fichier désirés dans Entxt.m aux lignes 4, 5 et 33, 34.\n
336 executer Entxt.m \n
337 2 fichiers, contenant les coordonnées des points et les connectivités, sont générés dans le dossier « matlab » ; ce sont ces fichiers qui sont utilisés par la suite dans MAGiC.\n
338 <BR><BR>
339
340
341 <span style="text-decoration: underline;"><B>Etape 5 :</B> </span> Exportation du squelette dans MAGiC\n
342 <i>skeleton.exe -construire_squelette -in nom_fichier_resu.magic -out nom_fichier -inpoints nom_fichier_points.txt -incorres nom_fichier_corres.txt -infilelisse nom_fichier_lisse.magic –connecte 1 –param_lissage paramliss.txt</i>\n\n
343
344
345 Pour obtenir une liste des paramètres pour d’éventuelles modifications, faire simplement :\n
346 <i>skeleton.exe -construire_squelette </i>\n
347
348 –connecte 1 : permet d’introduire des mini-poutres dans toute la zone (les triangles) de contact entre les tétraèdres optimisés et de non_design\n
349
350 –connecte 0 : permet d’introduire des mini-poutres uniquement au nœud de jonction entre le squelette et le non_design\n\n
351
352 Le résultat à utiliser pour la suite est le nom_fichier_squelette3.magic
353 <BR><BR>
354
355 <span style="text-decoration: underline;"><B>Etape 6 :</B> </span> Lancer le calcul EF \n
356 <i>mgoperation.exe -calculaster -in nom_fichier_squelette3.magic -out nom_fichier_sortie -param aster.txt -elastique</i>\n
357 */
358 /*! \page Commande_reconstruction2 Commandes de la reconstruction A Amroune
359
360 <span style="text-decoration: underline;"><B>Etape 1 :</B> </span> Optimisation topologique\n <i>topo_optis.exe
361 -optimise -design nom_fichier.magic -nondesign nom_fichier_bloc.magic -out nom_fichier_resu.magic -param nom_fichier_param.txt -paramaster aster.txt</i>\n\n
362 Si on a déjà un résultat optimal on peut directement passer à l'étape 2.
363 <BR><BR>
364
365 <span style="text-decoration: underline;"><B>Etape 2 :</B> </span> Lissage du résultat optimal (sans la partie de non_design) \n
366 <i>post_optis.exe -creepeau -in nom_fichier_resu.magic -out nom_fichier_lisse.magic -param paramliss.txt</i>\n\n
367 Dans le fichier paramliss, mettre à 1 le paramètre rmimpose_debut pour supprimer le non_design et donner un nom de fichier pour le résultat de la peau sans non_design avec le paramètre nomfichpeau.
368 <BR><BR>
369
370
371 <span style="text-decoration: underline;"><B>Etape 3</B> </span> : Transformation en .off \n
372 <i>mgoperation.exe -offout -in nom_fichier_lisse_peau.magic</i>\n\n
373 (Utiliser le fichier de la peau qui ne contient pas le non_design)
374 <BR><BR>
375
376
377 <span style="text-decoration: underline;"><B>Etape 4 </B> </span> : Squelettisation à l'aide de <a HREF=http://github.com/taiya/starlab-mcfskel target="_blank"/>starlab</a>\n
378
379 Ouvrir le fichier .off dans starlab et appliquer successiverment les filtres suivant :
380 <ol>
381 <li>Voronoi based MAT</li>
382 <li>MCF Skeletonization</li>
383 <li>SurfaceMesh to Skeleton</li>
384 </ol>
385
386 Enregistrer le squelette en fichier .cg
387 <BR><BR>
388 <span style="text-decoration: underline;"><B>Etape 5 :</B> </span> Reconstruction du modèle BREP\n
389 <i>recons_optis.exe -squelette squelette.cg -nd nd.magic -coefjonc 1.3 -nbsections 4 -nbptsinterp1 12 -nbptsinterp2 6 -angle 120 -peau peau.magic</i>
390 <ul>
391 <li>squelette chaine: Nom du fichier du squelette .cg</li>
392 <li>nd chaine: Fichier magic 3D du non-design</li>
393 <li>peau chaine: Fichier magic de la peau avec design et non-design</li>
394 <li>coefjonc double: Coefficient de distance deffinissant les limites des jonctions</li>
395 <li>nbsections integer: Nombre de sections transversales par branche</li>
396 <li>nbptsinterp1 integer: Nombre de points d'interpolation pour chaque section de branche</li>
397 <li>nbptsinterp2 integer: Nombre de points d'interpolation pour chaque segment de section de jonction</li>
398 <li>angle double: Intervalle angulaire de projection pour les sections intermediaires des jonctions (en degre)</li>
399 </ul>
400
401 */
402 /*! \page SiDolo Utilisation de SiDolo couplé à MAGiC
403 <ul>
404 <li>Avant étude</li>
405 <ul>
406 <li>S'assurer que SiDolo est disponible sur son ordinateur. Si ce n'est pas le cas il est diponible <a href="http://ericca.uqtr.ca/SiDolo"> ici </a>. Mettre à jour le fichier sidolo_user dans le répertoire bin afin de mettre le bon répertoire.</li>
407 </ul>
408 <li>Étape 1</li>
409 <ul>
410 <li>Créer un répertoire pour une étude d'optimisation. Conseil pratique un répetertoire = une étude</li>
411 <li>Entrer dans ce répertoire</li>
412 </ul>
413 <li>Étape 2</li>
414 <ul>
415 <li>Créer un modèle MAGiC.</li>
416 <li>Créer un script qui fait un calcul d'une itération d'optimisation.</li>
417 </ul>
418 <li>Étape 3</li>
419 <ul>
420 <li>Créer l'ensemble des fichiers nécessaire à une étude Sidolo. <a href="http://ericca.uqtr.ca/SiDolo"> Exemple de fichiers </a>.</li>
421 <ul>
422 <li>fichier .dat. Définition des parametre de l'étude </li>
423 <li>fichier sidvar.h. Définition des variables </li>
424 <li>fichier interface.f. Programmation des mises à jour de données entre chaque itération</li>
425 <li>fichier .exp. Fichier de la courbe expérimentale à approcher </li>
426 </ul>
427 <li>Configurer les fichiers en se référant à la documentation SiDolo présente dans le répertoire doc de SiDolo.</li>
428 </ul>
429 <li>Étape 4</li>
430 <ul>
431 <li><span style="color:magenta">source ../ou est SiDolo/bin/sidolo_user </span>. </li>
432 <li><span style="color:magenta">sde nomoptim</span> pour creer l'excutable de l'optimisation. </li>
433 <li><span style="color:magenta">sdi interface</span> pour creer l'executable de l'interface. </li>
434 <li><span style="color:magenta">ln -s "executable de l'interface" "non du fichier de la courbe expérimentale sans l'extension .exp"</span></li>
435 </ul>
436 <li>Étape 5</li>
437 <ul>
438 <li>Lancer l'executable de l'optimisateur</li>
439 </ul>
440 </ul>
441
442 */
443 /*!
444 \page microstructre Microstucture de matériaux hétérogénes
445
446 Matériaux hétérogénes à fibres courtes
447
448 - \subpage fibrescourtes
449
450 Polycristaux
451 - \subpage polycristaux
452
453 */
454 /*!
455 \page fibrescourtes Matériaux hétérogénes à fibres courtes
456 <ul>
457 <li>Création des fichiers paramètres</li>
458 <ul>
459 <li>Créer un répertoire vide par etude et se placer dedans.</li><br>
460 <li>Commande : microstructure.exe -creeparam </li><br>
461 Affiche les différents paramètres généraux:
462 Type de generateur : [0] RSA, [1] DCR
463 Type d'inclusion : [0] Sphere, [1] Cylindre
464 Type de maillage : [0] lineaire, [1] quadratique, [2] lineaire et quadratique
465 Type d'etude : [0] mecanique, [1] thermique, [2] mecanique et thermique
466 Nombre de couche d'erosion (defaut = 0)
467 Epaisseur d'une couche d'erosion (defaut = 0.02)
468 <li>Commande : microstructure.exe -creeparam -type_generateur 0 -type_inclusion 0 -type_maillage 0 -type_etude 0 -nb_couche_erosion 10</li><br>
469 Génère l'arborescence de fichier de paramètres nécessaire pour étudier une microstructure
470 <br><br></ul>
471 <li>Lancement de la simulation</li>
472 <ul>
473 <li>Afin de ne pas préciser tout le temps le repertoire app, il est possible de définir la variable locale suivante : export PATHMAGICEXEAPP=dossier app</li><br>
474 <ul>
475 <li>En séquentiel</li>
476 <ul>
477 <li>Commande : ./generer_nb_ves index_départ index_fin "dossier app"</li>
478 </ul>
479 </ul>
480 <ul>
481 <li>En parralélle</li>
482 <ul>
483 <li> </li>
484 </ul>
485 </ul>
486 </ul>
487 <li>Génération des résultats</li>
488 <ul>
489 <li>Commande : ./post_traitement "dossier app"</li>
490 <li>L'ensemble des résultats sont dans le répertoire resultatsé Si le format de fichier est SVG il est possible de consulter les graphiques dans le répertoire résultat/graph en faisant la commande : eog *.svg</li>
491 <li>Par défault, les graphiques sont générés au format SVG. Il est aussi possible de les obtenir au format pdf en faisant la commande suivante : gnuplot -e "sortie='pdf'" fig.gnu</li>
492 </ul>
493 */
494 /*!
495 \page polycristaux Polycristaux
496 <ul>
497 <li>Création des fichiers paramètres</li>
498 <ul>
499 <li>Créer un répertoire vide par etude et se placer dedans.</li><br>
500 <li>Commande : microstructure.exe -polycristaux -creeparampoly -param cuivre.txt</li><br>
501 Géneration de 5 fichiers. Fixer les paramétres mécaniques dans le fichier cuivre.txt. Fixer les paramétres code_aster dans param_aster.txt
502 <br><br></ul>
503 <li>Lancement de la simulation</li>
504 <ul>
505 <li>En séquentiel</li>
506 <ul>
507 <li>Commande : ./vasy nb_echantillon</li>
508 </ul>
509 </ul>
510 <ul>
511 <li>En parralélle</li>
512 <ul>
513 <li>Commande : parra.exe ./vasy_par nb_cpu nb_echantillon cuivre.txt </li>
514 </ul>
515
516 </ul>
517 </ul>
518 <ul>
519 <li>Génération des graphiques résultats</li>
520 <ul>
521 <li>Commande : microstructure.exe -polycristaux -analysepoly -param cuivre.txt</li><Br>Les fichiers peuvent être visualisés avec le programme eog (eye of gnome). eog *.svg.
522 </ul>
523 </ul>
524
525 */
526
527
528 /*! \page fichier fichier
529 var = fichier nom
530 @brief Mise en mémoire d'un gestionnaire MAGiC
531 @param nom une chaine de caractére.
532 @return var une variable representant le gestionnaire MAGiC
533 @details Si nom = nouveau il y a création d'un nouveau modèle MAGiC\n
534 @details Sinon ouverture du fichier MAGiC donné par nom\n
535 */
536
537
538 /*! \page p_boite p_boite
539 var = p_boite modele x1 y1 z1 x2 y2 z2
540 @brief Création d'une forme primitive volumique de type boîte [MG_CG_FORME_VOLUME_BOITE] entre les points (x1,y1,z1) et (x2,y2,z2)
541 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
542 @param x1 un double.
543 @param y1 un double.
544 @param z1 un double.
545 @param x2 un double.
546 @param y2 un double.
547 @param z2 un double.
548 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
549 */
550
551
552 /*! \page p_sphere p_sphere
553 var = p_sphere modele x1 y1 z1 r
554 @brief Création d'une forme primitive volumique de type sphère [MG_CG_FORME_VOLUME_SPHERE] de centre (x1,y1,z1) et de rayon r
555 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
556 @param x1 un double.
557 @param y1 un double.
558 @param z1 un double.
559 @param r un double.
560 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
561 */
562
563
564 /*! \page p_cylindre p_cylindre
565 var = p_cylindre modele x1 y1 z1 axe_x axe_y axe_z r h
566 @brief Création d'une forme primitive volumique de type cylindre [MG_CG_FORME_VOLUME_CYLINDRE]
567 basée sur le cercle centré en (x1,y1,z1) orienté selon l'axe (axe_x,axe_y,axe_z) de hauteur h et de rayon r
568 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
569 @param x1 un double.
570 @param y1 un double.
571 @param z1 un double.
572 @param axe_x un double.
573 @param axe_y un double.
574 @param axe_z un double.
575 @param r un double.
576 @param h un double.
577 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
578 */
579
580
581 /*! \page p_ellipsoide p_ellipsoide
582 var = p_ellipsoide modele x1 y1 z1 axe_x axe_y axe_z R r
583 @brief Création d'une forme primitive volumique de type ellipsoide [MG_CG_FORME_VOLUME_ELLIPSOIDE]
584 centré en (x1,y1,z1) orienté selon l'axe (axe_x,axe_y,axe_z) de rayon majeur R et de rayon mineur r
585 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
586 @param x1 un double.
587 @param y1 un double.
588 @param z1 un double.
589 @param axe_x un double.
590 @param axe_y un double.
591 @param axe_z un double.
592 @param R un double.
593 @param r un double.
594 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
595 */
596
597
598
599 /*! \page p_tore p_tore
600 var = p_tore modele x1 y1 z1 axe_x axe_y axe_z R r angle1 angle2
601 @brief Création d'une forme primitive volumique de type tore [MG_CG_FORME_VOLUME_TORE] basée sur le cercle centré en (x1,y1,z1) orienté selon l'axe (axe_x,axe_y,axe_z) de grand rayon R et de petit rayon r
602 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
603 @param x1 un double.
604 @param y1 un double.
605 @param z1 un double.
606 @param axe_x un double.
607 @param axe_y un double.
608 @param axe_z un double.
609 @param R un double.
610 @param r un double.
611 @param angle1 un double qui représente la portion de 2PI du tore.
612 @param angle2 un double qui represente le début du tore par rapport à x.
613 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
614 */
615
616
617 /*! \page p_cone p_cone
618 var = p_cone modele x1 y1 z1 axe_x axe_y axe_z h r
619 @brief Création d'une forme primitive volumique de type cone [MG_CG_FORME_VOLUME_CONE] basée sur le cercle centré en (x1,y1,z1) orienté selon l'axe (axe_x,axe_y,axe_z) de hauteur h et de petit rayon r
620 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
621 @param x1 un double.
622 @param y1 un double.
623 @param z1 un double.
624 @param axe_x un double.
625 @param axe_y un double.
626 @param axe_z un double.
627 @param h un double.
628 @param r un double.
629 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
630 */
631
632 /*! \page ajoutass ajoutass
633 var = ajoutass assemblage forme
634 @brief Ajoute une forme [MG_CG_FORME] dans un assemblage [MG_CG_ASSEMBLAGE]
635 @param assemblage une variable représentant un assemblage [MG_CG_ASSEMBLAGE].
636 @param forme une variable représentant forme utile pour la construction géométrique [MG_CG_FORME]
637 @return var une variable inutilisable
638 */
639 /*! \page union union
640 var = union modele forme1 forme2 nom_semantique
641 @brief Création d'une opération booléene d'union [MG_CG_OP_BOOL_UNION] entre deux formes [MG_CG_FORME]
642 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
643 @param forme1 une forme [MG_CG_FORME].
644 @param forme2 une forme [MG_CG_FORME].
645 @param nom_semantique OPTIONNEL nom pour donner un sens physique à l'opération. Les choix sont : chamfrein, conge, intersection, percage, soustraction, union, extrusion
646 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
647 @details Si aucun nom de sémantique n'est donné le qualificatif SANS est attribué
648 */
649
650 /*! \page diff diff
651 var = diff modele forme1 forme2 nom_semantique
652 @brief Création d'une opération booléene de soustraction [MG_CG_OP_BOOL_DIFFERENCE] entre deux formes [MG_CG_FORME]
653 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
654 @param forme1 une forme [MG_CG_FORME].
655 @param forme2 une forme [MG_CG_FORME].
656 @param nom_semantique OPTIONNEL nom pour donner un sens physique à l'opération. Les choix sont : chamfrein, conge, intersection, percage, soustraction, union, extrusion
657 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
658 @details Si aucun nom de sémantique n'est donné le qualificatif SANS est attribué
659 */
660
661 /*! \page inter inter
662 var = inter modele forme1 forme2 nom_semantique
663 @brief Création d'une opération booléene d'intersection [MG_CG_OP_BOOL_INTERSECTION] entre deux formes [MG_CG_FORME]
664 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
665 @param forme1 une forme [MG_CG_FORME].
666 @param forme2 une forme [MG_CG_FORME].
667 @param nom_semantique OPTIONNEL nom pour donner un sens physique à l'opération. Les choix sont : chamfrein, conge, intersection, percage, soustraction, union, extrusion
668 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
669 @details Si aucun nom de sémantique n'est donné le qualificatif SANS est attribué
670 */
671
672 /*! \page fragment fragment
673 var = fragment modele forme1 forme2 nom_semantique
674 @brief Création d'une opération booléene de fragmentation [MG_CG_OP_BOOL_FRAGMENT] entre deux formes [MG_CG_FORME]
675 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
676 @param forme1 une forme [MG_CG_FORME].
677 @param forme2 une forme [MG_CG_FORME].
678 @param nom_semantique OPTIONNEL nom pour donner un sens physique à l'opération. Les choix sont : chamfrein, conge, intersection, percage, soustraction, union, extrusion
679 @return var une variable representant une forme utile pour la construction géométrique [MG_CG_FORME]
680 @details Si aucun nom de sémantique n'est donné le qualificatif SANS est attribué
681 */
682
683
684 /*! \page creemodele creemodele
685 var = creemodele gest nom unite eps fusion triSTL eps_tri
686 @brief Création d'un modele de construction géométrique [MG_CG_MODELE]
687 @param gest une variable représentant un modèle MAGiC [MG_GESTIONNAIRE]
688 @param nom une chaine de caractère.
689 @param unite un double représentant l'unité de mesure utilisé
690 @param eps un double représentant la précision utilisé
691 @param fusion une chaine de caractère. Si la valeur est "fusion" alors les entités similaires seront fusionnés à partir d'un algorithme de balayage.
692 @param triSTL est une chaine de caractère. Si la valeur est "true" alors le modèle sera disposé à importer la triangulation STL.
693 @param eps_tri un double représentant l'écart entre un entité topologique et son maillage STL.
694 @return var une variable representant un modele de construction géométrique [MG_CG_MODELE]
695 */
696
697
698 /*! \page creeassemblage creeassemblage
699 var = creeassemblage modele nom
700 @brief Création d'un assemblage [MG_CG_ASSEMBLAGE] dans un modele de construction géométrique [MG_CG_MODELE]
701 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
702 @param nom une chaine de caractère. Ce nom n'est pas utilisé par la suite
703 @return var une variable representant un assemblage [MG_CG_ASSEMBLAGE]
704 */
705
706 /*! \page enregistrer enregistrer
707 var = enregistrer gest nom
708 @brief Sauvegarde d'un fichier MAGiC
709 @param gest une variable représentant un gestionnaire MAGiC [MG_GESTIONNAIRE]
710 @param nom une string représentant un nom de fichier (L'extension s'ajoute automatiquement au nom du fichier).
711 @return var une variable inutilisable
712 */
713
714 /*! \page brepassemblage brepassemblage
715 var = brepassemblage assemblage nom
716 @brief Conversion d'un assemblage [MG_CG_ASSEMBLAGE] au format brep d'OpenCascade
717 @param gest une variable représentant un gestionnaire MAGiC [MG_GESTIONNAIRE]
718 @param nom une string représentant un nom de fichier brep
719 @return var une variable inutilisable
720 */
721
722
723 /*! \page export_mg_gmsh export_mg_gmsh
724 var = export_mg_gmsh gest nom num
725 @brief Exportation d'un MG_MAILLAGE MAGiC en format GMSH
726 @param gest une variable représentant un gestionnaire MAGiC [MG_GESTIONNAIRE]
727 @param nom une string représentant un nom de fichier gmsh (L'extension s'ajoute automatiquement au nom du fichier).
728 @param num un integer qui représente un numero sequantielle de maillage (entre 1 et n)
729 @return var une variable inutilisable
730 */
731
732 /*! \page export_fem_gmsh export_fem_gmsh
733 var = export_fem_gmsh gest nom num
734 @brief Exportation d'un FEM_MAILLAGE MAGiC en format GMSH
735 @param gest une variable représentant un gestionnaire MAGiC [MG_GESTIONNAIRE]
736 @param nom une string représentant un nom de fichier gmsh (L'extension s'ajoute automatiquement au nom du fichier).
737 @param num un integer qui représente un numero sequantielle de maillage (entre 1 et n)
738 @return var une variable inutilisable
739 */
740 /*! \page importstepocc importstepocc
741 var = importstepocc gest fichier_entree fichier_sortie eps fusion triSTL eps_tri
742 @brief importation d'un fichier STEP en MAGiC via opencascade V2017
743 @param gest une variable représentant un gestionnaire MAGiC [MG_GESTIONNAIRE]
744 @param fichier_entree une string représentant le nom de fichier STEP.
745 @param fichier_sortie une string représentant le nom du fichier MAGiC.
746 @param eps un double représentant la précision utilisé
747 @param fusion une chaine de caractère. Si la valeur est "fusion" alors les entités similaires seront fusionnés à partir d'un algorithme de balayage.
748 @param triSTL est une chaine de caractère. Si la valeur est "true" alors le modèle sera disposé à importer la triangulation STL.
749 @param eps_tri un double représentant l'écart entre un entité topologique et son maillage STL.
750 @return var une variable de type geometrie
751 */
752
753 /*! \page tristlmodele tristlmodele
754 var = tristlmodele modele type
755 @brief Création de la triangulation STL [MG_MAILLAGE] d'un modele de construction géométrique [MG_CG_MODELE]
756 @param modele une variable représentant un modele de conscrution géométrique [MG_CG_MODELE].
757 @param type une string représentant le type de triangulation. Si type = tristl la triangulation ne tiendra pas en compte de la conformité du maillage. Si type = triangulation la conformité du maillage sera assurée.
758 @return var une variable inutilisable
759 */
760
761 /*! \page tristlassemblage tristlassemblage
762 var = tristlassemblage assemblage type
763 @brief Création de la triangulation STL [MG_MAILLAGE] d'un assemblage [MG_CG_ASSEMBLAGE]
764 @param assemblage une variable représentant un assemblage [MG_CG_ASSEMBLAGE].
765 @param type une string représentant le type de triangulation. Si type = tristl la triangulation ne tiendra pas en compte de la conformité du maillage. Si type = triangulation la conformité du maillage sera assurée.
766 @return var une variable inutilisable
767
768 */
769 /*! \page histo Historique du projet MAGiC
770 La librairie MAGiC est l'implémentation pratique du MTU (Modèle de Topologie Unified) de la publication <a href="https://www.tandfonline.com/doi/abs/10.1080/16864360.2014.902677" target="_blank">Integration of CAD, FEA and topology optimization through a unified topological model</a>.
771 <br> Voici l'historique du projet depuis sa naissance en 1999 :
772 <ul>
773 <li>Version 1 : 1999. Début du projet non structuré sur multiplateforme UNIX. BREP interne STEP ou SAT</li>
774 <li>Version 2 : 2000. Transfert du projet sur Windows avec Visualisateur intégré. Visual MAGiC. Compilateur Borland c++ exclusif. BREP SolidWorks</li>
775 <li>Version 3 : 2007. Adapatation vers linux en conservant la version Windows. Abandon de la visualisation personnelle sur linux. BREP opencascade</li>
776 <li>Version 4 : 2008. Linux exclusif. Abandon finale de la visualisation personnelle. Passage en projet uniquement open-source. Projet multi utilisateur géré par SVN. Utilisation de GMSH comme visualisateur.</li>
777 <ul>
778 <li>Version 4.1 : 2010. Encapsulation du code Éléments Finis Code Aster</li> .
779 <br>&emsp;&emsp;Création d'un optimisateur de topologie intégré
780 <li>Version 4.2 : 2011. Multiplication des programmes et création de MAGIC_APPLICATION un lanceur d'application personnel et universel</li> .
781 <br>&emsp;&emsp;Création de visualisateurs simplistes intégrés en VTK pour visualiser des particularités (Conditions aux limites, comparaison de modèle.
782 <li>Version 4.3 : 2018. Utilisation du code Multi-Physique Project-Chrono</li>.
783 <br>&emsp;&emsp;Création d'un calculateur d'homogéinisation de particules fibres courtes orientées aléatoirement
784 </ul>
785
786 </ul>
787
788 */