Arcane  v3.15.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
ItemConnectivityContainerView.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/* ItemConnectivityContainerView.h (C) 2000-2023 */
9/* */
10/* Vues sur les conteneurs contenant les connectivités. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_ITEMCONNECTIVITYCONTAINERVIEW_H
13#define ARCANE_ITEMCONNECTIVITYCONTAINERVIEW_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arccore/base/Span.h"
18
19#include "arcane/ArcaneTypes.h"
20#include "arcane/ItemTypes.h"
21#include "arcane/ItemLocalId.h"
22
23/*---------------------------------------------------------------------------*/
24/*---------------------------------------------------------------------------*/
25
26namespace Arcane::mesh
27{
28class IncrementalItemConnectivityBase;
29}
30
31namespace Arcane
32{
33class ItemInternalConnectivityList;
34
35/*---------------------------------------------------------------------------*/
36/*---------------------------------------------------------------------------*/
43class ARCANE_CORE_EXPORT ItemConnectivityContainerView
44{
45 // Liste des classes qui ont le droit de créer ou de récupérer directement
46 // des instances de cette classe
51 template <typename ItemType1, typename ItemType2>
53
54 private:
55
60 : m_list_data(_list.data())
61 , m_indexes(_indexes.data())
62 , m_nb_connected_items(_nb_connected_item.data())
63 , m_list_data_size(_list.size())
64 , m_nb_item(_nb_connected_item.size())
65 {
66#ifdef ARCANE_CHECK
67 _checkSize( _indexes.size(), _nb_connected_item.size());
68#endif
69 }
70
71 public:
72
78 void checkSame(ItemConnectivityContainerView rhs) const;
79
80 private:
81
83 template <typename ItemType> constexpr ARCCORE_HOST_DEVICE
86 {
87 ARCANE_CHECK_AT(lid.localId(), m_nb_item);
88 Int32 x = m_indexes[lid];
89 ARCANE_CHECK_AT(x, m_list_data_size);
90 auto* p = &m_list_data[x];
91 // TODO: LOCAL_ID_OFFSET
92 return { p, m_nb_connected_items[lid], 0 };
93 }
94
96 template <typename ItemLocalIdType> constexpr ARCCORE_HOST_DEVICE
97 ItemLocalIdType
98 itemId(ItemLocalId lid, Int32 index) const
99 {
100 ARCANE_CHECK_AT(lid.localId(), m_nb_item);
101 Int32 x = m_indexes[lid] + index;
102 ARCANE_CHECK_AT(x, m_list_data_size);
103 return ItemLocalIdType(m_list_data[x]);
104 }
105
107 constexpr ARCCORE_HOST_DEVICE SmallSpan<const Int32>
108 indexes() const { return { m_indexes, m_nb_item }; }
109
111 constexpr ARCCORE_HOST_DEVICE SmallSpan<const Int32>
112 nbConnectedItems() const { return { m_nb_connected_items,m_nb_item }; }
113
115 constexpr ARCCORE_HOST_DEVICE Int32 nbItem() const { return m_nb_item; }
116
117 private:
118
119 const Int32* m_list_data = nullptr;
120 const Int32* m_indexes = nullptr;
121 const Int32* m_nb_connected_items = nullptr;
122 Int32 m_list_data_size = 0;
123 Int32 m_nb_item = 0;
124
125 private:
126
127 void _checkSize(Int32 indexes_size, Int32 nb_connected_item_size);
128};
129
130/*---------------------------------------------------------------------------*/
131/*---------------------------------------------------------------------------*/
132
133} // End namespace Arcane
134
135/*---------------------------------------------------------------------------*/
136/*---------------------------------------------------------------------------*/
137
138#endif
Vue spécialisée sur une connectivité non structurée entre deux entités.
Classe de base d'une vue sur une connectivité non structurée.
Classe de base d'une vue sur une connectivité non structurée.
Vues sur les conteneurs contenant les connectivités. Cette classe permet de rendre opaque en dehors d...
constexpr ARCCORE_HOST_DEVICE Int32 nbItem() const
Nombre d'entités.
constexpr ARCCORE_HOST_DEVICE SmallSpan< const Int32 > nbConnectedItems() const
Tableau du nombre d'entités connectées à une autre entité.
constexpr ARCCORE_HOST_DEVICE SmallSpan< const Int32 > indexes() const
Tableau des indices dans la table de connectivités.
constexpr ARCCORE_HOST_DEVICE ItemLocalIdType itemId(ItemLocalId lid, Int32 index) const
index-ème entité connectée à l'entité de localId() lid
constexpr ARCCORE_HOST_DEVICE ItemLocalIdListViewT< ItemType > itemsIds(ItemLocalId lid) const
Liste des entités connectées à l'entité de localId() lid.
Informations de connectivité, pour une famille d'entité, permettant la transition entre les anciennes...
Index d'un Item dans une variable.
Definition ItemLocalId.h:40
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:149
Classe de base pour les connectivités incrémentales item->item[].
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-