Arcane  v3.16.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
GeomShapeView.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2023 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/* GeomShapeView.h (C) 2000-2023 */
9/* */
10/* Gestion des formes géométriques 2D et 3D. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_GEOMETRIC_GEOMSHAPEVIEW_H
13#define ARCANE_GEOMETRIC_GEOMSHAPEVIEW_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/utils/ITraceMng.h"
18#include "arcane/utils/ArrayView.h"
19#include "arcane/utils/Real3.h"
20
21#include "arcane/Item.h"
22
23#include "arcane/geometric/GeometricConnectic.h"
24#include "arcane/geometric/GeomElement.h"
25#include "arcane/geometric/CellConnectivity.h"
26#include "arcane/geometric/GeomShapeMutableView.h"
27
28/*---------------------------------------------------------------------------*/
29/*---------------------------------------------------------------------------*/
30
31namespace Arcane::geometric
32{
34/*---------------------------------------------------------------------------*/
35/*---------------------------------------------------------------------------*/
36
39/*---------------------------------------------------------------------------*/
40/*---------------------------------------------------------------------------*/
41/*!
42 * \ingroup ArcaneGeometric
43 * \brief Vue constante sur une forme géométrique GeomShape.
44 *
45 * Une vue sur une forme géométrique permet de récupérer de manière
46 * optimisée la position des noeuds, des faces et des arêtes (en 3D)
47 * d'un objet géométrique.
48 *
49 * Cette classe gère une vue sur une forme géométrique. Il existe deux
50 * manières d'initialiser une vue:
51 * - en récupérant la vue associée à une maille du maillage via l'appel
52 * à GeomShapeMng::initShape(). Dans ce cas, il est possible de
53 * récupérer la maille associée via la méthode cell().
54 * - à partir d'une instance temporaire de GeomShape
55 * via une des deux méthodes initFromHexa() ou initFromQuad().
56 *
57 */
58class ARCANE_CEA_GEOMETRIC_EXPORT GeomShapeView
59{
60 friend class GeomShapeMng;
61 friend class GeomShape;
62 friend class GeomShapeConnectivity;
63
64 private:
65
66 static CellConnectivity* global_cell_connectivity[NB_BASIC_ITEM_TYPE];
67 static GeomShapeConnectivity* global_connectivity;
68
69 public:
70
71 static void initializeConnectivity();
72
73 public:
74
76 : m_node_ptr(0), m_face_ptr(0), m_center_ptr(0),
77 m_cell_connectivity(global_cell_connectivity[IT_NullType]),
78 m_item_internal(ItemInternal::nullItem())
79 {
80 }
81
82 public:
83
84#include "arcane/geometric/GeneratedGeomShapeViewDeclarations.h"
85
86 public:
88 //! Remplit \a hexa avec les informations du \a i-ème sous-volume de contrôle
89 void fillSubZoneElement(HexaElementView hexa, Integer i);
90 //! Remplit \a quad avec les informations du \a i-ème sous-volume de contrôle
91 void fillSubZoneElement(QuadElementView quad, Integer i);
92
93 /*!
94 * \deprecated Utiliser GeomShape::initFromHexaedron8() à la place.
95 */
96 ARCANE_DEPRECATED_122 void initFromHexa(HexaElementConstView hexa,GeomShape& geom_cell);
97 /*!
98 * \deprecated Utiliser GeomShape::initFromQuad4() à la place.
99 */
100 ARCANE_DEPRECATED_122 void initFromQuad(QuadElementConstView hexa,GeomShape& geom_cell);
102 public:
103
104 /*!
105 * \name Récupération des coordonnées.
106 */
107 //@{
108 //! Position du \a ième noeud de la forme
109 const Real3 node(Integer i) const
110 {
111 return m_node_ptr[i];
112 }
113
114 //! Position du centre de la \a ième face de la forme
115 const Real3 face(Integer i) const
117 return m_face_ptr[i];
118 }
119
120 //! Position du centre de la forme
121 const Real3 center() const
123 return *m_center_ptr;
125
126 //! Position du centre de la \a i-ème arête de la forme
127 inline const Real3 edge(Integer i) const
128 {
129 return 0.5 * (node(m_cell_connectivity->m_edge_direct_connectic[(i*2)]) + node(m_cell_connectivity->m_edge_direct_connectic[(i*2)+1]));
130 }
131 //@}
132
133 //! Entité associée (null si aucune)
134 Item item() const { return Item(m_item_internal); }
135 //! Maille associée (null si aucune)
136 Cell cell() const { return Cell(m_item_internal); }
137 //! Face associée (null si aucune)
138 Face face() const { return Face(m_item_internal); }
139
140 protected:
141
142 void _setArray(const Real3* node_ptr,const Real3* face_ptr,const Real3* center_ptr)
144 m_node_ptr = node_ptr;
145 m_face_ptr = face_ptr;
146 m_center_ptr = center_ptr;
148
149 private:
150
151 ARCANE_RESTRICT const Real3* m_node_ptr;
152 ARCANE_RESTRICT const Real3* m_face_ptr;
153 ARCANE_RESTRICT const Real3* m_center_ptr;
154 //! Informations sur la connectivité
155 CellConnectivity* m_cell_connectivity;
156 //! Information sur l'entité d'origine (ItemInternal::nullItem() si aucune)
157 ItemInternal* m_item_internal;
158
159 protected:
160
161 //TODO: A SUPPRIMER
162 const Real3POD* _nodeView() const { return (Real3POD*)m_node_ptr; }
163
164 public:
165
166
167 public:
168 /*!
169 * \name Informations sur la connectivité.
170 */
171 //@{
172 //! Informations de connectivité aux noeuds.
174 {
175 return m_cell_connectivity->nodeConnectic()[i];
176 }
177
178 //! Informations de connectivité aux arêtes.
180 {
181 return m_cell_connectivity->edgeConnectic()[i];
182 }
184 //! Informations de connectivité aux faces
186 {
187 return m_cell_connectivity->faceConnectic()[i];
188 }
189
190 //! Nombre de sous volume de controle
193 return m_cell_connectivity->nbSubZone();
194 }
195
196 //! Nombre de sous faces internes SVC
198 {
199 return m_cell_connectivity->nbSubZoneFace();
201
202 //! Numéro local du sommet associé au sous volume de controle
204 {
205 return m_cell_connectivity->nodeAssociation()[i];
206 }
207
208 const SVCFaceConnectic& svcFaceConnectic(Integer i) const
209 {
210 return m_cell_connectivity->SCVFaceConnectic()[i];
211 }
212
213 //! Numéro locaux dans le sous-volumes de contrôle
215 {
216 return m_cell_connectivity->m_edge_node_sub_zone_id[i];
217 }
218
219 Integer faceNodeSubZoneId(Integer i) const
220 {
221 return m_cell_connectivity->m_face_node_sub_zone_id[i];
222 }
223 //@}
224
225 /*!
226 * \brief Type géométrique de la forme.
227 *
228 * Si la forme est assossiée à une entité (récupérable via item()),
229 * il s'agit aussi du type de l'entité.
231 * Retourne \a GeomType::NullType si l'instance n'est pas initialisée.
232 */
234 {
235 return m_cell_connectivity->cellType();
236 }
237
238 protected:
239
240 void _setItem(Item item)
241 {
242 m_cell_connectivity = global_cell_connectivity[item.type()];
243 m_item_internal = ItemCompatibility::_itemInternal(item);
244 }
245
246 void _setNullItem(int item_type)
247 {
248 m_item_internal = ItemInternal::nullItem();
249 m_cell_connectivity = global_cell_connectivity[item_type];
250 }
251
252 private:
253
254};
255
256/*---------------------------------------------------------------------------*/
257/*---------------------------------------------------------------------------*/
258//TODO: Utiliser des Traits pour le nombre de noeuds et le nom du SVC.
259/*---------------------------------------------------------------------------*/
260/*---------------------------------------------------------------------------*/
261/*!
262 * \ingroup ArcaneGeometric
263 * \brief Vue sur forme géométrique 2D.
264 */
265class GeomShape2DView
267{
268 public:
270 explicit GeomShape2DView(const GeomShapeView& rhs) : GeomShapeView(rhs){}
271};
272
273/*!
274 * \ingroup ArcaneGeometric
275 * \brief Vue sur forme géométrique 3D.
276 */
277class GeomShape3DView
278: public GeomShapeView
279{
280 public:
281 GeomShape3DView(){}
282 explicit GeomShape3DView(const GeomShapeView& rhs) : GeomShapeView(rhs){}
283};
284
285/*---------------------------------------------------------------------------*/
286/*---------------------------------------------------------------------------*/
287
288/*---------------------------------------------------------------------------*/
289/*---------------------------------------------------------------------------*/
290
291#include "arcane/geometric/GeneratedGeomShapeView.h"
292
293/*---------------------------------------------------------------------------*/
294/*---------------------------------------------------------------------------*/
295
296}
298/*---------------------------------------------------------------------------*/
299/*---------------------------------------------------------------------------*/
300
301//! A supprimer à terme
302#include "arcane/geometric/GeomShape.h"
303
304/*---------------------------------------------------------------------------*/
305/*---------------------------------------------------------------------------*/
307#endif
Maille d'un maillage.
Definition Item.h:1191
Face d'une maille.
Definition Item.h:944
Classe de base d'un élément de maillage.
Definition Item.h:83
Classe gérant un vecteur de réel de dimension 3.
Definition Real3.h:132
Informations sur la connectivité d'une maille.
Vue sur forme géométrique 2D.
Vue constante sur une forme géométrique GeomShape.
const EdgeConnectic & edgeConnectic(Integer i) const
Informations de connectivité aux arêtes.
const Real3 node(Integer i) const
Position du ième noeud de la forme.
Integer edgeNodeSubZoneId(Integer i) const
Numéro locaux dans le sous-volumes de contrôle.
const Real3 face(Integer i) const
Position du centre de la ième face de la forme.
GeomType geomType() const
Type géométrique de la forme.
Cell cell() const
Maille associée (null si aucune)
Integer nbSvcFace() const
Nombre de sous faces internes SVC.
ARCANE_DEPRECATED_122 void initFromHexa(HexaElementConstView hexa, GeomShape &geom_cell)
const Real3 edge(Integer i) const
Position du centre de la i-ème arête de la forme.
ARCANE_DEPRECATED_122 void initFromQuad(QuadElementConstView hexa, GeomShape &geom_cell)
Integer nbSubZone() const
Nombre de sous volume de controle.
Face face() const
Face associée (null si aucune)
const Real3 center() const
Position du centre de la forme.
const NodeConnectic & nodeConnectic(Integer i) const
Informations de connectivité aux noeuds.
const FaceConnectic & faceConnectic(Integer i) const
Informations de connectivité aux faces.
void fillSubZoneElement(HexaElementView hexa, Integer i)
Remplit hexa avec les informations du i-ème sous-volume de contrôle.
Integer nodeAssociation(Integer i) const
Numéro local du sommet associé au sous volume de controle.
Item item() const
Entité associée (null si aucune)
Enumération spécifiant le type de polygone ou polyèdre associé à un élément ou une forme géométrique.
Definition GeomType.h:45
Int32 Integer
Type représentant un entier.
Structures de connectique locale des mailles.
Structure de connectique locale.
Structures de connectique locale des mailles.
Structures de connectique locale des mailles et svc.