**********
.. index:: single: reference
-The HOMARD software was subject of publications techniques in the course of conferences these last years. References of main documents are presented here.
-
-Main reference
-==============
For a reference to HOMARD, use:
G. Nicolas and T. Fouquet, Adaptive Mesh Refinement for Conformal Hexahedral Meshes, "*Finite Elements in Analysis and Design*", Vol. 67, pp. 1-12, 2013, doi:10.1016/j.finel.2012.11.008
`Available here <http://dx.doi.org/10.1016/j.finel.2012.11.008>`_
-Splitting meshing
-=================
-
- * G. Nicolas, T. Fouquet, Conformal hexaedral meshes and adaptive mesh refinement, VI International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2013*", J.P. Moitinho de Almeida, P. Diez, C. Tiago and N. Pares (Eds), Lisbonne, pp. 515-526, 2013
- * G. Nicolas, T. Fouquet, Hexaedral mesh adaptation for finite volume methods, III International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2007*", K. Runesson, P. Diez (Eds), Goteborg, pp. 174-177, 2007
- * G. Nicolas, F. Arnoux-Guisse, O. Bonnin, Adaptive meshing for 3D finite element software, IX International Conference on Finite Elements in Fluids, Venise, Italie, 15-21 Octobre 1995.
- * G. Nicolas, F. Arnoux-Guisse, O. Bonnin, Un logiciel d'adaptation de maillage en 2D et 3D, 27ème Congrès d'Analyse Numérique, Super-Besse, France, May 29-June 2, 1995.
-
-Error estimators
-================
-
- * A. Ern, S. Meunier, A posteriori error analysis of Euler-Galerkin approximations to coupled elliptic-parabolic problems", ESAIM: M2AN 43 (2009) 353-375.
- * J. Delmas, Stratégies de controle d'erreur en calcul de structures industrielles., PhD of the Université de Picardie, France, April 2008
- * S. Meunier, Analyse d'erreur a posteriori pour les couplages hydro-mécaniques et mise en oeuvre dans Code_Aster, PhD of the Ecole Nationale des Ponts et Chaussées, France, November 2007.
- * J. Delmas, P. Coorevits, P.-B. Badel and M. Guessasma, An explicit estimator for goal oriented H-Adaptivity with mesh optimaly criteria, III International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2007*", K. Runesson, P. Diez (Eds), Goteborg, pp. 93-96, 2007.
- * P. Destuynder, B. Métivet, Estimation d'erreur explicite dans une méthode d'éléments finis conforme, Compte Rendu Académie des Sciences Paris, tome 323, Série I, p. 679-684, 1996.
- * P. Destuynder, B. Métivet, Estimation d'erreur explicite pour une méthode d'éléments finis non conforme, Compte Rendu Académie des Sciences Paris, tome 322, Série I, p. 1081-1086, 1996.
- * C. Bernardi, O. Bonnin, C. Langouet, B. Métivet, Residual Error Indicators for Linear Problems - Extension to the Navier-Stokes Equations, IX International Conference on Finite Elements in Fluids, Venise, Italie, 15-21 Octobre 1995.
- * F. Arnoux-Guisse, O. Bonnin, L. Léal De Sousa, G. Nicolas, An adaptive finite element method for turbulent flow simulation, ICFD Conference on Numerical Methods for Fluid Dynamics, University of Oxford, Grande-Bretagne, 3-6 Avril 1995.
- * O. Bonnin, B. Métivet, G. Nicolas, F. Arnoux-Guisse, L. Léal de Sousa, Adaptive Meshing for N3S Fluid Mechanics Code, "*Computational Fluid Dynamics '94*", ECCOMAS Stuttgart, Allemagne, pp. 201-208, Wiley 1994.
-
-Applications
-============
-
- * S. Meunier, R. Fernandes, Mesh Adaptation for Coupled Hydro-Mechanical Industrial Studies, V International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2011*", D. Aubry, P. Diez, B. Tie and N. Pares (Eds), Paris, pp. 337-338, 2011
- * O. Hartmann, O. Bonnin, D. Gasser, An Adaptive Meshing for Turbomachinery Geometries, "*Computational Fluid Dynamics '98*", ECCOMAS Athènes, Greece, Wiley 1998.
-
Evolutions of the module
************************
SALOME VERSION 7.2.1 :
- English documentation
-Contact
-*******
-.. index:: single: Contact
-
-Gérald NICOLAS, Software Manager
-
-Address:
-EDF R&D, 1, avenue du Général de Gaulle, 92141 CLAMART Cedex, FRANCE
-
-Phone : (33/0) 1.47.65.56.94
-
-Email : Gerald.Nicolas[at]edf.fr
-
-
-Thierry FOUQUET
-
-Address:
-EDF R&D, 1, avenue du Général de Gaulle, 92141 CLAMART Cedex, FRANCE
-
-Phone : (33/0) 1.47.65.41.45
-
-Email : Thierry.Fouquet[at]edf.fr
-
-
-Really miscellaneous
-********************
-
-HOMARD is an acronym for
- - Outil de
- - Maillage
- - Adaptatif par
- - Raffinement et
- - Déraffinement
-
-which means:
- - Tool for
- - Adaptive
- - Meshing by
- - Refinement and
- - Unrefinement
-
-HOMARD is the french name for lobster.
-Then, our mascot is very nice in `the city of the loabster <http://www.shediac.org.cfm>`_ : |M|
-
-.. |M| image:: ../images/mascotte.gif
- :align: middle
- :alt: Mascot
- :width: 144
- :height: 94
-
.. index:: single: boundary
.. index:: single: frontière
-L'objet frontière contient toutes les définitions géométriques permettant de décrire une frontière courbe à suivre.
+The object boundary contains all the geometrical definitions allowing to describe a curved boundary to be followed.
-Il existe deux modes de description d'une frontière :
+There are two modes of description of a boundary:
- - Discrète : ce mode est utilisé pour décrire une courbe 1D
- - Analytique : ce mode est utilisé pour décrire une surface
+ - Discrete: this mode is used to describe a curve 1D
+ - Analytics: this mode is used to describe a surface
Discrete boundary
*****************
-Le suivi d'une frontière discrète se fera en sélectionnant une frontière choisie dans la liste des frontières discrètes existantes.
+The follow-up of a discrete boundary will be made by selecting a boundary chosen in the list of the existing discrete boundaries.
-Au démarrage, la liste est vide. Il faut créer une première frontière discrète par activation du bouton "*Nouveau*" :
+In the starting up, the list is empty. It is necessary to create a first discrete boundary by activation of the button "*New*" :
.. image:: images/create_boundary_di_1.png
:align: center
-La fenêtre proposée invite au choix d'un fichier de maillage. Ce maillage est celui de toutes les lignes constituant la frontière. Un nom de frontière est proposé automatiquement : Boun_1, Boun_2, etc. Ce nom peut être modifié. Il ne doit pas avoir déjà été utilisé pour une autre frontière.
+The window invites in the choice of a file of mesh. This mesh is the one of all the lines constituting the boundary. A name of boundary is automatically proposed: Boun_1, Boun_2, etc. This name can be modified. It must not already have been used for another boundary.
.. image:: images/create_boundary_di_2.png
:align: center
.. note::
- Le fichier ne doit contenir qu'un seul maillage.
+ The file has to contain only a single mesh.
-Si des frontières discrètes ont déjà été définies pour un autre cas, on peut sélectionner l'une d'elles. On peut également créer une nouvelle frontière discrète par activation du bouton "*Nouveau*", comme expliqué précédemment.
+If discrete boundaries were already defined for another case, we can select one of them. We can also create a new discrete boundary by activation of the button "*New*", as explained previously.
.. image:: images/create_boundary_di_3.png
:align: center
Analytical boundary
*******************
-Au démarrage, SALOME affiche un tableau avec un seule colonne. Cette colonne contient la liste de tous les groupes du maillage initial définissant le cas.
+In the starting up, SALOME shows a table with one only one column. This column contains the list of all the groups of the initial mesh defining the case.
.. image:: images/create_boundary_an_1.png
:align: center
-Il faut créer une première frontière analytique par activation du bouton "*Nouveau*". On aura le choix entre cylindre ou sphère. Une fois que la frontière sera validée, son nom figurera en en-tête d'une deuxième colonne.
+It is necessary to create a first analytical boundary by activation of the button "*New*". We shall have the choice between cylinder, sphere or cone. When the boundary will be validated, its name will appear in header of the second column.
.. image:: images/create_boundary_an_2.png
:align: center
-Il faut maintenant établir le lien entre le maillage définissant le cas et cette frontière décrite analytiquement. Cela se fait en cochant les groupes des faces qui doivent se trouver sur la frontière.
+It is now necessary to establish the link enter the mesh defining the case and this boundary described analytically. It is made by checking the groups of the faces which have to be on the boundary.
.. image:: images/create_boundary_an_3.png
:align: center
-Cette opération est répétée autant de fois que l'on souhaite placer des faces du maillages sur une surface courbe :
+This operation is repeated as often as we wish to place faces of meshs on a curved surface:
.. image:: images/create_boundary_an_4.png
:align: center
.. note::
- Un groupe peut très bien ne jamais être coché : cela signifie que les mailles qu'il définit n'appartiennent à aucune des frontières décrites.
+ A group can be checked very well never: it means that the elements which it defines belong to none of the described boundaries.
- Un groupe ne peut être coché qu'une seule fois. En effet, des mailles surfaciques ne peuvent pas appartenir à plus d'une surface.
+ A group can be checked only once. Indeed, surface elements cannot belong to more than one surface.
- Plusieurs groupes peuvent être cochés pour une même frontière. Cela arrive quand le maillage initial de la zone a été subdivisé en plusieurs groupes : toutes les mailles surfaciques appartiennent à cette surface mais ont été réparties en plusieurs groupes.
+ Several groups can be checked for the same boundary. It occurs if the initial mesh of the zone was subdivided into several groups: all the surface elements belong to this surface but were distributed in several groups.
- Inversement, une frontière peut très bien n'être retenue par aucun groupe. Cela arrive si elle a été définie pour un cas précédent et qu'elle est sans objet pour le cas en cours de définition.
+ Conversely, a boundary can be very well retained by no group. It occurs if it was defined for a previous case and if it is groundless for the case in the course of definition.
-Il existe trois types de frontière analytique :
+There are three types of analytical boundary:
- Cylindre
- - Sphère
- - Cône, décrit par un axe et un angle ou par deux rayons
+ - Sphere
+ - Cone, described by an axis and an angle or by two radius
.. note::
- Les valeurs numériques proposées par défaut tiennent compte de la géométrie du maillage.
+ The numerical values proposed by default take into account the geometry of the mesh.
Cylindre
========
.. index:: single: cylindre
-Le cylindre est défini par un point de l'axe, son axe et son rayon. L'axe est défini par un vecteur. La norme de ce vecteur n'est pas nécessairement égale à 1 ; de même, son orientation n'a aucune importance. Un nom de frontière est proposé automatiquement : Boun_1, Boun_2, etc. Ce nom peut être modifié. Il ne doit pas avoir déjà été utilisé pour une autre frontière.
+The cylinder is defined by a point of the axis, its axis and its radius. The axis is defined by a vector. The standard of this vector is not inevitably equal to 1; also, its orientation has no importance. A name of boundary is automatically proposed: Boun_1, Boun_2, etc. This name can be modified. It must not already have been used for another boundary.
.. image:: images/create_boundary_an_cy.png
:align: center
======
.. index:: single: sphere
-La sphère est définie par son centre et son rayon. Un nom de frontière est proposé automatiquement : Boun_1, Boun_2, etc. Ce nom peut être modifié. Il ne doit pas avoir déjà été utilisé pour une autre frontière.
+The sphere is defined by its center and its radius. A name of boundary is automatically proposed: Boun_1, Boun_2, etc. This name can be modified. It must not already have been used for another boundary.
.. image:: images/create_boundary_an_sp.png
:align: center
====
.. index:: single: cone
-Un cône est défini de deux manières différentes : le centre, l'axe et l'angle d'ouverture en degré ou par deux points centrés sur l'axe et le rayon associé. Un nom de frontière est proposé automatiquement : Boun_1, Boun_2, etc. Ce nom peut être modifié. Il ne doit pas avoir déjà été utilisé pour une autre frontière.
+A cone is defined by two different manners: the center, the axis and the angle of opening in degree or by two points centered on the axis and the associated radius. A name of boundary is automatically proposed: Boun_1, Boun_2, etc. This name can be modified. It must not already have been used for another boundary.
-Création par une origine, un axe et un angle d'ouverture :
+Creation by an origin, an axis and an angle of opening:
.. image:: images/create_boundary_an_co_1.png
:align: center
-Création par deux points centrés sur l'axe et le rayon associé :
+Creation by two points centered on the axis and the associated radius:
.. image:: images/create_boundary_an_co_2.png
:align: center
Object browser
**************
-A l'issue de cette création de frontières, l'arbre d'études a été enrichi. On y trouve toutes les frontières créées, identifiées par leur nom, avec la possibilité de les éditer.
+At the end of this creation of boundaries, the object browser was enriched. We find all the boundaries created, identified there by their name, with the possibility of editing them.
.. image:: images/create_boundary_1.png
:align: center
##############
.. index:: single: hypothesis
-L'hypothesis contient toutes les paramètres de pilotage d'une adaptation d'un maillage. Cette opération permet de réaliser l'itération à laquelle elle est attachée.
+The hypothesis contains all parameters of driving of a mesh adaptation. This operation allows to realize the iteration to which it is attached.
-Il existe trois classes d'hypotheses :
+There are three classes of hypotheses:
- - Uniforme sur tout le maillage,
- - Selon un champ,
- - En fonction de zone géométrique.
+ - Uniform over the whole mesh,
+ - According to a field,
+ - According to geometrical zone.
.. image:: images/create_hypothese_1.png
:align: center
Name of the hypothesis
**********************
-Un nom de l'hypothesis est proposé automatiquement : Hypo_1, Hypo_2, etc. Ce nom peut être modifié. Il ne doit pas asee été utilisé pour une hypothesis précédente.
+A name of the hypothesis is automatically proposed: Hypo_1, Hypo_2, etc. This name can be modified. It must not have been used for a previous hypothesis.
Uniform adaptation
******************
-Par défaut on propose un raffinement uniforme. Quand on part d'un maillage qui a déjà été raffiné, l'option de déraffinement supprimera les mailles produites.
+By default we propose a uniform refinement. When the starting point is a mesh which was already refined, the option of unefinement will eliminate the produced elements.
Adaptation by a field
*********************
.. note::
- Pour pousee adapter le maillage selon un champ il faut asee au préalable désigné le fichier med contenant le champ. Cela se fait dans la fenêtre de construction de l'itération (see :ref:`gui_create_iteration`). Le nom du fichier qui a été sélectionné est affiché sans modification possible ici :
+ To be able to adapt the mesh according to a field it is beforehand necessary to have indicated the file med containing the field. It is made in the window of construction of the iteration (see :ref:`gui_create_iteration`). The name of the file which was selected is shown without possible modification here:
.. image:: images/create_hypothese_ch_1.png
:align: center
-Le champ voulu est à choisir dans la liste des champs contenus dans le fichier.
-Une fois ce champ choisi, la liste des ses composantes s'affiche. Il suffit de désigner la (ou les) composantes désirées.
+The deliberate field is to be chosen in the list of fields contained in the file.
+Once this field was chosen, the list of its components is displayed. It is enough to indicate the wished component(s).
-Si l'on choisit une seule composante, par défaut, c'est sa valeur absolue qui sera utilisée, mais il est possible d'utiliser la valeur relative. Dans le cas de plusieurs composantes, par défaut HOMARD utilisera la norme L2 (euclidienne). On peut toutefois choisir d'utiliser la norme infinie (le max des valeurs absolues des composantes).
+If we choose a single component, by default, it is the absolute value which will be used, but it is possible to use the relative value. In the case of several components, by default HOMARD will use the L2 norm (Euclidian). We can however choose the infinite norm (the max of the absolute values of the components).
-On peut choisir de ne pas utiliser directement le champ, mais sa variation d'un élément à ses voisins. Pour cela, on activera le bouton "*Saut entre éléments*".
+We can choose not to use directly the field, but its variation from an element to its neighbors. For that purpose, we shall check the button "*Jump between elements*".
.. image:: images/create_hypothese_ch_2.png
:align: center
+The refinement is made according to a threshold which defines a high criterion of refinement. All the elements for which the indicator is upper to this criterion will be refined.
+For the choice of the criterion, four variants are possible:
-Le raffinement se fait selon un seuil qui définit un critère haut de raffinement. Toutes les mailles pour lesquelles l'indicateur est supérieur à ce critère seront raffinées.
-Pour le choix du critère, quatre variantes sont possible :
+ - According to a percentage of elements to be refined, real number included between 0 and 100; HOMARD will refine x% of the elements which have the biggest value of the field.
+ - According to a relative value of the field, the number included between 0 and 100; HOMARD will refine the elements where the field is upper in x% of the interval [mini, maxi].
+ - Beyond an absolute value; all the elements with a value of field superior to this value will be refined.
+ - Beyond an absolute value that is equal to the average of the mean of the field increased of n times its standard deviation; all the elements with a value of field superior to this value will be refined.
- - selon un pourcentage de mailles à raffiner, nombre réel compris entre 0 et 100 ; HOMARD raffinera les x% des mailles qui ont la plus grande valeur du champ.
- - selon une valeur relative du champ, nombre compris entre 0 et 100 ; HOMARD raffinera les mailles où le champ est supérieur à x% de l'intervalle [mini,maxi].
- - au dela d'une valeur absolue ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
- - au dela d'une valeur absolue valant la moyenne de la répartition du champ augmentée de n fois son écart-type ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
-
-La même convention s'applique au déraffinement, en remplaçant supérieur par inférieur. On peut inactiver une des fonctions (raffinement ou déraffinement) en cochant le bouton ad_hoc.
+The same convention applies to the unefinement, the by replacing upper by lower. We can inactivate one of the functions (refinement or unefinement) by checking the button ad_hoc.
.. image:: images/create_hypothese_ch_3.png
:align: center
********************
.. index:: single: zone
-Au démarrage, il faut créer une première zone par activation du bouton "*Nouveau*" (see :ref:`gui_create_zone`) :
+In the starting up, it is necessary to create a first zone by activation of the button "*New*" (see :ref:`gui_create_zone`) :
.. image:: images/create_hypothese_zo_1.png
:align: center
-Lorsque des zones ont déjà été créées, la liste apparaît dans la fenêtre, ce qui permet de sélectionner les zones voulues. On doit alors préciser si une zone est utilisée pour raffiner toutes les mailles dont une arête est contenue dans la zone, ou si la zone est utilisée pour déraffiner les mailles intérieures à la zone. Si aucun choix n'est fait, la zone est ignorée dans cette hypothesis.
+When zones were already created, the list appears in the window, what allows to select the deliberate zones. We then have to specify if a zone is used to refine all the elements a edge of which is contained in the zone, or if the zone is used for unrefine the internal elements in the zone. If no choice is made, the zone is ignored in this hypothesis.
.. image:: images/create_hypothese_zo_2.png
:align: center
***********************
.. index:: single: group
-On peut restreindre l'application de l'hypothesis d'adaptation à des groupes. Ainsi les mailles n'appartenant pas à ces groupes ne seront pas modidiées, sauf par contamination ultérieure du raffinement pour assurer la conformité du maillage final.
-On coche le bouton associé :
+We can restrict the application of the hypothesis of adaptation to groups. So elements not belonging to these groups will not be modified, except by later contamination of the refinement to assure the conformity of the final mesh.
+We check the associated button:
.. image:: images/create_hypothese_gr_1.png
:align: center
-La liste des groupes de mailles présents dans le maillage est affichée. Il suffit de cocher ceux voulus pour restreindre l'hypothesis d'adaptation.
+The list of the present groups of elements in the mesh is shown. It is enough to check those wanted to restrict the hypothesis of adaptation.
.. image:: images/create_hypothese_gr_2.png
:align: center
.. index:: single: interpolation
.. note::
- Pour pousee interpoler un champ de l'ancien vers le nouveau maillage, il faut asee au préalable désigné le fichier med contenant le champ. Cela se fait dans la fenêtre de construction de l'itération (see :ref:`gui_create_iteration`).
+ To be able to interpolate a field from the former towards the new mesh, it is beforehand necessary to have indicated the file med containing the field. It is made in the window of construction of the iteration (see :ref:`gui_create_iteration`).
-Par défaut, aucun champ n'est interpolé. A contrario, on peut demander l'interpolation de tous les champs présents dans le fichier fourni :
+By default, no field is interpolated. On the contrary, we can ask for the interpolation of all the present fields in the supplied file:
.. image:: images/create_hypothese_ch_4.png
:align: center
-Si on veut choisir les champs à interpoler, il faut les cocher dans la liste de tous les champs présents dans le fichier fourni :
+If we want to choose fields to be interpolated, it is necessary to check them in the list of all the present fields in the supplied file:
.. image:: images/create_hypothese_ch_5.png
:align: center
Advanced options
****************
-Si la case "Options avancées" n'est pas cochée, aucune contrainte supplémentaire n'est définie.
-Si la case est cochée, on définira les options avancées.
+If the compartment "*Advanced Options*" is not checked, no additional constraint is defined.
+If the compartment is checked, we shall define the advanced options.
-Une première série d'options portent sur la finesse maximale de maillage que l'on ne veut pas dépasser. Deux directives sont possibles, séparément ou ensemble. On peut imposer une taille de maille minimale : une maille dont le diamètre est inférieur à cette limite ne sera plus découpée. Par défaut, on propose un diamètre minimal nul, ce qui revient à ne rien imposer. On peut imposer un niveau de raffinement maximal. Par défaut, le maximum est à 99, ce qui équivaut en général à ne rien imposer.
+A first series of options concern the maximal sharpness of mesh which we do not want to exceed. Two directives are possible, separately or together. We can impose a size of minimal element: a element the diameter of which is lower than this limit will not be any more split. By default, we propose a minimal 0 diameter, what means imposing nothing. We can impose a level of maximal refinement. By default, the maximum is 99, what amounts generally to impose nothing.
-La deuxième série d'options n'a d'intérêt que dans le cas où l'adaptation est piloté par un champ et que ce champ n'est pas défini partout dans le maillage. Cela arrive par exemple quand on construit un champ basé sur une distance dans un plan alors que le domaine est 3D : le champ ne sera pas défini sur les noeuds hors du plan. Pour de tels champs, cette option permet de préciser le comportement que l'on souhaite dans les régions où le champ n'est pas défini. Par défaut, il ne se passe rien : les mailles sont gardées telles quelles. On peut choisir les deux autres variantes : raffiner, toutes les mailles seront a priori coupées, ou déraffiner, toutes les mailles seront candidates au déraffinement.
+The second series of options has interest only in case the adaptation is driven by a field and in case this field is not defined everywhere in the mesh. It arrives for example when we build a field based on a distance in a plan while the domain is 3D: the field will not be defined on nodes outside the plan. For such fields, this option allows to specify the behavior which we wish in the regions where the field is not defined. By default, there is nothing: elements are kept as they are. We can choose two other variants: to refine all the elements will a priori be cut, or to unrefine all the elements will be candidate in the unefinement.
-Le dernier choix porte sur une sortie supplémentaire de l'adaptation. Si la case est cochée, le fichier MED en sortie contiendra un champ contenant le niveau de raffinement de chaque maille. La convention est celle de HOMARD : une maille du maillage initial est de niveau 0, une maille issue d'un raffinement d'une maille initiale porte le niveau 1, etc. Les mailles de transition qui sont produites entre deux mailles de niveau différents, n et n+1, sont affectées du demi-niveau n+0,5. Par défaut, la case n'est pas cochée et le champ n'est pas produit.
+The last choice concerns an additional output of the adaptation. If the compartment is checked, the file MED in output will contain a field containing the level of refinement of every element. The convention is the one of HOMARD: a element of the initial mesh is of level 0, a element stemming from a refinement of an initial element carries the level 1, etc. The elements of transition which are produced between two level elements different, n and n+1, are affected by the half-level n+0,5. By default, the compartment is not checked and the field is not produced.
.. image:: images/create_hypothese_av_1.png
:align: center
**************
.. index:: single: object browser
-L'arbre d'études contient les hypotheses créées et les itérations qui les utilisent. La description des zones qui leur sont éventuellement attachées est présente.
+The object browser contains the created hypotheses and the iterations which use them. The description of the zones which are possibly attached to them is present.
.. image:: images/create_hypothese_2.png
:align: center
#############
.. index:: single: iteration
-La définition d'une iteration se fait par la donnée des informations suivantes :
+The definition of an iteration is done by the following information:
- - L'iteration précédente
- - Le nom du maillage résultat
- - L'hypothesis utilisée
- - Eventuellement, le fichier du champ d'indicateurs d'erreur
+ - The previous iteration
+ - The name of the resulting mesh
+ - The used hypothesis
+ - Possibly, the file of the field of error indicators
.. image:: images/create_iteration_1.png
:align: center
Name of the iteration
*********************
-Un nom de cas est proposé automatiquement : Iter_1, Iter_2, etc. Ce nom peut être modifié. Il ne doit pas avoir été utilisé pour une iteration précédente.
+A name of case is proposed automatically: Iter_1, Iter_2, etc This name can be modified. It must not have been used for a preceding iteration.
-The previous iteration
-**********************
-L'iteration précédente est choisie dans l'arbre d'étude. Le nom du maillage correspondant sera affiché.
+The preceding iteration
+***********************
+The preceding iteration is selected in the object browser. The name of the corresponding mesh will be posted.
.. index:: single: mesh;result
The name of the resulting mesh
******************************
-L'iteration en cours de création produira un maillage. Ce maillage sera connu sous un nom. Ce nom est fourni en le tapant dans la zone de texte. Par défaut, on propose un nom identique à celui de l'iteration précédente.
+The current iteration will produce a mesh. This mesh will be known under a name. This name is provided by typing it in the zone of text. By default, one proposes a name identical to that of the preceding iteration.
.. index:: single: field
.. index:: single: MED
The field
*********
-Pour créer ou utiliser une hypothesis d'adaptation basée sur un champ exprimé sur le maillage, on doit fournir le fichier où se trouve le champ. C'est également le cas si on veut interpoler des champs du maillage n au maillage n+1. Ce fichier est au format MED. Classiquement, il aura été produit par le logiciel de calcul avec lequel on travaille. Le nom du fichier peut être fourni, soit en tapant le nom dans la zone de texte, soit en activant la fonction de recherche.
-
+To create or use an hypothesis of adaptation based on a field expressed on the mesh, one must provide the file where the field is. It is also the case if one wants to interpolate fields from mesh #N to the mesh #(N+1). This file is with format MED. Classically, it will have been produced by the computation software with which one works. The name of the file can be provided, either by typing the name in the zone of text, or by activating the function of research.
.. image:: images/create_iteration_2.png
:align: center
-Dans le cas où des pas de temps ont été définis, une solution simple consiste à traiter les champs au dernier pas de temps enregistré dans le fichier. Si on veut définir un autre pas de temps, on coche le bouton "*Pas de temps choisi*". Les valeurs de 'Pas de temps' et de 'Numéro d'ordre' sont celles correspondant à la convention MED (time step / rank). Ces valeurs dépendent de la logique qui a été retenue par le logiciel qui a écrit le fichier. Souvent ces deux valeurs sont identiques mais il arrive que l'on disjoigne les pas de temps et les intervalles d'archivage.
+If steps of time were defined, a simple solution consists in treating the fields with the last step of time recorded in the file. If one wants to define another step of time, one notches the button "*Given time step*". The values of 'time' and 'Sequence number' are those corresponding to convention MED (time step/rank). These values depend on the logic which was retained by the software which wrote the file. Often these two values are identical but it happens that one disjoins the time steps and the intervals of saving.
.. image:: images/create_iteration_3.png
:align: center
The hypothesis
**************
-L'iteration en cours pilotera l'adaptation par HOMARD selon un scénario défini dans une hypothesis. Celle-ci est choisie dans la liste des hypothesiss existantes.
+The iteration in progress will control the adaptation by HOMARD according to a scenario defined on an hypothesis. This one is selected in the list of the existing hypotheses.
-Au démarrage, il faut créer une première hypothesis par activation du bouton "*Nouveau*" (voir :ref:`gui_create_hypothese`) :
+With starting, it is necessary to create a first hypothesis by activation of the button "*New*" (see: :ref:`gui_create_hypothese`) :
.. image:: images/create_iteration_4.png
:align: center
-Ensuite, si une hypothesis précédemment définie convient, il suffit de la sélectionner dans la liste proposée. Sinon, il faut créer une nouvelle hypothesis par activation du bouton "*Nouveau*", puis la sélectionner dans la liste proposée :
+Then, if an hypothesis previously defined is appropriate, it is enough to select it in the proposed list. If not, it is necessary to create a new hypothesis by activation of the button "*New*", then to select it in the proposed list:
.. image:: images/create_iteration_5.png
:align: center
-
.. note::
- Si on envisage une adaptation selon les valeurs d'un champ sur le maillage, il faut avoir renseigné les informations sur ce champ avant de créer une nouvelle hypothesis.
+ If one considers an adaptation according to the values of a field on the mesh, it is necessary to have given information about this field before creating a new hypothesis.
.. index:: single: object browser
Object browser
**************
-A l'issue de cette création d'iteration, l'arbre d'études a été enrichi. On y trouve l'iteration initiale, identifiée par le nom du maillage qui a été lu dans le fichier fourni, l'iteration courante, identifiée par son nom. On trouve aussi l'hypothesis qui lui est attachée. L'icône en regard de l'iteration permet de différencier les iterations calculées ou non.
+At the conclusion of this creation of iteration, the object browser was enriched. One finds there the initial iteration, identified by the name of the mesh which was read in the provided file, the current iteration, identified by its name. One finds also the hypothesis which is attached to him. The icon compared to the iteration makes it possible to differentiate the iterations calculated or not.
.. image:: images/create_iteration_6.png
:align: center
-Quand plusieurs iterations s'enchaînent, leur hypothesis est visible dans l'arbre d'étude. On remarquera dans la figure ci-après que deux iterations peuvent partager la même hypothesis.
+When several iterations are connected, their hypothesis is visible in the object browser. One will notice in the figure hereafter that two iterations can share the same hypothesis.
.. image:: images/create_iteration_7.png
:align: center
.. index:: single: zone
.. index:: single: 2D
-L'objet zone contient toutes les définitions géométriques permettant de décrire une zone à raffiner.
+The object zone contains all the geometrical definitions allowing to describe a zone to be refined.
-En 3D, il existe quatre types de zone :
+In 3D, there are four types of zone:
- - Parallélépipède
- - Cylindre
- - Tuyau
- - Sphère
+ - Box
+ - Cylinder
+ - Pipe
+ - Sphere
-Leurs analogues en 2D sont :
+Their analogues in 2D are:
- Rectangle
- - Disque
- - Disque percé
+ - Disk
+ - Disk with a hole
-Le principe du raffinement selon des zones est le suivant. Chaque arête de maille dont les deux extrémités
-sont incluses dans une même zone sera coupée. Ensuite HOMARD applique l'algorithme de traitement de la
-conformité pour produire un maillage correct.
+The principle of the refinement according to zones is the following one. Every edge of element among which both extremities are included in the same zone will be cut. Then HOMARD applies the algorithm of processing of it conformity to produce a correct mesh.
.. note::
- Les valeurs proposées par défaut pour les dimensions des zones tiennent compte de la géométrie du maillage.
+ The values proposed by default for the size of zones take into account the geometry of the mesh.
Name of the zone
****************
-Un nom de zone est proposé automatiquement : Zone_1, Zone_2, etc. Ce nom peut être modifié. Il ne doit pas avoir été déjà utilisé pour une autre zone.
+A name of zone is automatically proposed: Zone_1, Zone_2, etc. This name can be modified. He must not have been already used for another zone.
Box
***
.. index:: single: box
-Le parallélépipède est obligatoirement parallèle aux axes de coordonnées. Il est défini par ses extrêmes dans chaque direction.
+The parallelepiped is necessarily parallel to coordinate system. It is defined by its extremes in every direction.
.. image:: images/create_zone_1.png
:align: center
-Cylindre
+Cylinder
********
.. index:: single: cylindre
-Le cylindre est défini par son axe, un point de base positionné sur l'axe, sa hauteur et son rayon. L'axe est défini par un vecteur qui doit être correctement orienté : on retiendra le volume partant de la base dans la direction du vecteur jusqu'à la hauteur retenue. La norme de ce vecteur n'est pas nécessairement égale à 1.
+The cylinder is defined by its axis, a basis point positioned on the axis, its height and its radius. The axis is defined by a vector which must be correctly directed: we shall retain the ready volume of the basis in the direction of the vector until the reserved height. The norm of this vector is not inevitably equal to 1.
.. image:: images/create_zone_2.png
:align: center
****
.. index:: single: pipe
-Le cylindre est défini par son axe, un point de base positionné sur l'axe, sa hauteur et ses rayons interne et externe. L'axe est défini par un vecteur qui doit être correctement orienté : on retiendra le volume partant de la base dans la direction du vecteur jusqu'à la hauteur retenue. La norme de ce vecteur n'est pas nécessairement égale à 1.
+The pipe is defined by its axis, a basis point positioned on the axis, its height and its internal and external radius. The axis is defined by a vector which must be correctly directed: we shall retain the ready volume of the basis in the direction of the vector until the reserved height. The norm of this vector is not inevitably equal to 1.
.. image:: images/create_zone_3.png
:align: center
******
.. index:: single: sphere
-La sphère est définie par son centre et son rayon.
+The sphere is defined by its center and its radius.
.. image:: images/create_zone_4.png
:align: center
*********
.. index:: single: rectangle
-Le rectangle est obligatoirement parallèle aux axes de coordonnées. Il est défini par ses extrêmes dans chacune des directions valides. La coordonnée constante est affichée pour information, mais n'est pas modifiable.
+The rectangle is necessarily parallel to coordinate system. It is defined by its extremes in each of the valid directions. The constant coordinate is shown for information, but is not modifiable.
.. image:: images/create_zone_21.png
:align: center
****
.. index:: single: disk
-Le disque est obligatoirement dans le plan des axes de coordonnées. Il est défini par son centre et son rayon. La coordonnée constante est affichée pour information, mais n'est pas modifiable.
+The disk is necessarily in the plan of coordinate system. It is defined by its center and its radius. The constant coordinate is shown for information, but is not modifiable.
.. image:: images/create_zone_22.png
:align: center
****************
.. index:: single: disk with a hole
-Le disque avec trou est obligatoirement dans le plan des axes de coordonnées. Il est défini par son centre et ses rayons externe et interne. La coordonnée constante est affichée pour information, mais n'est pas modifiable.
+The disk with hole is necessarily in the plan of coordinate system. It is defined by its center and its external and internal radius. The constant coordinate is shown for information, but is not modifiable.
.. image:: images/create_zone_23.png
:align: center
-
Corresponding python functions
******************************
Look :ref:`tui_create_zone`
.. index:: single: iteration
.. index:: single: computation
-To cumpute an iteration
+To compute an iteration
***********************
-Lancer une adaptation s'obtient en sélectionnant l'iteration à calculer. Elle est repérée par une icone "en attente". On choisit ensuite "*Calculer*" dans le menu HOMARD ou à la souris.
+To launch an adaptation obtains by selecting the iteration to calculate. It is identified by an icone "wait". We choose then "*Compute*" in the menu HOMARD or with the mouse.
.. image:: images/lancement_1.png
:align: center
Object browser
**************
-A l'issue de ce calcul, l'arbre d'études a été enrichi. L'icone devant l'iteration est validée. Sous l'iteration, on trouve la référence aux fichiers de résultats créés, identifiés par leur nom dans le répertoire *rep* qui a été défini à la création du cas :
+At the end of this calculation, the object browser was enriched. The icone in front of the iteration is validated. Under the iteration, we find the reference to the files of results created, identified by their name in the directory *rep* which was defined in the creation of the case:
- *rep*/I(n+1)/Liste.n.vers.(n+1).log
- *rep*/I(n+1)/apad.n.vers.(n+1).bilan
- *rep*/maill.(n+1).med
-Les deux premiers fichiers sont des fichiers de texte, éditables. Liste.n.vers.(n+1).log contient des informations sur le déroulement de l'adaptation : récapitulatif du mode d'adaptation, pourcentage de mailles concernées, etc. Le fichier apad.n.vers.(n+1).bilan est un résumé des caractéristiques du maillage obtenu.
+The first two files are text files, editable. Liste.n.vers.(n+1).log contains information on the progress of the adaptation: summary of the mode of adaptation, percentage of concerned elements, etc. The file apad.n.vers.(n+1).bilan is a summary of the characteristics of the obtained mesh.
-Le fichier maill.(n+1).med est celui qui contient le maillage produit au format MED. On retrouve ce maillage dans la section de l'arbre d'études du module SMESH. Il est alors visible dans ce module et utilisable ensuite comme tout autre maillage.
+The file maill.(n+1).med is the one which contains the mesh produced in the format MED. We find this mesh in the section of the object browser of the module SMESH. It is then visible in this module and usable then as quite different mesh.
.. image:: images/lancement_2.png
To consult the result of an adaptation
**************************************
-Les deux fichiers de texte, Liste.n.vers.(n+1).log et apad.n.vers.(n+1).bilan, sont visibles en les sélectionnant. On choisit ensuite "*Afficher le fichier*" dans le menu HOMARD ou à la souris.
+Both text files, Liste.n.vers.(n+1).log and apad.n.vers.(n+1).bilan, are visible by selecting them. We choose then "*Edit file*" in the menu HOMARD or with the mouse.
.. image:: images/lancement_3.png
:align: center
.. note::
- Par défaut, le calcul est lancé avec l'exécutable de HOMARD installé avec SALOME. Si on souhaite utiliser une version privée de HOMARD, pour tester une évolution par exemple, il faut préciser où le nouvel exécutable est disponible. Pour cela, il faut renseigner deux variables d'environnement.
- "*HOMARD_REP_EXE_PRIVATE*" définit le répertoire dans lequel se trouve l'exécutable voulu.
- "*HOMARD_EXE_PRIVATE*" définit le nom de l'exécutable dans ce répertoire, si ce nom est différent de "*homard*".
+ By default, the calculation is launched with the load module of HOMARD installed with SALOME. If we wish to use a personal version of HOMARD, to test an evolution for example, it is necessary to specify where the new load module is available. For that purpose, it is necessary to have got two variables of environment.
+ "*HOMARD_REP_EXE_PRIVATE*" defines the directory in which is the load module
+ "*HOMARD_EXE_PRIVATE*" defines the name of the load module in this directory, if this name is different of "*homard*".
Corresponding python functions
******************************
.. index:: single: analysis
.. index:: single: information
-La demande d'analysis d'un maillage se fait par la donnée des informations suivantes :
+The request of analysis of a mesh is made by the following information:
- - Un répertoire
- - Le fichier du maillage
+ - A directory
+ - A mesh file
-Si le maillage fait partie d'un cas enregistré, son analysis est faite à partir de son itération dans l'arbre d'études. Voir plus loin.
+If the mesh is a part of a registered case, its analysis is made from its iteration in the object browser. See farther.
Importation of the mesh
***********************
-La sélection de la fonction d'analysis est faite par le menu de la barre supérieure de la fenêtre :
+The selection of the function of analysis is made by the menu of the superior bar of the window:
.. image:: images/mesh_info_1.png
:align: center
-La fenêtre de choix s'affiche.
+The window of choice is displayed.
.. image:: images/mesh_info_2.png
:align: center
Name of the case
****************
-Un nom de cas est proposé automatiquement : Case_1, Case_2, etc. Ce nom peut être modifié. Il ne doit pas avoir déjà été utilisé pour un autre cas.
+A name of case is automatically proposed: Case_1, Case_2, etc. This name can be modified. He must not already have been used for another case.
The directory
*************
-Le répertoire est celui qui contiendra les fichiers produits par l'information. Par défaut, rien n'est proposé. Le choix est fait, soit en tapant le nom dans la zone de texte, soit en activant la fonction de recherche. C'est dans ce répertoire que seront exportés les fichiers d'information de nom ``Liste.log`` et ``info_av.00.bilan``. Ces fichiers seront visibles dans l'arbre d'études.
+The directory is the one which will contain files produced by the information. By default, nothing is proposed. The choice is made, either by typing the name in the text field, or by activating the function of research. It is in this directory that will be exported the files of information of name "Liste.log" and "info_av.00.bilan". These files will be visible in the object browser.
.. image:: images/create_case_2.png
:align: center
Mesh to be analysed
*******************
-Le maillage à analysisr doit se trouver dans un fichier au format MED. Le nom du fichier peut être fourni, soit en tapant le nom dans la zone de texte, soit en activant la fonction de recherche.
+The mesh to be analyzed has to be in a file in the format MED. The name of the file can be supplied, either by typing the name in the text field, or by activating the function of research.
.. image:: images/create_case_3.png
:align: center
.. note::
- Le fichier ne doit contenir qu'un seul maillage.
+ The file has to contain only a single mesh.
.. warning::
- Le maillage ne doit pas être lui-même le produit d'une adaptation de maillage par HOMARD, sous peine de perdre l'analysis des différents niveaux de raffinement/déraffinement
+ The mesh does not have to be produced of an adaptation of mesh by HOMARD itself, at the risk of losing the analysis of the various levels of refinement / unrefinement
Options for the analysis
************************
-L'analysis est faite selon les options cochées.
- - qualité des mailles
- - diamètre des mailles
- - connexité du domaine ; en un seul morceau, combien de trous, etc.
- - tailles des constituants du domaine, groupe par groupe
- - interpénétration des mailles, par dimension
+The analysis is made according to the marked options.
+ - Quality of elements
+ - Diameter of elements
+ - Connectivity of the domain; in a single piece, how many holes, etc.
+ - Sizes of the constituents of the domain, group by group
+ - Interpenetration of elements, by dimension
-Le résultat de l'analysis est contenu dans le fichier ``info_av.00.bilan`` ; ce fichier est à consulter en l'affichant après sa désignation avec "*Afficher le fichier*" dans le menu HOMARD ou à la souris.
+The result of the analysis is contained in the file "info_av.00.bilan"; this file is to be consulted by showing it after its name with "*Edit file*" in the menu HOMARD or with the mouse.
Object browser
**************
-A l'issue de cette demande d'information, l'arbre d'études a été enrichi de ce nouveau cas. On y trouve l'itération initiale, identifiée par le nom du maillage qui a été lu dans le fichier fourni, et les deux fichiers d'information de nom ``Liste.log`` et ``info_av.00.bilan``.
+At the end of this request of information, the object browser was enriched by this new case. We find the initial iteration there, identified by the name of the mesh which was read in the supplied file, and both files of information of name "Liste.log" and "info_av.00.bilan".
.. image:: images/mesh_info_3.png
:align: center
Computed iteration
******************
-Pour analysisr le maillage produit par une itération d'adaptation de maillage, on désigne à la souris cette itération dans l'arbre d'études et on lance l'analysis. On retrouve le menu similaire au cas initial :
+To analyze the mesh produced by an iteration of mesh adaptation, we indicate with the mouse this iteration in the object browser and we launch the analysis. We find the menu similar to the initial case:
.. image:: images/mesh_info_4.png
:align: center
-Comme pour un maillage importé, l'arbre d'études a été enrichi avec les deux fichiers d'information de nom ``Liste.log`` et ``info_ap.xx.bilan``, où xx est le numéro de l'itération dans le cas.
+As for an imported mesh, the object browser was enriched with both files of information of name "Liste.log" and "info_ap.xx.bilan", where xx is the number of the iteration in the case.
.. image:: ../images/mesh_info_5.png
:align: center
intro
regles
- applications
divers
Licence
DataInit
========
.. image:: ../images/yacs_a_01.png
- :align: left
+ :align: center
:alt: DataInit
:width: 158
:height: 61
- SetCurrentStudy : service of the component HOMARD
.. image:: ../images/yacs_b_01.png
- :align: left
+ :align: center
:alt: Etude_Initialisation
:width: 323
:height: 97
The box Tant_que_le_calcul_n_a_pas_converge is type WhileLoop. The condition is initialized in 1: the internal block Alternance_Calcul_HOMARD is executed. Within this block, we calculate and we adapt the mesh; when the process has to stop either as a result of error, or by convergence, the condition passes in 0. The loop ends and we pass in the following box, Bilan.
.. image:: ../images/yacs_c_01.png
- :align: left
+ :align: center
:alt: Boucle
:width: 195
:height: 142
Bilan
=====
.. image:: ../images/yacs_d_01.png
- :align: left
+ :align: center
:alt: Bilan
:width: 158
:height: 63
Loop for the calculations
*************************
.. image:: ../images/yacs_c_02.png
- :align: left
+ :align: center
:alt: Boucle
:width: 323
:height: 158
Calcul
======
.. image:: ../images/yacs_c_03.png
- :align: left
+ :align: center
:alt: Calcul
:width: 155
:height: 87
Adaptation
==========
.. image:: ../images/yacs_c_04.png
- :align: left
+ :align: center
:alt: Adaptation
:width: 672
:height: 569
Homard_init_au_debut
^^^^^^^^^^^^^^^^^^^^
.. image:: ../images/yacs_c_06.png
- :align: left
+ :align: center
:alt: Homard_init_au_debut
:width: 481
:height: 150
Once initialized, the adaptation can be calculated. It is the goal of the Homard_Exec box, in the form of a script python.
.. image:: ../images/yacs_c_09.png
- :align: left
+ :align: center
:alt: Homard_Exec
:width: 153
:height: 141
Homard_init_ensuite
^^^^^^^^^^^^^^^^^^^
.. image:: ../images/yacs_c_07.png
- :align: left
+ :align: center
:alt: Homard_init_ensuite
:width: 323
:height: 97
Arret_boucle
------------
.. image:: ../images/yacs_c_08.png
- :align: left
+ :align: center
:alt: Arret_boucle
:width: 163
:height: 152
Analyse
=======
.. image:: ../images/yacs_c_05.png
- :align: left
+ :align: center
:alt: Analyse
:width: 155
:height: 169
**********
.. index:: single: référence
-Le logiciel HOMARD a fait l'objet de publications techniques au cours de conférences ces dernières années. Les références des principaux documents sont présentées ici.
-
-Référence principale
-====================
-
Pour une référence à HOMARD, utiliser :
G. Nicolas and T. Fouquet, Adaptive Mesh Refinement for Conformal Hexahedral Meshes, "*Finite Elements in Analysis and Design*", Vol. 67, pp. 1-12, 2013, doi:10.1016/j.finel.2012.11.008
`Accessible en cliquant ici <http://dx.doi.org/10.1016/j.finel.2012.11.008>`_
-Découpage de maillage
-=====================
-
- * G. Nicolas, T. Fouquet, Conformal hexaedral meshes and adaptive mesh refinement, VI International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2013*", J.P. Moitinho de Almeida, P. Diez, C. Tiago and N. Pares (Eds), Lisbonne, pp. 515-526, 2013
- * G. Nicolas, T. Fouquet, Hexaedral mesh adaptation for finite volume methods, III International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2007*", K. Runesson, P. Diez (Eds), Goteborg, pp. 174-177, 2007
- * G. Nicolas, F. Arnoux-Guisse, O. Bonnin, Adaptive meshing for 3D finite element software, IX International Conference on Finite Elements in Fluids, Venise, Italie, 15-21 Octobre 1995.
- * G. Nicolas, F. Arnoux-Guisse, O. Bonnin, Un logiciel d'adaptation de maillage en 2D et 3D, 27ème Congrès d'Analyse Numérique, Super-Besse, France, 29 mai-2 juin 1995.
-
-Estimateurs d'erreurs
-=====================
-
- * A. Ern, S. Meunier, A posteriori error analysis of Euler-Galerkin approximations to coupled elliptic-parabolic problems", ESAIM: M2AN 43 (2009) 353-375.
- * J. Delmas, Stratégies de controle d'erreur en calcul de structures industrielles., Thèse de l'Université de Picardie, France, avril 2008
- * S. Meunier, Analyse d'erreur a posteriori pour les couplages hydro-mécaniques et mise en oeuvre dans Code_Aster, Thèse de l'Ecole Nationale des Ponts et Chaussées, France, novembre 2007.
- * J. Delmas, P. Coorevits, P.-B. Badel and M. Guessasma, An explicit estimator for goal oriented H-Adaptivity with mesh optimaly criteria, III International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2007*", K. Runesson, P. Diez (Eds), Goteborg, pp. 93-96, 2007.
- * P. Destuynder, B. Métivet, Estimation d'erreur explicite dans une méthode d'éléments finis conforme, Compte Rendu Académie des Sciences Paris, tome 323, Série I, p. 679-684, 1996.
- * P. Destuynder, B. Métivet, Estimation d'erreur explicite pour une méthode d'éléments finis non conforme, Compte Rendu Académie des Sciences Paris, tome 322, Série I, p. 1081-1086, 1996.
- * C. Bernardi, O. Bonnin, C. Langouet, B. Métivet, Residual Error Indicators for Linear Problems - Extension to the Navier-Stokes Equations, IX International Conference on Finite Elements in Fluids, Venise, Italie, 15-21 Octobre 1995.
- * F. Arnoux-Guisse, O. Bonnin, L. Léal De Sousa, G. Nicolas, An adaptive finite element method for turbulent flow simulation, ICFD Conference on Numerical Methods for Fluid Dynamics, University of Oxford, Grande-Bretagne, 3-6 Avril 1995.
- * O. Bonnin, B. Métivet, G. Nicolas, F. Arnoux-Guisse, L. Léal de Sousa, Adaptive Meshing for N3S Fluid Mechanics Code, "*Computational Fluid Dynamics '94*", ECCOMAS Stuttgart, Allemagne, pp. 201-208, Wiley 1994.
-
-Applications
-============
- * S. Meunier, R. Fernandes, Mesh Adaptation for Coupled Hydro-Mechanical Industrial Studies, V International Conference on Adaptive Modeling and Siumulation, "*ADMOS 2011*", D. Aubry, P. Diez, B. Tie and N. Pares (Eds), Paris, pp. 337-338, 2011
- * O. Hartmann, O. Bonnin, D. Gasser, An Adaptive Meshing for Turbomachinery Geometries, "*Computational Fluid Dynamics '98*", ECCOMAS Athènes, Grèce, Wiley 1998.
-
Evolutions du module
********************
.. index:: single: évolution
SALOME VERSION 7.2.1 :
- Documentation en anglais
-Contact
-*******
-.. index:: single: Contact
-
-Gérald NICOLAS, Responsable du Logiciel
-
-Adresse :
-EDF R&D, 1, avenue du Général de Gaulle, 92141 CLAMART Cedex, FRANCE
-
-Téléphone : (33/0) 1.47.65.56.94
-
-Email : Gerald.Nicolas[at]edf.fr
-
-
-Thierry FOUQUET
-
-Adresse :
-EDF R&D, 1, avenue du Général de Gaulle, 92141 CLAMART Cedex, FRANCE
-
-Téléphone : (33/0) 1.47.65.41.45
-
-Email : Thierry.Fouquet[at]edf.fr
-
-
-Vraiment divers ...
-*******************
-
-HOMARD est un acronyme pour :
- - Outil de
- - Maillage
- - Adaptatif par
- - Raffinement et
- - Déraffinement
-
-Notre mascotte était toute trouvée dans `la ville du homard <http://www.shediac.org>`_ : |M|
-
-.. |M| image:: ../images/mascotte.gif
- :align: middle
- :alt: Mascotte
- :width: 144
- :height: 94
-
-West led the aaaaaaaaa |H| ffffffff |S| ccccccccccccccccc.
-
-.. |H| image:: ../images/mascotte.gif
- :width: 144
- :height: 94
-.. |S| image:: ../images/dec_tria_1.gif
- :width: 399
- :height: 88
-
-
.. image:: images/create_boundary_an_1.png
:align: center
-Il faut créer une première frontière analytique par activation du bouton "*Nouveau*". On aura le choix entre cylindre ou sphère. Une fois que la frontière sera validée, son nom figurera en en-tête d'une deuxième colonne.
+Il faut créer une première frontière analytique par activation du bouton "*Nouveau*". On aura le choix entre cylindre, sphère ou cône. Une fois que la frontière sera validée, son nom figurera en en-tête d'une deuxième colonne.
.. image:: images/create_boundary_an_2.png
:align: center
- selon un pourcentage de mailles à raffiner, nombre réel compris entre 0 et 100 ; HOMARD raffinera les x% des mailles qui ont la plus grande valeur du champ.
- selon une valeur relative du champ, nombre compris entre 0 et 100 ; HOMARD raffinera les mailles où le champ est supérieur à x% de l'intervalle [mini,maxi].
- - au dela d'une valeur absolue ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
- - au dela d'une valeur absolue valant la moyenne de la répartition du champ augmentée de n fois son écart-type ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
+ - au delà d'une valeur absolue ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
+ - au delà d'une valeur absolue valant la moyenne de la répartition du champ augmentée de n fois son écart-type ; toutes les mailles avec une valeur de champ supérieure à cette valeur seront raffinées.
La même convention s'applique au déraffinement, en remplaçant supérieur par inférieur. On peut inactiver une des fonctions (raffinement ou déraffinement) en cochant le bouton ad_hoc.
************************
.. index:: single: groupe
-On peut restreindre l'application de l'hypothèse d'adaptation à des groupes. Ainsi les mailles n'appartenant pas à ces groupes ne seront pas modidiées, sauf par contamination ultérieure du raffinement pour assurer la conformité du maillage final.
+On peut restreindre l'application de l'hypothèse d'adaptation à des groupes. Ainsi les mailles n'appartenant pas à ces groupes ne seront pas modifiées, sauf par contamination ultérieure du raffinement pour assurer la conformité du maillage final.
On coche le bouton associé :
.. image:: images/create_hypothese_gr_1.png
.. image:: images/create_iteration_5.png
:align: center
-
.. note::
Si on envisage une adaptation selon les valeurs d'un champ sur le maillage, il faut avoir renseigné les informations sur ce champ avant de créer une nouvelle hypothèse.
********
.. index:: single: tuyau
-Le cylindre est défini par son axe, un point de base positionné sur l'axe, sa hauteur et ses rayons interne et externe. L'axe est défini par un vecteur qui doit être correctement orienté : on retiendra le volume partant de la base dans la direction du vecteur jusqu'à la hauteur retenue. La norme de ce vecteur n'est pas nécessairement égale à 1.
+Le tuyau est défini par son axe, un point de base positionné sur l'axe, sa hauteur et ses rayons interne et externe. L'axe est défini par un vecteur qui doit être correctement orienté : on retiendra le volume partant de la base dans la direction du vecteur jusqu'à la hauteur retenue. La norme de ce vecteur n'est pas nécessairement égale à 1.
.. image:: images/create_zone_3.png
:align: center
Le fichier ne doit contenir qu'un seul maillage.
.. warning::
- Le maillage ne doit pas être lui-même le produit d'une adaptation de maillage par HOMARD, sous peine de perdre l'analyse des différents niveaux de raffinement/déraffinement
+ Le maillage ne doit pas être lui-même le produit d'une adaptation de maillage par HOMARD, sous peine de perdre l'analyse des différents niveaux de raffinement/déraffinement.
Options d'analyse
=================
intro
regles
- applications
divers
Licence
DataInit
========
.. image:: ../images/yacs_a_01.png
- :align: left
+ :align: center
:alt: DataInit
:width: 158
:height: 61
- SetCurrentStudy : service du composant HOMARD
.. image:: ../images/yacs_b_01.png
- :align: left
+ :align: center
:alt: Etude_Initialisation
:width: 323
:height: 97
La boîte Tant_que_le_calcul_n_a_pas_converge est une boucle de type WhileLoop. La condition est initialisée à 1 : le bloc interne Alternance_Calcul_HOMARD est exécuté. Au sein de ce bloc, on calcule et on adapte le maillage ; quand le processus doit s'arrêter soit par suite d'erreur, soit par convergence, la condition passe à 0. La boucle s'achève et on passe à la boîte suivante, Bilan.
.. image:: ../images/yacs_c_01.png
- :align: left
+ :align: center
:alt: Boucle
:width: 195
:height: 142
Bilan
=====
.. image:: ../images/yacs_d_01.png
- :align: left
+ :align: center
:alt: Bilan
:width: 158
:height: 63
La boucle de calculs
********************
.. image:: ../images/yacs_c_02.png
- :align: left
+ :align: center
:alt: Boucle
:width: 323
:height: 158
Calcul
======
.. image:: ../images/yacs_c_03.png
- :align: left
+ :align: center
:alt: Calcul
:width: 155
:height: 87
Adaptation
==========
.. image:: ../images/yacs_c_04.png
- :align: left
+ :align: center
:alt: Adaptation
:width: 672
:height: 569
Homard_init_au_debut
^^^^^^^^^^^^^^^^^^^^
.. image:: ../images/yacs_c_06.png
- :align: left
+ :align: center
:alt: Homard_init_au_debut
:width: 481
:height: 150
Une fois initialisée, l'adaptation peut être calculée. C'est le but de la boîte Homard_Exec, sous forme d'un script python.
.. image:: ../images/yacs_c_09.png
- :align: left
+ :align: center
:alt: Homard_Exec
:width: 153
:height: 141
Homard_init_ensuite
^^^^^^^^^^^^^^^^^^^
.. image:: ../images/yacs_c_07.png
- :align: left
+ :align: center
:alt: Homard_init_ensuite
:width: 323
:height: 97
Arret_boucle
------------
.. image:: ../images/yacs_c_08.png
- :align: left
+ :align: center
:alt: Arret_boucle
:width: 163
:height: 152
Analyse
=======
.. image:: ../images/yacs_c_05.png
- :align: left
+ :align: center
:alt: Analyse
:width: 155
:height: 169