14#include "arcane/materials/internal/ComponentItemInternalData.h"
18#include "arcane/core/IItemFamily.h"
19#include "arcane/core/internal/IItemFamilyInternal.h"
21#include "arcane/materials/internal/MeshMaterialMng.h"
35MemoryAllocationOptions ComponentItemInternalData::Storage::
36_allocInfo(
const MemoryAllocationOptions& alloc_info,
const String& base_name,
const String& name)
38 MemoryAllocationOptions opts(alloc_info);
39 opts.setArrayName(base_name + name);
46ComponentItemInternalData::Storage::
47Storage(
const MemoryAllocationOptions& alloc_info,
const String& base_name)
48: m_first_sub_constituent_item_id_list(_allocInfo(alloc_info, base_name,
"FirtSubComponentIdList"))
49, m_super_component_item_local_id_list(_allocInfo(alloc_info, base_name,
"SuperComponentIdList"))
50, m_component_id_list(_allocInfo(alloc_info, base_name,
"ComponentIdList"))
51, m_nb_sub_constituent_item_list(_allocInfo(alloc_info, base_name,
"NbSubConstituentItemList"))
52, m_global_item_local_id_list(_allocInfo(alloc_info, base_name,
"GlobalItemLocalIdList"))
53, m_var_index_list(_allocInfo(alloc_info, base_name,
"VarIndexList"))
60void ComponentItemInternalData::Storage::
61resize(Int32 new_size, ComponentItemSharedInfo* shared_info, RunQueue& queue)
66 Int32 true_size = new_size + 1;
69 const bool force_resize =
false;
70 MemoryUtils::checkResizeArrayWithCapacity(m_first_sub_constituent_item_id_list, true_size, force_resize);
71 MemoryUtils::checkResizeArrayWithCapacity(m_super_component_item_local_id_list, true_size, force_resize);
72 MemoryUtils::checkResizeArrayWithCapacity(m_component_id_list, true_size, force_resize);
73 MemoryUtils::checkResizeArrayWithCapacity(m_nb_sub_constituent_item_list, true_size, force_resize);
74 MemoryUtils::checkResizeArrayWithCapacity(m_global_item_local_id_list, true_size, force_resize);
75 MemoryUtils::checkResizeArrayWithCapacity(m_var_index_list, true_size, force_resize);
77 auto first_sub_constituent_item_id_list = m_first_sub_constituent_item_id_list.smallSpan();
78 auto super_component_item_local_id_list = m_super_component_item_local_id_list.smallSpan();
79 auto component_id_list = m_component_id_list.smallSpan();
80 auto nb_sub_constituent_item_list = m_nb_sub_constituent_item_list.smallSpan();
81 auto global_item_local_id_list = m_global_item_local_id_list.smallSpan();
82 auto var_index_list = m_var_index_list.smallSpan();
90 shared_info->m_storage_size = new_size;
91 first_sub_constituent_item_id_list[0] = {};
92 component_id_list[0] = -1;
93 nb_sub_constituent_item_list[0] = 0;
94 global_item_local_id_list[0] = NULL_ITEM_LOCAL_ID;
95 var_index_list[0].reset();
97 shared_info->m_first_sub_constituent_item_id_data = first_sub_constituent_item_id_list.data() + 1;
98 shared_info->m_super_component_item_local_id_data = super_component_item_local_id_list.data() + 1;
99 shared_info->m_component_id_data = component_id_list.data() + 1;
101 shared_info->m_nb_sub_constituent_item_data = nb_sub_constituent_item_list.data() + 1;
102 shared_info->m_global_item_local_id_data = global_item_local_id_list.data() + 1;
103 shared_info->m_var_index_data = var_index_list.data() + 1;
114ComponentItemInternalData::
115ComponentItemInternalData(MeshMaterialMng* mmg)
116: TraceAccessor(mmg->traceMng())
119, m_all_env_storage(_allocOptions(),
"AllEnvStorage")
120, m_env_storage(_allocOptions(),
"EnvStorage")
121, m_mat_storage(_allocOptions(),
"MatStorage")
125 ComponentItemSharedInfo::_setNullInstance();
130 m_shared_infos.resize(3);
131 m_shared_infos.setDebugName(
"ComponentItemInternalDataSharedInfo");
137MemoryAllocationOptions ComponentItemInternalData::
140 return MemoryAllocationOptions(platform::getDefaultDataAllocator());
146void ComponentItemInternalData::
157void ComponentItemInternalData::
163 RunQueue queue(m_material_mng->runQueue());
166 ComponentItemSharedInfo* all_env_shared_info = allEnvSharedInfo();
167 ComponentItemSharedInfo* env_shared_info = envSharedInfo();
168 ComponentItemSharedInfo* mat_shared_info = matSharedInfo();
169 const Int32 all_env_size = m_all_env_storage.size();
170 const Int32 env_size = m_env_storage.size();
171 const Int32 mat_size = m_mat_storage.size();
179 if (i < all_env_size)
180 all_env_shared_info->_reset(cii);
182 env_shared_info->_reset(cii);
184 mat_shared_info->_reset(cii);
192void ComponentItemInternalData::
193resizeComponentItemInternals(
Int32 max_local_id,
Int32 total_nb_env_cell)
195 RunQueue& queue(m_material_mng->runQueue());
197 auto environments = m_material_mng->trueEnvironments();
198 const Int32 nb_env = environments.size();
202 Int32 total_nb_mat_cell = 0;
204 total_nb_mat_cell += env->totalNbCellMat();
208 m_all_env_items_internal_range.setRange(0, max_local_id);
209 m_env_items_internal_range.setRange(0, total_nb_env_cell);
210 Int32 index_in_container = 0;
212 Int32 nb_cell_mat = env->totalNbCellMat();
214 mat_range.setRange(index_in_container, nb_cell_mat);
215 env->setMatInternalDataRange(mat_range);
216 index_in_container += nb_cell_mat;
220 info(4) <<
"ResizeStorage max_local_id=" << max_local_id
221 <<
" total_nb_env_cell=" << total_nb_env_cell
222 <<
" total_nb_mat_cell=" << total_nb_mat_cell;
225 m_all_env_storage.resize(max_local_id, allEnvSharedInfo(), queue);
226 m_env_storage.resize(total_nb_env_cell, envSharedInfo(), queue);
227 m_mat_storage.resize(total_nb_mat_cell, matSharedInfo(), queue);
236void ComponentItemInternalData::
245 ComponentItemSharedInfo* info_mat = sharedInfo(LEVEL_MATERIAL);
246 ComponentItemSharedInfo* info_env = sharedInfo(LEVEL_ENVIRONMENT);
247 ComponentItemSharedInfo* info_all_env = sharedInfo(LEVEL_ALLENVIRONMENT);
249 info_mat->m_level = LEVEL_MATERIAL;
250 info_mat->m_item_shared_info = item_shared_info;
251 info_mat->m_components = m_material_mng->materialsAsComponents();
252 info_mat->m_super_component_item_shared_info = info_env;
254 info_env->m_level = LEVEL_ENVIRONMENT;
255 info_env->m_item_shared_info = item_shared_info;
256 info_env->m_components = m_material_mng->environmentsAsComponents();
257 info_env->m_super_component_item_shared_info = info_all_env;
258 info_env->m_sub_component_item_shared_info = info_mat;
260 info_all_env->m_level = LEVEL_ALLENVIRONMENT;
261 info_all_env->m_item_shared_info = item_shared_info;
263 info_all_env->m_sub_component_item_shared_info = info_env;
264 info() <<
"EndCreate ComponentItemInternalData nb_mat=" << info_mat->m_components.
size()
265 <<
" nb_env=" << info_env->m_components.
size();
266 info() <<
"EndCreate ComponentItemInternalData mat_shared_info=" << info_mat
267 <<
" env_shared_info=" << info_env;
Fonctions de gestion mémoire et des allocateurs.
Types et macros pour gérer les boucles sur les accélérateurs.
#define RUNCOMMAND_SINGLE(...)
Boucle sur accélérateur pour exécution avec un seul thread.
#define RUNCOMMAND_LOOP1(iter_name, x1,...)
Boucle sur accélérateur avec arguments supplémentaires pour les réductions.
Permet de modifier l'asynchronisme de la file pendant la durée de vie de l'instance.
File d'exécution pour un accélérateur.
Vue constante d'un tableau de type T.
constexpr Integer size() const noexcept
Nombre d'éléments du tableau.
virtual ItemSharedInfo * commonItemSharedInfo()=0
Instance de ItemSharedInfo pour les entités de la famille.
Interface d'une famille d'entités.
virtual IMesh * mesh() const =0
Maillage associé
virtual IItemFamilyInternal * _internalApi()=0
API interne à Arcane.
virtual IItemFamily * cellFamily()=0
Retourne la famille des mailles.
Structure interne partagée d'une entité de maillage.
void _resetItemsInternal()
Réinitialise les ComponentItemInternal associés aux EnvCell et AllEnvCell.
Interval des identifiants des constituants dans la liste des ComponentItemInternal.
Index d'une entité constituant dans la liste des entités constituants.
Tableaux multi-dimensionnels pour les types numériques accessibles sur accélérateurs.
TraceMessage info() const
Flot pour un message d'information.
T max(const T &a, const T &b, const T &c)
Retourne le maximum de trois éléments.
RunCommand makeCommand(const RunQueue &run_queue)
Créé une commande associée à la file run_queue.
Active toujours les traces dans les parties Arcane concernant les matériaux.
MemoryAllocationOptions getAllocatorForMostlyReadOnlyData()
Allocateur par défaut pour les données essentiellement en lecture.
bool arcaneIsCheck()
Vrai si on est en mode vérification.
std::int32_t Int32
Type entier signé sur 32 bits.