14#include "arcane/utils/NotImplementedException.h"
15#include "arcane/utils/ITraceMng.h"
16#include "arcane/utils/FunctorUtils.h"
17#include "arcane/utils/ArgumentException.h"
18#include "arcane/utils/OStringStream.h"
20#include "arcane/utils/ValueConvert.h"
21#include "arcane/utils/ArraySimdPadder.h"
23#include "arcane/core/IMesh.h"
24#include "arcane/core/IItemFamily.h"
25#include "arcane/core/ItemPrinter.h"
26#include "arcane/core/VariableBuildInfo.h"
27#include "arcane/core/internal/ItemGroupImplInternal.h"
28#include "arcane/core/materials/internal/IMeshMaterialVariableInternal.h"
30#include "arcane/materials/IMeshMaterialVariable.h"
31#include "arcane/materials/CellToAllEnvCellConverter.h"
33#include "arcane/materials/internal/MeshMaterialMng.h"
34#include "arcane/materials/internal/AllEnvData.h"
35#include "arcane/materials/internal/MaterialModifierOperation.h"
36#include "arcane/materials/internal/ConstituentConnectivityList.h"
37#include "arcane/materials/internal/ComponentItemListBuilder.h"
38#include "arcane/materials/internal/AllCellToAllEnvCellContainer.h"
40#include "arcane/accelerator/Scan.h"
57 explicit RecomputeConstituentCellInfos(
RunQueue& q)
78, m_item_internal_data(mmg)
83 m_component_connectivity_list_ref = m_component_connectivity_list->toSourceReference();
98 m_item_internal_data.endCreate();
99 m_component_connectivity_list->endCreate(is_continue);
106_isFullVerbose()
const
115_computeNbEnvAndNbMatPerCell()
122 env->computeNbMatPerCell();
130_computeAndResizeEnvItemsInternal()
134 IMesh* mesh = m_material_mng->mesh();
135 const IItemFamily* cell_family = mesh->cellFamily();
136 ConstArrayView<MeshEnvironment*> true_environments(m_material_mng->trueEnvironments());
138 Integer nb_env = true_environments.size();
141 info(4) <<
"NB_ENV = " << nb_env;
142 for (
const MeshEnvironment* env : true_environments) {
145 info(4) <<
"EnvName=" << cells.name() <<
" nb_env_cell=" << env_nb_cell <<
" nb_mat_cell=" << env->totalNbCellMat();
146 total_env_cell += env_nb_cell;
147 total_mat_cell += env->totalNbCellMat();
151 Int32 max_local_id = cell_family->maxLocalId();
152 info(4) <<
"RESIZE TotalEnvCell=" << total_env_cell
153 <<
" TotalMatCell=" << total_mat_cell
154 <<
" MaxLocalId=" << max_local_id;
159 m_item_internal_data.resizeComponentItemInternals(max_local_id, total_env_cell);
162 Int32 computed_nb_mat = 0;
163 Int32 computed_nb_env = 0;
164 ConstArrayView<Int16> cells_nb_env = m_component_connectivity_list->cellsNbEnvironment();
165 ConstArrayView<Int16> cells_nb_mat = m_component_connectivity_list->cellsNbMaterial();
166 ENUMERATE_ (Cell, icell, cell_family->allItems()) {
167 Int32 lid = icell.itemLocalId();
168 computed_nb_env += cells_nb_env[lid];
169 computed_nb_mat += cells_nb_mat[lid];
171 Int32 computed_size = computed_nb_mat + computed_nb_env;
172 Int32 storage_size = total_mat_cell + total_env_cell;
173 info(4) <<
"storage_size=" << storage_size <<
" computed=" << computed_size
174 <<
" max_local_id=" << max_local_id <<
" internal_nb_mat=" << total_mat_cell <<
" internal_nb_env=" << total_env_cell
175 <<
" computed_nb_mat=" << computed_nb_mat <<
" computed_nb_env=" << computed_nb_env;
176 if (storage_size != computed_size)
177 ARCANE_FATAL(
"BAD STORAGE SIZE internal={0} connectivity={1}", storage_size, computed_size);
191 auto clist = m_component_connectivity_list;
192 clist->removeAllConnectivities();
194 clist->addCellsToEnvironment(env->componentId(), env->cells().view().localIds(), queue);
196 clist->addCellsToMaterial(mat->componentId(), mat->cells().view().localIds(), queue);
204_rebuildMaterialsAndEnvironmentsFromGroups()
207 const bool is_full_verbose = _isFullVerbose();
214 info(4) <<
"ENV_INDEXER (V2) i=" << var_indexer->index() <<
" NB_CELL=" << var_nb_cell <<
" name=" << cells.
name()
215 <<
" index=" << var_indexer->index();
220 if (cells_nb_env[icell.itemLocalId()] > 1)
221 list_builder.addPartialItem(icell.itemLocalId());
224 list_builder.addPureItem(icell.itemLocalId());
227 info() <<
"MAT_NB_MULTIPLE_CELL (V2) mat=" << var_indexer->
name()
228 <<
" nb_in_global=" << list_builder.pureMatVarIndexes().size()
229 <<
" (ids=" << list_builder.pureMatVarIndexes() <<
")"
230 <<
" nb_in_multiple=" << list_builder.partialMatVarIndexes().size()
231 <<
" (ids=" << list_builder.partialLocalIds() <<
")";
235 for (MeshEnvironment* env : true_environments)
236 env->computeItemListForMaterials(*m_component_connectivity_list);
245 IMesh* mesh = m_material_mng->mesh();
246 IItemFamily* cell_family = mesh->cellFamily();
247 CellGroup all_cells = cell_family->allItems();
249 const Int32 max_local_id = cell_family->maxLocalId();
251 SmallSpan<const Int16> cells_nb_env = m_component_connectivity_list->cellsNbEnvironment();
259 bool do_old = (max_local_id != nb_cell);
263 Int32 lid = icell.itemLocalId();
264 Int32 nb_env = cells_nb_env[lid];
265 work_info.env_cell_indexes[lid] = env_cell_index;
266 env_cell_index += nb_env;
272 Accelerator::GenericScanner scanner(work_info.m_queue);
273 SmallSpan<Int32> env_cell_indexes_view(work_info.env_cell_indexes);
274 Accelerator::ScannerSumOperator<Int32> op;
275 scanner.applyExclusive(0, cells_nb_env, env_cell_indexes_view, op, A_FUNCINFO);
287 SmallSpan<const Int16> cells_nb_env = m_component_connectivity_list->cellsNbEnvironment();
290 ComponentItemSharedInfo* all_env_shared_info = m_item_internal_data.allEnvSharedInfo();
292 SmallSpan<Int32> env_cell_indexes_view(work_info.env_cell_indexes);
296 Int16 n = cells_nb_env[lid];
297 matimpl::ConstituentItemBase ref_ii(all_env_shared_info, ConstituentItemIndex(lid));
298 ref_ii._setSuperAndGlobalItem({}, cell_id);
299 ref_ii._setVariableIndex(MatVarIndex(0, lid));
300 ref_ii._setNbSubItem(n);
302 ref_ii._setFirstSubItem(ConstituentItemIndex(env_cell_indexes_view[lid]));
315 RunQueue queue(m_material_mng->runQueue());
322 const Int16 env_id = env->componentId();
326 env->resizeItemsInternal(var_indexer->nbItem());
328 info(4) <<
"COMPUTE (V2) env_cells env=" << env->name() <<
" nb_cell=" << cells.
size()
329 <<
" index=" << var_indexer->index()
336 const bool is_mono_mat = env->isMonoMaterial();
338 work_info.cells_nb_material.
resize(max_local_id);
343 m_component_connectivity_list->fillCellsNbMaterial(local_ids, env_id, cells_nb_mat_view, queue);
347 const Int32 nb_id = matvar_indexes.
size();
348 ComponentItemSharedInfo* env_shared_info = m_item_internal_data.envSharedInfo();
357 Int32 lid = local_ids[z];
358 Int32 pos = current_pos_view[lid];
359 ++current_pos_view[lid];
360 Int16 nb_mat = (is_mono_mat) ? 1 : cells_nb_mat_view[z];
365 env_id_list[z] = cii_pos;
367 ref_ii._setSuperAndGlobalItem(cii_lid,
ItemLocalId(lid));
370 ref_ii._setComponent(env_id);
373 ArraySimdPadder::applySimdPaddingView(env_cells_local_id);
382 env->computeMaterialIndexes(&m_item_internal_data, queue_pool[env->id()]);
401 ComponentCell cc = *icitem;
403 Int32 direct_lid = indexer_local_ids[index];
404 if (matvar_lid != direct_lid)
405 ARCANE_FATAL(
"Incoherent localId() matvar_lid={0} direct_lid={1} index={2}",
406 matvar_lid, direct_lid, index);
433 m_material_mng->incrementTimestamp();
437 Int64 mesh_timestamp = m_material_mng->mesh()->timestamp();
438 info(4) <<
"ForceRecompute NB_VAR_IDX=" << nb_var <<
" compute_all?=" << compute_all
439 <<
" mesh_timestamp=" << mesh_timestamp <<
" current_mesh_timestamp=" << m_current_mesh_timestamp;
442 bool has_mesh_changed = m_current_mesh_timestamp != mesh_timestamp;
443 m_current_mesh_timestamp = mesh_timestamp;
456 if (compute_all || has_mesh_changed)
457 _computeNbEnvAndNbMatPerCell();
459 _computeAndResizeEnvItemsInternal();
461 bool is_full_verbose = _isFullVerbose();
464 _rebuildMaterialsAndEnvironmentsFromGroups();
470 info(4) <<
"FINAL_INDEXER i=" << var_indexer->index() <<
" NB_CELL=" << var_nb_cell <<
" name=" << cells.
name()
471 <<
" index=" << var_indexer->index();
472 if (is_full_verbose) {
474 info(5) <<
"FINAL_INDEXER (V2) name=" << cells.
name() <<
" cells=" << my_array;
475 info(4) <<
"FINAL_MAT_NB_MULTIPLE_CELL (V2) mat=" << var_indexer->
name()
476 <<
" ids=" << var_indexer->matvarIndexes();
480 RunQueue& queue(m_material_mng->runQueue());
484 _computeInfosForAllEnvCells1(work_info);
485 _computeInfosForAllEnvCells2(work_info);
489 if (is_verbose_debug) {
490 _printAllEnvCells(m_material_mng->mesh()->allCells().view());
491 for (
IMeshMaterial* material : m_material_mng->materials()) {
501 env->componentData()->_rebuildPartData(queue);
503 mat->componentData()->_rebuildPartData(queue);
508 m_material_mng->checkValid();
510 m_material_mng->syncVariablesReferences(compute_all);
512 if (is_verbose_debug) {
514 m_material_mng->dumpInfos2(ostr());
515 info() << ostr.str();
524 if (m_material_mng->isCellToAllEnvCellForRunCommand()) {
525 auto* all_cell_to_all_env_cell(m_material_mng->_internalApi()->getAllCellToAllEnvCellContainer());
526 if (all_cell_to_all_env_cell)
527 all_cell_to_all_env_cell->bruteForceUpdate();
529 m_material_mng->_internalApi()->createAllCellToAllEnvCell();
537recomputeIncremental()
541 _checkConnectivityCoherency();
556 <<
" nb_env=" << cells_nb_env[cell.
localId()]
557 <<
" direct_nb_env=" << cell_nb_env;
558 for (
Integer z = 0; z < cell_nb_env; ++z) {
560 Integer cell_nb_mat = ec.nbMaterial();
562 for (
Integer k = 0; k < cell_nb_mat; ++k) {
574_checkConnectivityCoherency()
576 info() <<
"AllEnvData: checkCoherency()";
577 ConstArrayView<Int16> nb_mat_v2 = m_component_connectivity_list->cellsNbMaterial();
578 ConstArrayView<MeshEnvironment*> true_environments(m_material_mng->trueEnvironments());
580 ItemGroup all_cells = m_material_mng->mesh()->allCells();
586 Int32 ref_nb_mat = 0;
587 for (MeshEnvironment* env : true_environments) {
588 Int16 env_id = env->componentId();
589 ref_nb_mat += m_component_connectivity_list->cellNbMaterial(icell, env_id);
591 Int32 current_nb_mat = nb_mat_v2[icell.itemLocalId()];
592 if (ref_nb_mat != current_nb_mat) {
595 error() <<
"Invalid values for nb_material cell=" << icell->uniqueId()
596 <<
" ref=" << ref_nb_mat <<
" current=" << current_nb_mat;
601 ARCANE_FATAL(
"Invalid values for component connectivity nb_error={0}", nb_error);
#define ARCANE_FATAL(...)
Macro envoyant une exception FatalErrorException.
Fonctions de gestion mémoire et des allocateurs.
Types et macros pour gérer les énumérations des entités sur les accélérateurs.
#define RUNCOMMAND_ENUMERATE(ItemTypeName, iter_name, item_group,...)
Macro pour itérer sur accélérateur sur un groupe d'entités.
Types et macros pour gérer les boucles sur les accélérateurs.
#define RUNCOMMAND_LOOP1(iter_name, x1,...)
Boucle sur accélérateur avec arguments supplémentaires pour les réductions.
void barrier() const
Force l'attente de toutes les RunQueue.
File d'exécution pour un accélérateur.
MemoryAllocationOptions allocationOptions() const
Options d'allocation associée à cette file.
void resize(Int64 s)
Change le nombre d'éléments du tableau à s.
ArrayView< T > view() const
Vue mutable sur ce tableau.
Vue constante d'un tableau de type T.
constexpr Integer size() const noexcept
Nombre d'éléments du tableau.
Interface d'une famille d'entités.
virtual Int32 maxLocalId() const =0
virtual CellGroup allCells()=0
Groupe de toutes les mailles.
void notifySimdPaddingDone()
Indique que le padding SIMD des entités à été effectué
SmallSpan< Int32 > itemsLocalId()
Liste des localId() des entités du groupe.
const String & name() const
Nom du groupe.
ItemVectorView view() const
Vue sur les entités du groupe.
Integer size() const
Nombre d'éléments du groupe.
ItemGroupImplInternal * _internalApi() const
API interne à Arcane.
IMesh * mesh() const
Maillage auquel appartient ce groupe (0 pour le group nul)
Index d'un Item dans une variable.
Classe utilitaire pour imprimer les infos sur une entité.
Int32ConstArrayView localIds() const
Tableau des numéros locaux des entités.
constexpr Int32 localId() const
Identifiant local de l'entité dans le sous-domaine du processeur.
Maille arcane avec info matériaux et milieux.
__host__ __device__ Int32 nbEnvironment() const
Nombre de milieux présents dans la maille.
EnvCell cell(Int32 i) const
i-ème maille milieu
void _checkLocalIdsCoherency() const
Vérifie la cohérence des localIds() du variableIndexer(). avec la maille globale associée au milieu.
Int32 m_verbose_debug_level
Niveau de verbosité
void _rebuildIncrementalConnectivitiesFromGroups()
Reconstruit les connectivités incrémentales à parties des groupes.
void endCreate(bool is_continue)
Notification de la fin de création des milieux/matériaux.
void forceRecompute(bool compute_all)
Remise à jour des structures suite à une modification des mailles de matériaux ou de milieux.
void _computeInfosForEnvCells(RecomputeConstituentCellInfos &work_info)
Positionne les infos pour les EnvCell.
Classe d'aide à la construction d'une liste de ComponentItem pour un MeshMaterialVariableIndexer.
Gestion des listes de connectivité des constituants.
Index d'une entité constituant dans la liste des entités constituants.
Cell globalCell() const
Maille globale.
__host__ __device__ MatVarIndex _varIndex() const
Maille arcane d'un milieu.
__host__ __device__ MatCell cell(Integer i) const
i-ème maille matériau de cette maille
__host__ __device__ Int32 environmentId() const
Identifiant du milieu.
Interface d'un matériau d'un maillage.
Représente un matériau d'une maille multi-matériau.
__host__ __device__ Int32 materialId() const
Identifiant du matériau.
Représente un index sur les variables matériaux et milieux.
Implémentation d'un gestion des matériaux.
AllEnvCellVectorView view(const CellGroup &cells) final
Vue sur les mailles milieux correspondant au groupe cells.
Indexer pour les variables materiaux.
void endUpdate(const ComponentItemListBuilderOld &builder)
Fonctions privées mais accessibles aux classes 'friend'.
Integer maxIndexInMultipleArray() const
const String & name() const
Nom de l'indexeur.
Informations génériques sur une entité d'un constituant.
__host__ __device__ void _setVariableIndex(MatVarIndex index)
Positionne l'indexeur dans les variables matériaux.
__host__ __device__ void _setNbSubItem(Int16 nb_sub_item)
Positionne le nombre de sous-composants.
Flot de sortie lié à une String.
Vue d'un tableau d'éléments de type T.
constexpr __host__ __device__ SizeType size() const noexcept
Retourne la taille du tableau.
Vue d'un tableau d'éléments de type T.
TraceAccessor(ITraceMng *m)
Construit un accesseur via le gestionnaire de trace m.
TraceMessage info() const
Flot pour un message d'information.
TraceMessage error() const
Flot pour un message d'erreur.
ITraceMng * traceMng() const
Gestionnaire de trace.
Vecteur 1D de données avec sémantique par valeur (style STL).
ItemGroupT< Cell > CellGroup
Groupe de mailles.
ItemVectorViewT< Cell > CellVectorView
Vue sur un vecteur de mailles.
RunCommand makeCommand(const RunQueue &run_queue)
Créé une commande associée à la file run_queue.
RunQueue makeQueue(const Runner &runner)
Créé une file associée à runner.
Active toujours les traces dans les parties Arcane concernant les matériaux.
Int32 checkResizeArrayWithCapacity(Array< DataType > &array, Int64 new_size, bool force_resize)
Redimensionne un tableau en ajoutant une réserve de mémoire.
bool arcaneIsCheck()
Vrai si on est en mode vérification.
std::int64_t Int64
Type entier signé sur 64 bits.
Int32 Integer
Type représentant un entier.
ConstArrayView< Int32 > Int32ConstArrayView
Equivalent C d'un tableau à une dimension d'entiers 32 bits.
UniqueArray< Int32 > Int32UniqueArray
Tableau dynamique à une dimension d'entiers 32 bits.
std::int16_t Int16
Type entier signé sur 16 bits.
std::int32_t Int32
Type entier signé sur 32 bits.