Arcane  v3.16.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
ItemTypeInfoBuilder.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2025 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* ItemTypeInfoBuilder.h (C) 2000-2025 */
9/* */
10/* Construction d'un type d'entité du maillage. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_CORE_ITEMTYPEINFOBUILDER_H
13#define ARCANE_CORE_ITEMTYPEINFOBUILDER_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/core/ItemTypeInfo.h"
18
19#include <array>
20
21/*---------------------------------------------------------------------------*/
22/*---------------------------------------------------------------------------*/
23
24namespace Arcane
25{
26
27/*---------------------------------------------------------------------------*/
28/*---------------------------------------------------------------------------*/
29
30/*!
31 * \internal
32 * \brief Construction des infos d'un type d'entité du maillage.
33 *
34 * Pour des raisons de performances, on essaie de stocker ces informations
35 * de manière contigue en mémoire car elles seront accédées très souvent.
36 * Pour cela, on utilise un Buffer dans ItemTypeMng.
37 *
38 * La méthode setInfos() permet d'indiquer le type et le nombre de noeuds, d'arêtes
39 * et de faces du type. Il faut ensuite appeler les méthodes addEdge() et addFace...()
40 *
41 * Une fois le type complètement défini, il ne doit plus être modifié.
42 *
43 * Pour un numéro de type donné, il n'existe qu'une instance de ItemTypeInfo et cette
44 * instance reste valide tant que le gestionnaire de type (ItemTypeMng) n'est pas détruit.
45 * Par conséquent, il est possible de stocker le pointeur sur l'instance et
46 * de comparer deux types uniquement en comparant les pointeurs
47 */
49: public ItemTypeInfo
50{
51 public:
52
53 //! Dimension du type
54 enum class Dimension : Int16
55 {
56 DimUnknown = -1,
57 Dim0 = 0,
58 Dim1 = 1,
59 Dim2 = 2,
60 Dim3 = 3
61 };
62
63 public:
64
65 //! Constructeur par défaut
67
68 public:
69
70 ARCANE_DEPRECATED_REASON("Y2025: Use setInfo(...,Dimension dimension, ...) instead")
71 void setInfos(ItemTypeMng* mng, Int16 type_id, String type_name,
72 Int32 nb_node, Int32 nb_edge, Int32 nb_face);
73
74 ARCANE_DEPRECATED_REASON("Y2025: Use setInfo(...,Dimension dimension, ...) instead")
75 void setInfos(ItemTypeMng* mng, ItemTypeId type_id, String type_name,
76 Int32 nb_node, Int32 nb_edge, Int32 nb_face);
77
78 /*!
79 * \brief Positionne les informations d'un type.
80 */
81 ARCANE_DEPRECATED_REASON("Y2025: Use setInfo(...,Dimension dimension, ...) instead")
82 void setInfos(ItemTypeMng* mng, ItemTypeId type_id, String type_name, Int16 dimension,
83 Int32 nb_node, Int32 nb_edge, Int32 nb_face);
84
85 /*!
86 * \brief Positionne les informations d'un type.
87 */
88 void setInfos(ItemTypeMng* mng, ItemTypeId type_id, String type_name, Dimension dimension,
89 Int32 nb_node, Int32 nb_edge, Int32 nb_face);
90
91 /*!
92 * \brief Positionne les informations d'un type.
93 */
94 void setInfos(ItemTypeMng* mng, Int16 type_id, String type_name, Dimension dimension,
95 Int32 nb_node, Int32 nb_edge, Int32 nb_face);
96
97 /*!
98 * \brief Ajoute une arête à la liste des arêtes
99 *
100 * \a n0 noeud origine
101 * \a n1 noeud extremité
102 * \a f_left numéro local de la face à gauche
103 * \a f_right numéro local de la face à droite
104 */
105 void addEdge(Integer edge_index, Integer n0, Integer n1, Integer f_left, Integer f_right);
106
107 //! Ajoute un sommet à la liste des faces (pour les elements 1D)
108 void addFaceVertex(Integer face_index, Integer n0);
109
110 //! Ajoute une ligne à la liste des faces (pour les elements 2D)
111 void addFaceLine(Integer face_index, Integer n0, Integer n1);
112
113 //! Ajoute une ligne quadratique à la liste des faces (pour les elements 2D)
114 void addFaceLine3(Integer face_index, Integer n0, Integer n1, Integer n2);
115
116 //! Ajoute un triangle à la liste des faces
117 void addFaceTriangle(Integer face_index, Integer n0, Integer n1, Integer n2);
118
119 //! Ajoute un triangle quadratique à la liste des faces
120 void addFaceTriangle6(Integer face_index, Integer n0, Integer n1, Integer n2,
121 Integer n3, Integer n4, Integer n5);
122
123 //! Ajoute un quadrilatère à la liste des faces
124 void addFaceQuad(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3);
125
126 //! Ajoute un quadrilatère quadratique à la liste des faces
127 void addFaceQuad8(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3,
128 Integer n4, Integer n5, Integer n6, Integer n7);
129
130 //! Ajoute un pentagone à la liste des faces
131 void addFacePentagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4);
132
133 //! Ajoute un hexagone à la liste des faces
134 void addFaceHexagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3,
135 Integer n4, Integer n5);
136
137 //! Ajoute un heptagone à la liste des faces
138 void addFaceHeptagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3,
139 Integer n4, Integer n5, Integer n6);
140
141 //! Ajoute un heptagone à la liste des faces
142 void addFaceOctogon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3,
143 Integer n4, Integer n5, Integer n6, Integer n7);
144
145 //! Ajoute une face générique à la liste des faces
146 void addFaceGeneric(Integer face_index, Integer type_id, ConstArrayView<Integer> n);
147
148 //! Calcule les relations face->arêtes
150
151 void setIsValidForCell(bool is_valid)
152 {
153 m_is_valid_for_cell = is_valid;
154 }
155
156 private:
157
158 void _setNbEdgeAndFace(Integer nb_edge,Integer nb_face);
159 void _checkDimension(Int16 dim);
160};
161
162/*---------------------------------------------------------------------------*/
163/*---------------------------------------------------------------------------*/
164
165} // End namespace Arcane
166
167/*---------------------------------------------------------------------------*/
168/*---------------------------------------------------------------------------*/
169
170#endif
171
Vue constante d'un tableau de type T.
Type d'une entité (Item).
Definition ItemTypeId.h:32
void addFaceHexagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4, Integer n5)
Ajoute un hexagone à la liste des faces.
void addEdge(Integer edge_index, Integer n0, Integer n1, Integer f_left, Integer f_right)
Ajoute une arête à la liste des arêtes.
void addFacePentagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4)
Ajoute un pentagone à la liste des faces.
void addFaceHeptagon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4, Integer n5, Integer n6)
Ajoute un heptagone à la liste des faces.
void addFaceQuad8(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4, Integer n5, Integer n6, Integer n7)
Ajoute un quadrilatère quadratique à la liste des faces.
void addFaceLine3(Integer face_index, Integer n0, Integer n1, Integer n2)
Ajoute une ligne quadratique à la liste des faces (pour les elements 2D)
void addFaceOctogon(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4, Integer n5, Integer n6, Integer n7)
Ajoute un heptagone à la liste des faces.
void addFaceGeneric(Integer face_index, Integer type_id, ConstArrayView< Integer > n)
Ajoute une face générique à la liste des faces.
void addFaceVertex(Integer face_index, Integer n0)
Ajoute un sommet à la liste des faces (pour les elements 1D)
ItemTypeInfoBuilder()=default
Constructeur par défaut.
void addFaceTriangle(Integer face_index, Integer n0, Integer n1, Integer n2)
Ajoute un triangle à la liste des faces.
void computeFaceEdgeInfos()
Calcule les relations face->arêtes.
void addFaceQuad(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3)
Ajoute un quadrilatère à la liste des faces.
void addFaceLine(Integer face_index, Integer n0, Integer n1)
Ajoute une ligne à la liste des faces (pour les elements 2D)
void addFaceTriangle6(Integer face_index, Integer n0, Integer n1, Integer n2, Integer n3, Integer n4, Integer n5)
Ajoute un triangle quadratique à la liste des faces.
Int16 dimension() const
Dimension de l'élément (<0 si inconnu)
bool m_is_valid_for_cell
Indique si le type est valide pour une maille.
ItemTypeInfo()=default
Constructeur par défaut.
Gestionnaire des types d'entités de maillage.
Definition ItemTypeMng.h:66
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Int32 Integer
Type représentant un entier.
std::int16_t Int16
Type entier signé sur 16 bits.
std::int32_t Int32
Type entier signé sur 32 bits.