14#include "arcane/utils/FatalErrorException.h"
15#include "arcane/utils/ITraceMng.h"
16#include "arcane/utils/StringBuilder.h"
17#include "arcane/utils/ScopedPtr.h"
18#include "arcane/utils/NotImplementedException.h"
19#include "arcane/utils/NotSupportedException.h"
20#include "arcane/utils/ArgumentException.h"
21#include "arcane/utils/CheckedConvert.h"
22#include "arcane/utils/PlatformUtils.h"
23#include "arcane/utils/OStringStream.h"
24#include "arcane/utils/ValueConvert.h"
25#include "arcane/utils/CStringUtils.h"
27#include "arcane/core/IParallelMng.h"
28#include "arcane/core/ISubDomain.h"
29#include "arcane/core/VariableTypes.h"
30#include "arcane/core/IVariableMng.h"
31#include "arcane/core/IVariable.h"
32#include "arcane/core/IMesh.h"
33#include "arcane/core/IMeshSubMeshTransition.h"
34#include "arcane/core/IApplication.h"
35#include "arcane/core/IDataFactoryMng.h"
36#include "arcane/core/ItemInfoListView.h"
37#include "arcane/core/ItemPairGroup.h"
38#include "arcane/core/ItemPairGroupImpl.h"
39#include "arcane/core/IMeshUtilities.h"
40#include "arcane/core/IVariableSynchronizer.h"
41#include "arcane/core/ItemInternalSortFunction.h"
42#include "arcane/core/Properties.h"
43#include "arcane/core/ItemFamilyCompactInfos.h"
44#include "arcane/core/IMeshMng.h"
45#include "arcane/core/IMeshCompacter.h"
46#include "arcane/core/IMeshCompactMng.h"
47#include "arcane/core/MeshPartInfo.h"
48#include "arcane/core/ParallelMngUtils.h"
49#include "arcane/core/internal/IDataInternal.h"
50#include "arcane/core/internal/IItemFamilyInternal.h"
51#include "arcane/core/internal/IIncrementalItemConnectivityInternal.h"
52#include "arcane/core/datatype/IDataOperation.h"
54#include "arcane/mesh/ItemFamily.h"
55#include "arcane/mesh/ItemSharedInfoList.h"
56#include "arcane/mesh/ItemConnectivityInfo.h"
57#include "arcane/mesh/ItemConnectivitySelector.h"
58#include "arcane/mesh/AbstractItemFamilyTopologyModifier.h"
59#include "arcane/mesh/DynamicMeshKindInfos.h"
61#include "arcane/core/parallel/GhostItemsVariableParallelOperation.h"
62#include "arcane/core/parallel/IStat.h"
64#include "arcane/core/IIncrementalItemConnectivity.h"
65#include "arcane/core/IItemConnectivityMng.h"
66#include "arcane/core/IItemFamilyPolicyMng.h"
68#include "arcane/core/ItemPrinter.h"
69#include "arcane/core/ConnectivityItemVector.h"
70#include "arcane/core/IndexedItemConnectivityView.h"
72#include "arcane/mesh/ItemProperty.h"
73#include "arcane/mesh/ItemData.h"
74#include "arcane/mesh/ConnectivityNewWithDependenciesTypes.h"
90 template <
typename DataType>
void
91 _offsetArrayByOne(Array<DataType>* array)
93 Array<DataType>& v = *array;
94 MeshUtils::checkResizeArray(v, v.size() + 1,
false);
96 for (
Int32 i = (n - 1); i >= 1; --i)
110 explicit InternalApi(ItemFamily* family)
118 return m_family->_unstructuredItemInternalConnectivityList();
122 return m_family->_topologyModifier();
126 return m_family->commonItemSharedInfo();
130 m_family->_addSourceConnectivity(connectivity);
134 m_family->_addTargetConnectivity(connectivity);
138 return m_family->_endAllocate();
142 return m_family->_notifyEndUpdateFromMesh();
146 return m_family->_addVariable(var);
150 return m_family->_removeVariable(var);
154 m_family->_resizeShMemVariables();
155 m_family->_resizeVariables(force_resize);
160 ItemFamily* m_family =
nullptr;
171 const String& family_name,
173 const String& shared_data_name,
174 const String& unique_ids_name,
175 const String& items_owner_name,
176 const String& items_flags_name,
177 const String& items_type_id_name,
178 const String& items_nb_parent_name,
179 const String& groups_name,
180 const String& current_id_name,
181 const String& new_owner_name,
182 const String& parent_mesh_name,
183 const String& parent_family_name,
184 const String& parent_family_depth_name,
185 const String& child_meshes_name,
186 const String& child_families_name)
271, m_internal_api(new InternalApi(this))
272, m_sub_domain(
mesh->subDomain())
274, m_item_internal_list(
mesh->meshItemInternalList())
275, m_common_item_shared_info(new
ItemSharedInfo(this, m_item_internal_list, &m_item_connectivity_list))
277, m_used_variables(&_cmpIVariablePtr)
278, m_used_shmem_variables(&_cmpIVariablePtr)
280, m_sub_domain_id(
mesh->meshPartInfo().partRank())
283 m_infos->setItemFamily(
this);
284 m_connectivity_selector_list_by_item_kind.resize(ItemInternalConnectivityList::MAX_ITEM_KIND);
293 delete m_topology_modifier;
296 delete m_local_connectivity_info;
297 delete m_global_connectivity_info;
298 delete m_item_sort_function;
299 delete m_internal_variables;
300 delete m_item_shared_infos;
302 for (ItemConnectivitySelector* ics : m_connectivity_selector_list)
305 delete m_common_item_shared_info;
306 delete m_internal_api;
313_variableName(
const String& base_name)
const
315 return m_name + base_name;
324 m_item_type_mng = m_mesh->itemTypeMng();
328 if (!m_topology_modifier)
329 m_topology_modifier =
new AbstractItemFamilyTopologyModifier(
this);
331 m_full_name = m_mesh->name() +
"_" + m_name;
333 m_local_connectivity_info =
new ItemConnectivityInfo();
334 m_global_connectivity_info =
new ItemConnectivityInfo();
336 IParallelMng* pm = m_mesh->parallelMng();
337 if (!pm->isParallel()) {
338 m_default_sub_domain_owner = 0;
339 m_is_parallel =
false;
342 m_is_parallel =
true;
352 String var_unique_ids_name(_variableName(
"FamilyUniqueIds"));
353 String var_owner_name(_variableName(
"FamilyOwner"));
354 String var_flags_name(_variableName(
"FamilyFlags"));
355 String var_typeid_name(_variableName(
"FamilyItemTypeId"));
356 String var_nb_parent_name(_variableName(
"FamilyItemNbParent"));
357 String var_count_name(_variableName(
"FamilyItemsShared"));
358 String var_groups_name(_variableName(
"FamilyGroupsName"));
359 String var_current_id_name(_variableName(
"FamilyCurrentId"));
360 String var_new_owner_name(_variableName(
"FamilyNewOwnerName"));
361 String var_parent_mesh_name(_variableName(
"ParentMeshName"));
362 String var_parent_family_name(_variableName(
"ParentFamilyName"));
363 String var_parent_family_depth_name(_variableName(
"ParentFamilyDepthName"));
364 String var_child_meshes_name(_variableName(
"ChildMeshesName"));
365 String var_child_families_name(_variableName(
"ChildFamiliesName"));
367 var_unique_ids_name, var_owner_name,
368 var_flags_name, var_typeid_name, var_nb_parent_name, var_groups_name,
369 var_current_id_name, var_new_owner_name,
370 var_parent_mesh_name, var_parent_family_name,
371 var_parent_family_depth_name,
372 var_child_meshes_name,
373 var_child_families_name);
377 m_items_unique_id = &m_internal_variables->m_items_unique_id._internalTrueData()->_internalDeprecatedValue();
378 m_items_owner = &m_internal_variables->m_items_owner._internalTrueData()->_internalDeprecatedValue();
379 m_items_flags = &m_internal_variables->m_items_flags._internalTrueData()->_internalDeprecatedValue();
380 m_items_type_id = &m_internal_variables->m_items_type_id._internalTrueData()->_internalDeprecatedValue();
381 m_items_nb_parent = &m_internal_variables->m_items_nb_parent._internalTrueData()->_internalDeprecatedValue();
384 _addOnSizeChangedObservable(m_internal_variables->m_items_unique_id);
385 _addOnSizeChangedObservable(m_internal_variables->m_items_owner);
386 _addOnSizeChangedObservable(m_internal_variables->m_items_flags);
387 _addOnSizeChangedObservable(m_internal_variables->m_items_type_id);
388 _addOnSizeChangedObservable(m_internal_variables->m_items_nb_parent);
395 m_item_sort_function = _defaultItemSortFunction();
399 if (s ==
"TRUE" || s ==
"1") {
400 info() <<
"WARNING: Using legacy 'compactItem()' without compactReference()'";
401 m_use_legacy_compact_item =
true;
406 m_do_shrink_after_allocate = (v.value() != 0);
416 return m_infos->findOne(uid);
421 return m_infos->itemsMap();
423const DynamicMeshKindInfos& ItemFamily::
429const DynamicMeshKindInfos& ItemFamily::
440 m_infos->removeOne(ItemCompatibility::_itemInternal(item));
445 m_infos->detachOne(ItemCompatibility::_itemInternal(item));
450 return m_infos->itemsInternal();
452ItemInternal* ItemFamily::
453_itemInternal(
Int32 local_id)
455 return m_infos->itemInternal(local_id);
457ItemInternal* ItemFamily::
458_allocOne(
Int64 unique_id)
460 return m_infos->allocOne(unique_id);
462ItemInternal* ItemFamily::
463_allocOne(
Int64 unique_id,
bool& need_alloc)
465 return m_infos->allocOne(unique_id, need_alloc);
467ItemInternal* ItemFamily::
468_findOrAllocOne(
Int64 uid,
bool& is_alloc)
470 return m_infos->findOrAllocOne(uid, is_alloc);
473_setHasUniqueIdMap(
bool v)
475 m_infos->setHasUniqueIdMap(v);
480 m_infos->removeMany(local_ids);
483_removeDetachedOne(Item item)
485 m_infos->removeDetachedOne(ItemCompatibility::_itemInternal(item));
490 return m_infos->kind();
499 return m_infos->nbItem();
508 return m_infos->maxUsedLocalId();
517 return m_infos->itemsInternal();
535 return m_parent_family;
544 m_parent_family = parent;
546 m_parent_family_depth = 1;
548 m_parent_family_depth = 0;
551 m_parent_family->addChildFamily(
this);
553 ARCANE_ASSERT((m_parent_family_depth < 2), (
"Not test if more than one depth level"));
562 return m_parent_family_depth;
572 m_child_families.add(true_family);
582 for (
Integer i = 0; i < m_child_families.size(); ++i) {
583 collection.add(m_child_families[i]);
594 return m_internal_variables->m_items_new_owner;
604 m_item_shared_infos->checkValid();
613 _checkValidConnectivity();
627 _computeConnectivityInfo(m_local_connectivity_info);
628 _computeConnectivityInfo(m_global_connectivity_info);
653 if (!m_parent_family) {
654 m_internal_variables->setUsed();
656 if (m_do_shrink_after_allocate)
657 _shrinkConnectivityAndPrintInfos();
664_shrinkConnectivityAndPrintInfos()
667 ItemConnectivityMemoryInfo mem_info;
668 for (ItemConnectivitySelector* cs : m_connectivity_selector_list) {
669 IIncrementalItemConnectivity* c = cs->customConnectivity();
670 c->_internalApi()->addMemoryInfos(mem_info);
672 const Int64 total_capacity = mem_info.m_total_capacity;
673 const Int64 total_size = mem_info.m_total_size;
674 Int64 ratio = 100 * (total_capacity - total_size);
675 ratio /= (total_size + 1);
677 const Int64 mega_byte = 1024 * 1024;
678 Int64 capacity_mega_byte = (mem_info.m_total_capacity * sizeof_int32) / mega_byte;
679 info() <<
"MemoryUsed for family name=" <<
name() <<
" size=" << mem_info.m_total_size
680 <<
" capacity=" << mem_info.m_total_capacity
681 <<
" capacity (MegaByte)=" << capacity_mega_byte
682 <<
" ratio=" << ratio;
685 std::ostream& o = ostr();
687 for (ItemConnectivitySelector* cs : m_connectivity_selector_list) {
688 IIncrementalItemConnectivity* c = cs->customConnectivity();
691 c->_internalApi()->shrinkMemory();
696 info() << ostr.str();
705 bool need_end_update = m_infos->changed();
706 info(4) <<
"ItemFamily::endUpdate() " <<
fullName() <<
" need_end_update?=" << need_end_update;
707 if (!need_end_update) {
713 if (m_need_prepare_dump) {
714 _computeConnectivityInfo(m_local_connectivity_info);
719 m_item_need_prepare_dump =
true;
720 _computeConnectivityInfo(m_local_connectivity_info);
725 m_connectivity_mng->setModifiedItems(
this, m_infos->addedItems(), m_infos->removedItems());
727 m_infos->finalizeMeshChanged();
736_endUpdate(
bool need_check_remove)
738 _resizeShMemVariables();
739 if (_partialEndUpdate())
742 _resizeVariables(
false);
744 <<
" hashmapsize=" << itemsMap().nbBucket()
745 <<
" nb_group=" << m_item_groups.count();
747 _updateGroups(need_check_remove);
765 _updateGroup(group,
true);
772_updateGroup(
ItemGroup group,
bool need_check_remove)
775 if (group == m_infos->allItems())
780 if (need_check_remove) {
792_updateGroups(
bool need_check_remove)
795 ItemGroup group = *i;
796 _updateGroup(group, need_check_remove);
806 _updateVariable(variable);
822_resizeVariables(
bool force_resize)
826 <<
" nb_item=" <<
nbItem()
827 <<
" currentsize=" << m_current_variable_item_size;
828 if (force_resize || (
maxLocalId() != m_current_variable_item_size)) {
829 info(4) <<
"ItemFamily::resizeVariables: name=" <<
fullName()
831 <<
" nb_item=" <<
nbItem()
832 <<
" currentsize=" << m_current_variable_item_size
834 <<
" nb_var=" << m_used_variables.size();
838 for (
IVariable* var : m_used_variables) {
839 _updateVariable(var);
848_resizeShMemVariables()
850 for (IVariable* var : m_used_shmem_variables) {
851 _updateVariable(var);
859itemsUniqueIdToLocalId(ArrayView<Int64> ids,
bool do_fatal)
const
861 m_infos->itemsUniqueIdToLocalId(ids, do_fatal);
872 m_infos->itemsUniqueIdToLocalId(local_ids, unique_ids, do_fatal);
883 m_infos->itemsUniqueIdToLocalId(local_ids, unique_ids, do_fatal);
919 return m_mesh->parallelMng();
928 _checkNeedEndUpdate();
929 return m_infos->allItems();
938 debug(
Trace::High) <<
"ItemFamily:createGroup(name,Int32ConstArrayView): " << m_name <<
":"
939 <<
" group_name=" <<
name
940 <<
" count=" << elements.
size()
941 <<
" override=" << do_override;
943 _checkNeedEndUpdate();
971 fatal() <<
"Attempting to create an already existing group '" <<
name <<
"'";
974 debug() <<
"ItemFamily:createGroup(name): " << m_name <<
":"
977 _processNewGroup(group);
991 fatal() <<
"Group already existing but with a different parent";
993 fatal() <<
"A group can not be its own parent name=" <<
name;
996 fatal() <<
"Attempting to create an already existing group '" <<
name <<
"'";
999 fatal() <<
"Attempting to create a group '" <<
name <<
"' with no parent.";
1000 debug() <<
"ItemFamily:createGroup(name,parent): " << m_name <<
":"
1002 <<
" parent=" << parent.
name();
1004 _processNewGroup(group);
1014 _invalidateComputedGroups();
1016 m_item_groups.clear();
1020 m_item_groups.add(group);
1033 debug() <<
"ItemFamily::notifyItemsOwnerChanged()";
1040 for (
Integer i = 0; i < m_child_families.size(); ++i) {
1043 for (
Integer z = 0, zs = items.
size(); z < zs; ++z) {
1044 impl::MutableItemBase item(items[z]);
1047 Item parent_item = item.parentBase(0);
1048 ARCANE_ASSERT((parent_item.
uniqueId() == item.
uniqueId()), (
"Inconsistent parent uid"));
1063 ARCANE_FATAL(
"Incoherent family name={0} wanted={1} current={2}",
1066 m_item_groups.add(group);
1067 m_need_prepare_dump =
true;
1071 if (!m_is_parallel && m_mesh->
meshPartInfo().nbPart() == 1)
1081 return m_item_groups;
1090 for (
const ItemGroup& group : m_item_groups) {
1105 if (create_if_needed)
1117 itemsMap().notifyUniqueIdsChanged();
1124_checkNeedEndUpdate()
const
1126 if (m_infos->changed())
1127 ARCANE_FATAL(
"missing call to endUpdate() after modification");
1136 info(4) <<
"ItemFamily::prepareForDump(): " <<
fullName()
1137 <<
" need=" << m_need_prepare_dump
1138 <<
" item-need=" << m_item_need_prepare_dump
1139 <<
" m_item_shared_infos->hasChanged()=" << m_item_shared_infos->hasChanged()
1140 <<
" nb_item=" << m_infos->nbItem();
1143 auto* p = m_properties;
1144 p->setInt32(
"dump-version", 0x0307);
1145 p->setInt32(
"nb-item", m_infos->nbItem());
1150 if (m_item_need_prepare_dump || m_item_shared_infos->hasChanged()) {
1151 info(4) <<
"Prepare for dump:2: name=" << m_name <<
" nb_alloc=" << m_nb_allocate_info
1152 <<
" uid_size=" << m_items_unique_id->size() <<
" cap=" << m_items_unique_id->capacity()
1153 <<
" byte=" << m_items_unique_id->capacity() *
sizeof(
Int64);
1159 m_infos->prepareForDump();
1160 m_item_shared_infos->prepareForDump();
1161 m_need_prepare_dump =
true;
1163 m_item_need_prepare_dump =
false;
1164 if (m_need_prepare_dump) {
1165 Integer nb_item = m_infos->nbItem();
1167 _resizeItemVariables(nb_item,
true);
1170 <<
" saveid=" << m_internal_variables->m_current_id();
1172 m_internal_variables->m_items_shared_data_index.resize(nb_item);
1173 IntegerArrayView items_shared_data_index(m_internal_variables->m_items_shared_data_index);
1174 info(4) <<
"ItemFamily::prepareForDump(): " << m_name
1175 <<
" count=" << nb_item <<
" currentid=" <<
m_current_id;
1178 for (
Integer i = 0; i < nb_item; ++i) {
1184 for (
Integer i = 0; i < nb_item; ++i) {
1187 items_shared_data_index[i] = isi->index();
1191 info() <<
"Item: SHARED_INDEX = " << items_shared_data_index[i]
1193 <<
" lid = " << item->
localId()
1194 <<
" dataindex = " << item->dataIndex()
1195 <<
" flags = " << item->
flags();
1203 if (m_parent_family) {
1204 m_internal_variables->m_parent_family_name = m_parent_family->name();
1205 m_internal_variables->m_parent_mesh_name = m_parent_family->mesh()->name();
1207 m_internal_variables->m_parent_family_depth = m_parent_family_depth;
1208 const Integer child_count = m_child_families.size();
1209 m_internal_variables->m_child_meshes_name.resize(child_count);
1210 m_internal_variables->m_child_families_name.resize(child_count);
1211 for (
Integer i = 0; i < child_count; ++i) {
1212 m_internal_variables->m_child_meshes_name[i] = m_child_families[i]->mesh()->name();
1213 m_internal_variables->m_child_families_name[i] = m_child_families[i]->name();
1228 m_internal_variables->m_groups_name.resize(nb_group_to_save);
1230 Integer current_group_index = 0;
1235 m_internal_variables->m_groups_name[current_group_index] = group.
name();
1236 ++current_group_index;
1245 _applyCheckNeedUpdateOnGroups();
1247 m_need_prepare_dump =
false;
1260 Int32 dump_version = 0;
1265 bool use_type_variable =
false;
1268 auto* p = m_properties;
1269 if (p->get(
"dump-version", x))
1271 if (dump_version >= 0x0307) {
1272 use_type_variable =
true;
1273 nb_item = p->getInt32(
"nb-item");
1274 Int32 cid = p->getInt32(
"current-change-id");
1275 Int32 expected_cid = m_internal_variables->m_current_id();
1276 if (cid != expected_cid)
1277 ARCANE_FATAL(
"Bad value for current id mesh={0} id={1} expected={2}",
1282 const bool allow_old_version =
true;
1283 if (!allow_old_version)
1284 if (dump_version < 0x0307)
1285 ARCANE_FATAL(
"Your checkpoint is from a version of Arcane which is too old (mininum version is 3.7)");
1291 const MeshPartInfo& part_info = m_mesh->meshPartInfo();
1292 m_sub_domain_id = part_info.partRank();
1293 if (m_infos->allItems().isOwn() && part_info.nbPart() > 1)
1294 m_infos->allItems().setOwn(
false);
1303 IntegerArrayView items_shared_data_index(m_internal_variables->m_items_shared_data_index);
1304 if (!use_type_variable)
1305 nb_item = items_shared_data_index.
size();
1307 info(4) <<
"ItemFamily::readFromDump(): " <<
fullName()
1308 <<
" count=" << nb_item
1310 <<
" saveid=" << m_internal_variables->m_current_id()
1311 <<
" use_type_variable?=" << use_type_variable
1312 <<
" dump_version=" << dump_version;
1314 if (!use_type_variable) {
1321 _handleOldCheckpoint();
1325 if (m_internal_variables->m_current_id() ==
m_current_id) {
1326 debug() <<
"Family unchanged. Nothing to do.";
1333 _invalidateComputedGroups();
1340 m_current_variable_item_size = 0;
1344 IMeshMng* mesh_mng = m_mesh->meshMng();
1345 if (!m_internal_variables->m_parent_mesh_name().null()) {
1347 m_parent_family = parent_mesh->
findItemFamily(m_internal_variables->m_parent_family_name(),
true);
1349 m_parent_family_depth = m_internal_variables->m_parent_family_depth();
1350 ARCANE_ASSERT((m_internal_variables->m_child_meshes_name.size() == m_internal_variables->m_child_families_name.size()),
1351 (
"Incompatible child mesh/family sizes"));
1352 Integer child_count = m_internal_variables->m_child_families_name.size();
1353 for (
Integer i = 0; i < child_count; ++i) {
1356 m_child_families.add(
dynamic_cast<ItemFamily*
>(child_family));
1360 m_item_shared_infos->readFromDump();
1361 m_infos->readFromDump();
1366 if (use_type_variable) {
1368 for (
Integer i = 0; i < nb_item; ++i) {
1370 ItemTypeId type_id{ m_common_item_shared_info->m_type_ids[i] };
1372 Int64 uid = m_items_unique_id_view[i];
1374 item->_setSharedInfo(isi->sharedInfo(), type_id);
1379 auto item_shared_infos = m_item_shared_infos->itemSharedInfos();
1380 for (
Integer i = 0; i < nb_item; ++i) {
1381 Integer shared_data_index = items_shared_data_index[i];
1383 Int64 uid = m_items_unique_id_view[i];
1385 item->_setSharedInfo(isi->sharedInfo(), isi->itemTypeId());
1391 m_infos->allItems().clear();
1394 for (
auto& c : m_source_incremental_item_connectivities)
1395 c->notifyReadFromDump();
1401 _invalidateComputedGroups();
1412_applyCheckNeedUpdateOnGroups()
1417 if (group == m_infos->allItems())
1427_invalidateComputedGroups()
1433 ItemGroup group = *i;
1434 if (!group.internal()->parentGroup().null()) {
1451 debug() <<
"ItemFamily::readFromDump(): number of group: " << groups_var.
size();
1452 for (
Integer i = 0, is = groups_var.
size(); i < is; ++i) {
1454 debug() <<
"Readign group again: " <<
name;
1462 for (
ItemGroup& group : m_item_groups) {
1463 group.incrementTimestamp();
1479 if (global_changed != 0)
1499 m_need_prepare_dump =
true;
1507 m_item_need_prepare_dump =
true;
1520 if (!m_use_legacy_compact_item) {
1523 _applyCheckNeedUpdateOnGroups();
1555 m_infos->beginCompactItems(compact_infos);
1558 m_infos->checkValid();
1563 for (
auto& c : m_source_incremental_item_connectivities)
1564 c->notifySourceFamilyLocalIdChanged(new_to_old_ids);
1566 for (
auto& c : m_target_incremental_item_connectivities)
1567 c->notifyTargetFamilyLocalIdChanged(old_to_new_ids);
1570 c->notifySourceFamilyLocalIdChanged(new_to_old_ids);
1573 c->notifyTargetFamilyLocalIdChanged(old_to_new_ids);
1580 if (m_parent_family_depth > 0)
1591finishCompactItems(ItemFamilyCompactInfos& compact_infos)
1594 m_infos->checkValid();
1596 m_infos->finishCompactItems(compact_infos);
1598 for (ItemConnectivitySelector* ics : m_connectivity_selector_list)
1599 ics->compactConnectivities();
1614 ARCANE_ASSERT(source.size() == destination.
size(),
1615 (
"Can't copy. Source and destination have different size !"));
1617 if (source.size() != 0) {
1618 for (
IVariable* var : m_used_variables) {
1625 for (
IVariable* var : m_used_shmem_variables) {
1647 ARCANE_ASSERT(first_source.
size() == destination.
size(),
1648 (
"Can't copy. : first_source and destination have different size !"));
1649 ARCANE_ASSERT(second_source.
size() == destination.
size(),
1650 (
"Can't copy : second_source and destination have different size !"));
1652 if (first_source.
size() != 0) {
1653 for (
IVariable* var : m_used_variables) {
1658 for (
IVariable* var : m_used_shmem_variables) {
1680 for (
IVariable* var : m_used_variables) {
1684 for (
IVariable* var : m_used_shmem_variables) {
1689 m_variable_synchronizer->changeLocalIds(old_to_new_ids);
1699 for (
Integer i = 0; i < m_child_families.size(); ++i)
1704 <<
" nb_item=" <<
nbItem();
1709 m_current_variable_item_size =
nbItem();
1722compactConnectivities()
1727 c->notifySourceFamilyLocalIdChanged(new_to_old_ids);
1730 c->notifyTargetFamilyLocalIdChanged(old_to_new_ids);
1744 if (m_parent_family_depth > 1)
1747 ARCANE_ASSERT((
nbItem() == 0 || !old_to_new_lids.
empty()), (
"Empty oldToNewLocalIds"));
1748 debug() <<
"\tfrom parent family " << m_parent_family->name();
1749 if (
this == m_parent_family)
1752 for (
Integer z = 0, zs = items.
size(); z < zs; ++z) {
1754 Int32 old_parent_lid = item->parentId(0);
1755 item->
setParent(0, old_to_new_lids[old_parent_lid]);
1768 ARCANE_UNUSED(local_ids);
1769 ARCANE_UNUSED(keep_ghost);
1782 if (m_sub_domain_id != part_rank)
1783 ARCANE_FATAL(
"Family {0} Bad value for partRank ({1}) expected={2}",
1784 fullName(), m_sub_domain_id, part_rank);
1792_reserveInfosMemory(
Integer memory)
1794 ARCANE_UNUSED(memory);
1803 ARCANE_UNUSED(new_size);
1812 ARCANE_UNUSED(memory);
1820_findSharedInfo(ItemTypeInfo*
type)
1822 return m_item_shared_infos->findSharedInfo(type);
1832 m_need_prepare_dump =
true;
1839_allocateInfos(ItemInternal* item,
Int64 uid, ItemTypeInfo*
type)
1841 ItemSharedInfoWithType* isi = _findSharedInfo(type);
1842 _allocateInfos(item, uid, isi);
1849_resizeItemVariables(
Int32 new_size,
bool force_resize)
1851 bool is_resize = MeshUtils::checkResizeArray(*m_items_unique_id, new_size + 1, force_resize);
1852 is_resize |= MeshUtils::checkResizeArray(*m_items_owner, new_size + 1, force_resize);
1853 is_resize |= MeshUtils::checkResizeArray(*m_items_flags, new_size + 1, force_resize);
1854 is_resize |= MeshUtils::checkResizeArray(*m_items_type_id, new_size + 1, force_resize);
1855 if (m_parent_family_depth > 0)
1856 is_resize |= MeshUtils::checkResizeArray(*m_items_nb_parent, new_size, force_resize);
1862 (*m_items_unique_id)[0] = NULL_ITEM_UNIQUE_ID;
1863 (*m_items_flags)[0] = 0;
1864 (*m_items_owner)[0] = A_NULL_RANK;
1865 (*m_items_type_id)[0] = IT_NullType;
1876 Int32 local_id = item->localId();
1877 _resizeItemVariables(local_id + 1,
false);
1882 ItemTypeId iti = isi->itemTypeId();
1883 item->_setSharedInfo(isi->sharedInfo(), iti);
1885 item->reinitialize(uid, m_default_sub_domain_owner, m_sub_domain_id);
1886 ++m_nb_allocate_info;
1888 for (
auto& c : m_source_incremental_item_connectivities)
1889 c->notifySourceItemAdded(ItemLocalId(local_id));
1896_preAllocate(
Int32 nb_item,
bool pre_alloc_connectivity)
1899 m_infos->itemsMap().resize(nb_item,
true);
1900 _resizeItemVariables(nb_item,
false);
1901 for (
auto& c : m_source_incremental_item_connectivities)
1902 c->reserveMemoryForNbSourceItems(nb_item, pre_alloc_connectivity);
1909_notifyDataIndexChanged()
1923 sub_domains.
copy(ranks);
1936 if (m_is_parallel && m_mesh->meshPartInfo().nbPart() ==
parallelMng()->commSize()) {
1937 m_variable_synchronizer->compute();
1975 return &m_items_unique_id_view;
1991 if (!var && throw_exception) {
2019 info() <<
"ItemFamily::checkUniqueIds name=" <<
name() <<
" n=" << nb_item
2020 <<
" total=" << all_unique_ids.
size();
2021 for (
Integer i = 0; i < nb_item; ++i)
2022 items_map.
add(unique_ids[i], 0);
2023 for (
Integer i = 0, is = all_unique_ids.
size(); i < is; ++i) {
2028 for (
Integer i = 0; i < nb_item; ++i) {
2029 Integer nb_ref = items_map[unique_ids[i]];
2031 fatal() <<
"Duplicate unique_id=" << unique_ids[i];
2051 auto i = m_adjacency_groups.find(at);
2053 if (i == m_adjacency_groups.end()) {
2054 debug() <<
"** BUILD ADJENCY_ITEMS : " << group.
name() <<
" x "
2055 << sub_group.
name() <<
" link=" << link_kind <<
" nblayer=" << layer;
2058 m_adjacency_groups.insert(std::make_pair(at, v));
2061 debug() <<
"** FOUND KNOWN ADJENCY_ITEMS! : " << group.
name() <<
" x "
2062 << sub_group.
name() <<
" link=" << link_kind <<
" nblayer=" << layer;
2072 return m_local_connectivity_info;
2081 return m_global_connectivity_info;
2129 ARCANE_FATAL(
"Can not add a variable to a different family");
2132 m_used_shmem_variables.insert(var);
2134 m_used_variables.insert(var);
2145 m_used_shmem_variables.erase(var);
2147 m_used_variables.erase(var);
2156 for(
IVariable* var : m_used_variables ){
2157 collection.add(var);
2159 for (
IVariable* var : m_used_shmem_variables) {
2160 collection.add(var);
2170 return m_variable_synchronizer.get();
2179 if (m_item_sort_function==sort_function)
2181 delete m_item_sort_function;
2182 m_item_sort_function = sort_function;
2183 if (!m_item_sort_function)
2184 m_item_sort_function = _defaultItemSortFunction();
2193 return m_item_sort_function;
2202 m_variable_synchronizer->synchronize(variables);
2211 m_variable_synchronizer->synchronize(variables, local_ids);
2220 ARCANE_UNUSED(unique_ids);
2221 ARCANE_UNUSED(items);
2222 ARCANE_UNUSED(owners);
2233 ARCANE_FATAL(
"Family name='{0}': IMesh::itemFamilyNetwork() is null",
name());
2242 for (
auto child_connectivity : child_connectivities) {
2243 child_families.
add(child_connectivity->targetFamily());
2245 if (child_families_to_current_family.
back() ==
nullptr)
fatal() <<
"removeItems2 needs reverse connectivity. Missing Connectivity " << connectivityName(child_families.
back(),
this);
2247 child_families_has_extra_parent_properties.
back().resize(child_families.
back(),
false);
2248 for (
auto parent_connectivity : m_mesh->
itemFamilyNetwork()->getParentDependencies(child_families.
back())) {
2249 if (parent_connectivity == child_connectivity)
continue;
2251 _getConnectedItems(parent_connectivity,connected_items);
2252 _fillHasExtraParentProperty(child_families_has_extra_parent_properties[index],connected_items);
2258 for (
auto removed_item_lid_int64 : removed_item_lids) {
2259 Int32 removed_item_lid = CheckedConvert::toInt32(removed_item_lid_int64);
2261 for (
auto child_connectivity : child_connectivities) {
2262 ConnectivityItemVector child_con_accessor(child_connectivity);
2263 ENUMERATE_ITEM(connected_item, child_con_accessor.connectedItems(ItemLocalId(removed_item_lid))) {
2264 if (!this->
itemsInternal()[removed_item_lid]->isDetached()) {
2265 child_families_to_current_family[index]->removeConnectedItem(ItemLocalId(connected_item),ItemLocalId(removed_item_lid));
2268 if (! child_families_has_extra_parent_properties[index][connected_item] && child_families_to_current_family[index]->nbConnectedItem(ItemLocalId(connected_item)) == 0) {
2269 item_data_list[child_connectivity->targetFamily()->itemKind()].itemInfos().add((
Int64) connected_item.localId());
2277 for (
auto removed_item_lid_int64 : removed_item_lids) {
2278 Int32 removed_item_lid = CheckedConvert::toInt32(removed_item_lid_int64);
2279 for (
auto child_relation : m_mesh->itemFamilyNetwork()->getChildRelations(
this)) {
2280 ConnectivityItemVector connectivity_accessor(child_relation);
2281 ENUMERATE_ITEM(connected_item, connectivity_accessor.connectedItems(ItemLocalId(removed_item_lid))) {
2282 child_relation->removeConnectedItem(ItemLocalId(removed_item_lid),ItemLocalId(connected_item));
2287 ItemScalarProperty<bool> is_removed_item;
2288 is_removed_item.resize(
this,
false);
2289 for (
auto removed_item_lid_int64 : removed_item_lids) {
2290 Int32 removed_item_lid = CheckedConvert::toInt32(removed_item_lid_int64);
2291 is_removed_item[*(this->
itemsInternal()[removed_item_lid])] =
true;
2293 for (
auto parent_relation : m_mesh->itemFamilyNetwork()->getParentRelations(
this)) {
2294 for (
auto source_item : parent_relation->sourceFamily()->itemsInternal()) {
2295 if (source_item->isSuppressed())
continue;
2296 ConnectivityItemVector connectivity_accessor(parent_relation);
2297 ENUMERATE_ITEM(connected_item, connectivity_accessor.connectedItems(ItemLocalId(source_item))) {
2298 if (is_removed_item[connected_item])
2299 parent_relation->removeConnectedItem(ItemLocalId(source_item),connected_item);
2304 for (
auto removed_item_lid_int64 : removed_item_lids) {
2305 Int32 removed_item_lid = CheckedConvert::toInt32(removed_item_lid_int64);
2306 ItemInternal* removed_item = m_infos->itemInternal(removed_item_lid);
2307 if (removed_item->isDetached()) {
2308 m_infos->removeDetachedOne(removed_item);
2311 m_infos->removeOne(removed_item);
2321_getConnectedItems(IIncrementalItemConnectivity* parent_connectivity,ItemVector& target_family_connected_items)
2323 ConnectivityItemVector connectivity_accessor(parent_connectivity);
2324 for(
auto source_item : parent_connectivity->sourceFamily()->itemsInternal()) {
2325 if (source_item->isSuppressed())
continue;
2326 target_family_connected_items.add(connectivity_accessor.connectedItems(ItemLocalId(source_item)).localIds());
2334_fillHasExtraParentProperty(ItemScalarProperty<bool>& child_families_has_extra_parent,ItemVectorView connected_items)
2337 child_families_has_extra_parent[connected_item] =
true;
2348 ARCANE_ASSERT((m_mesh->itemFamilyNetwork()->getParentDependencies(
this).empty()),(
"Only cells are detached, no parent dependencies are to be found."))
2351 for (auto removed_item_lid : local_ids) {
2352 for (
auto child_relation : m_mesh->itemFamilyNetwork()->getChildRelations(
this)) {
2353 ConnectivityItemVector connectivity_accessor(child_relation);
2354 ENUMERATE_ITEM(connected_item, connectivity_accessor.connectedItems(ItemLocalId(removed_item_lid))) {
2355 child_relation->removeConnectedItem(ItemLocalId(removed_item_lid),ItemLocalId(connected_item));
2360 ItemScalarProperty<bool> is_detached_item;
2361 is_detached_item.resize(
this,
false);
2362 for (
auto detached_item_lid : local_ids) {
2363 is_detached_item[*(this->itemsInternal()[detached_item_lid])] =
true;
2365 for (
auto parent_relation : m_mesh->itemFamilyNetwork()->getParentRelations(
this)) {
2366 for(auto source_item : parent_relation->sourceFamily()->itemsInternal()) {
2367 if (source_item->isSuppressed()) continue;
2368 ConnectivityItemVector connectivity_accessor(parent_relation);
2369 ENUMERATE_ITEM(connected_item, connectivity_accessor.connectedItems(ItemLocalId(source_item))) {
2370 if (is_detached_item[connected_item]) {
2371 parent_relation->removeConnectedItem(ItemLocalId(source_item),connected_item);
2377 for (
auto detached_item_lid : local_ids) {
2378 m_infos->detachOne(m_infos->itemInternal(detached_item_lid));
2386removeNeedRemoveMarkedItems()
2388 ItemInternalMap& item_map = itemsMap();
2389 if (item_map.
count()==0)
2392 if (!m_mesh->itemFamilyNetwork())
2393 ARCANE_FATAL(
"Family name='{0}': IMesh::itemFamilyNetwork() is null",
name());
2394 if (!IItemFamilyNetwork::plug_serializer)
2395 ARCANE_FATAL(
"family name='{0}': removeNeedMarkedItems() cannot be called if ItemFamilyNetwork is unplugged.",
name());
2399 items_to_remove.
reserve(1000);
2400 items_to_remove_lids.
reserve(1000);
2402 item_map.
eachItem([&](impl::ItemBase item) {
2407 items_to_remove.
add(item._itemInternal());
2411 info() <<
"Number of " <<
itemKind() <<
" of family "<<
name()<<
" to remove: " << items_to_remove.
size();
2412 if (items_to_remove.
size() == 0)
2418 is_removed_item.resize(
this,
false);
2419 for (
auto removed_item: items_to_remove) {
2420 is_removed_item[*removed_item] =
true;
2423 for (
auto parent_connectivity : m_mesh->itemFamilyNetwork()->getParentRelations(
this)) {
2424 for(
auto source_item : parent_connectivity->sourceFamily()->itemsInternal()) {
2425 if (source_item->isSuppressed())
continue;
2428 if (is_removed_item[connected_item]) {
2429 parent_connectivity->removeConnectedItem(
ItemLocalId(source_item),connected_item);
2435 m_infos->removeMany(items_to_remove_lids);
2462_defaultItemSortFunction()
2473 if (m_policy_mng==policy_mng)
2477 m_policy_mng = policy_mng;
2484addSourceConnectivity(IItemConnectivity* connectivity)
2486 m_source_item_connectivities.insert(connectivity);
2495 m_target_item_connectivities.insert(connectivity);
2504 m_source_item_connectivities.erase(m_source_item_connectivities.find(connectivity));
2513 m_target_item_connectivities.erase(m_target_item_connectivities.find(connectivity));
2522 ARCANE_ASSERT((m_connectivity_mng == NULL || m_connectivity_mng== connectivity_mng),
2523 (
"Connectivity Manager must be unique") )
2524 m_connectivity_mng = connectivity_mng;
2533 return m_infos->itemListChangedEvent();
2544 if (old_uid==unique_id)
2547 iitem->setUniqueId(unique_id);
2549 if (m_infos->hasUniqueIdMap()){
2550 ItemInternalMap& item_map = itemsMap();
2551 item_map.
remove(old_uid);
2552 item_map.
add(unique_id,iitem);
2578_checkValidConnectivity()
2585 ARCANE_FATAL(
"family={0}: local item lid={1} is null",fullName(),item);
2593 Item i2 = m_common_item_shared_info->m_items_internal[item.localId()];
2595 ARCANE_FATAL(
"family={0}: incoherent item internal lid={1} i1={2} i2={3}",
2599 constexpr Int32 MAX_KIND = ItemInternalConnectivityList::MAX_ITEM_KIND;
2600 std::array<Int32,MAX_KIND> computed_max;
2601 computed_max.fill(0);
2603 for(
Integer i=0; i<MAX_KIND; ++i ){
2606 Int32 stored_max_nb = m_item_connectivity_list.maxNbConnectedItem(i);
2607 const Int32 con_nb_item_size = con_view.nbSourceItem();
2609 info(4) <<
"Family name=" << fullName() <<
" I=" << i <<
" nb_item_size=" << con_nb_item_size;
2612 if (con_nb_item_size!=0){
2617 Int32 x = con_view.nbItem(i);
2621 if (stored_max_nb<max_nb)
2622 ARCANE_FATAL(
"Bad value for max connected item family={0} kind={1} stored={2} computed={3}",
2623 name(),i,stored_max_nb,max_nb);
2624 computed_max[i] = max_nb;
2630 std::array<Int32,MAX_KIND> stored_max;
2632 auto* ci = m_local_connectivity_info;
2633 stored_max[ItemInternalConnectivityList::NODE_IDX] = ci->maxNodePerItem();
2634 stored_max[ItemInternalConnectivityList::EDGE_IDX] = ci->maxEdgePerItem();
2635 stored_max[ItemInternalConnectivityList::FACE_IDX] = ci->maxFacePerItem();
2636 stored_max[ItemInternalConnectivityList::CELL_IDX] = ci->maxCellPerItem();
2639 stored_max[ItemInternalConnectivityList::HPARENT_IDX] = computed_max[ItemInternalConnectivityList::HPARENT_IDX];
2640 stored_max[ItemInternalConnectivityList::HCHILD_IDX] = computed_max[ItemInternalConnectivityList::HCHILD_IDX];
2641 for(
Integer i=0; i<MAX_KIND; ++i )
2642 if (stored_max[i]<computed_max[i])
2643 ARCANE_FATAL(
"Bad value for local_connectivity_info family={0} kind={1} stored={2} computed={3}",
2644 name(),i,stored_max[i],computed_max[i]);
2646 for(
auto ics : m_connectivity_selector_list )
2647 ics->checkValidConnectivityList();
2654_addConnectivitySelector(ItemConnectivitySelector* selector)
2656 m_connectivity_selector_list.add(selector);
2663_buildConnectivitySelectors()
2665 m_connectivity_selector_list_by_item_kind.clear();
2666 m_connectivity_selector_list_by_item_kind.resize(ItemInternalConnectivityList::MAX_ITEM_KIND);
2667 m_connectivity_selector_list_by_item_kind.fill(
nullptr);
2669 for( ItemConnectivitySelector* ics : m_connectivity_selector_list ){
2671 Int32 i = ics->itemConnectivityIndex();
2673 if (m_connectivity_selector_list_by_item_kind[i])
2674 ARCANE_FATAL(
"Can not have two connectivity selector for same item kind");
2675 m_connectivity_selector_list_by_item_kind[i] = ics;
2686 delete m_topology_modifier;
2687 m_topology_modifier = tm;
2700_updateItemsSharedFlag()
2709 for(
Integer i=0; i<nb_rank; ++i ){
2711 for(
auto id : shared_ids )
2722 ici->fill(itemInternalConnectivityList());
2723 info(5) <<
"COMPUTE CONNECTIVITY INFO family=" << name() <<
" v=" << ici
2732_handleOldCheckpoint()
2736 _offsetArrayByOne(m_items_unique_id);
2737 _offsetArrayByOne(m_items_flags);
2738 _offsetArrayByOne(m_items_owner);
2739 (*m_items_unique_id)[0] = NULL_ITEM_UNIQUE_ID;
2740 (*m_items_flags)[0] = 0;
2741 (*m_items_owner)[0] = A_NULL_RANK;
2751template<
typename DataType>
2752ArrayView<DataType> _getView(Array<DataType>* v)
2754 Int32 n = v->size();
2755 return v->subView(1,n-1);
2763 m_common_item_shared_info->m_unique_ids = _getView(m_items_unique_id);
2764 m_common_item_shared_info->m_flags = _getView(m_items_flags);
2765 m_common_item_shared_info->m_type_ids = _getView(m_items_type_id);
2766 m_common_item_shared_info->m_owners = _getView(m_items_owner);
2767 m_common_item_shared_info->m_parent_item_ids = m_items_nb_parent->view();
2769 m_items_unique_id_view = _getView(m_items_unique_id);
2778 m_observers.addObserver(
this,&ItemFamily::_updateItemViews,
2779 var_ref.variable()->onSizeChangedObservable());
2788 return m_internal_api;
#define ARCANE_CHECK_POINTER(ptr)
Macro retournant le pointeur ptr s'il est non nul ou lancant une exception s'il est nul.
#define ARCANE_THROW(exception_class,...)
Macro pour envoyer une exception avec formattage.
#define ARCANE_FATAL(...)
Macro envoyant une exception FatalErrorException.
bool checkResizeArray(Array< DataType > &array, Int64 new_size, bool force_resize)
Redimensionne un tableau qui est indexé par des 'ItemLocalId'.
Integer size() const
Nombre d'éléments du vecteur.
Exception lorsqu'un argument est invalide.
constexpr Integer size() const noexcept
Retourne la taille du tableau.
void resize(Int64 s)
Change le nombre d'éléments du tableau à s.
void reserve(Int64 new_capacity)
Réserve le mémoire pour new_capacity éléments.
void copy(Span< const T > rhs)
Copie les valeurs de rhs dans l'instance.
ArrayView< T > view() const
Vue mutable sur ce tableau.
void add(ConstReferenceType val)
Ajoute l'élément val à la fin du tableau.
T & back()
Dernier élément du tableau.
Gère la récupération des informations de connectivité.
ItemVectorView connectedItems(ItemLocalId item)
Retourne les entités connectées à item.
Vue constante d'un tableau de type T.
constexpr Integer size() const noexcept
Nombre d'éléments du tableau.
constexpr bool empty() const noexcept
true si le tableau est vide (size()==0)
static ARCCORE_BASE_EXPORT std::optional< Int32 > tryParseFromEnvironment(StringView s, bool throw_if_invalid)
Classe gérant les observateurs associés à un évènement.
Table de hachage pour tableaux associatifs.
Data * lookup(KeyTypeConstRef id)
Recherche la valeur correspondant à la clé id.
bool add(KeyTypeConstRef id, const ValueType &value)
Ajoute la valeur value correspondant à la clé id.
virtual IDataOperation * createDataOperation(Parallel::eReduceType rt)=0
Créé une opération effectuant une réduction de type rt.
Interface d'une opération sur une donnée.
Interface de la source d'une connectivité incrémentale.
virtual Ref< IIncrementalItemSourceConnectivity > toSourceReference()=0
Retourne une référence sur l'instance.
Interface de la cible d'une connectivité incrémentale.
virtual Ref< IIncrementalItemTargetConnectivity > toTargetReference()=0
Retourne une référence sur l'instance.
Interface des informations sur la connectivité par type d'entité.
virtual void notifyLocalIdChanged(IItemFamily *item_family, Int32ConstArrayView old_to_new_ids, Integer nb_item)=0
Mise à jour des items modifiés éventuellement compactés.
Interface pour gérer une connectivité.
Partie interne de IItemFamily.
virtual IIncrementalItemConnectivity * getConnectivity(IItemFamily *source_family, IItemFamily *target_family, const String &name)=0
Retourne la connectivité entre les familles source_family et target_family de nom name,...
virtual SharedArray< IIncrementalItemConnectivity * > getChildDependencies(IItemFamily *source_family)=0
Obtenir la liste de toutes les dépendances, filles d'une famille source_family ou parentes d'une fami...
Interface des politiques d'une famille d'entités.
Interface de modification de la topologie des entités d'une famille.
Interface d'une famille d'entités.
virtual Integer parentFamilyDepth() const =0
Donne la profondeur d'imbrication du maillage courant.
virtual ItemInternalArrayView itemsInternal()=0
Tableau interne des entités.
virtual void notifyItemsOwnerChanged()=0
Notifie que les entités propres au sous-domaine de la famille ont été modifiées.
Interface d'une fonction de tri des entités.
virtual String name() const =0
Nom du maillage.
virtual IItemFamily * findItemFamily(eItemKind ik, const String &name, bool create_if_needed=false, bool register_modifier_if_created=false)=0
Retourne la famille de nom name.
Interface du gestionnaire des compactages de familles d'un maillage.
virtual void endCompact()=0
Signale que le compactage est terminé.
virtual IMeshCompacter * beginCompact()=0
Débute un compactage sur toutes les familles du maillage.
Gestion d'un compactage de familles du maillage.
virtual void setSorted(bool v)=0
Indique s'il faut trier les entités lors du compactage.
virtual void doAllActions()=0
Exécute successivement toutes les actions de compactage.
Interface du gestionnaire des maillages.
virtual MeshHandle * findMeshHandle(const String &name, bool throw_exception)=0
Recherche le maillage de nom name.
virtual void computeAdjacency(const ItemPairGroup &adjacency_array, eItemKind link_kind, Integer nb_layer)
Calcul des adjacences, rangées dans adjacency_array.
virtual IMeshUtilities * utilities()=0
Interface des fonctions utilitaires associée.
virtual ItemTypeMng * itemTypeMng() const =0
Gestionnaire de types d'entités associé
virtual IItemFamilyNetwork * itemFamilyNetwork()=0
Interface du réseau de familles (familles connectées)
virtual IMeshCompactMng * _compactMng()=0
virtual const MeshPartInfo & meshPartInfo() const =0
Informations sur les parties du maillage.
Interface du gestionnaire de parallélisme pour un sous-domaine.
virtual void allGatherVariable(ConstArrayView< char > send_buf, Array< char > &recv_buf)=0
Effectue un regroupement sur tous les processeurs.
virtual char reduce(eReduceType rt, char v)=0
Effectue la réduction de type rt sur le réel v et retourne la valeur.
Interface du gestionnaire d'un sous-domaine.
virtual IVariableMng * variableMng()=0
Retourne le gestionnaire de variables.
Interface du gestionnaire de traces.
Interface du gestionnaire de variables.
virtual IVariable * findVariableFullyQualified(const String &name)=0
Retourne la variable de nom complet name ou 0 si aucune de se nom existe.
Interface d'un service de synchronisation de variable.
virtual void changeLocalIds(Int32ConstArrayView old_to_new_ids)=0
Appelé lorsque les numéros locaux des entités sont modifiés.
Interface d'une variable.
virtual String fullName() const =0
Nom complet de la variable (avec le préfixe de la famille)
@ PSubDomainDepend
Indique que la valeur de la variable est dépendante du sous-domaine.
@ PTemporary
Indique que la variable est temporaire.
@ PInShMem
Indique que la variable doit être alloué en mémoire partagée.
@ PExecutionDepend
Indique que la valeur de la variable est dépendante de l'exécution.
@ PPrivate
Indique que la variable est privée.
@ PNoRestore
Indique que la variable ne doit pas être restaurée.
@ PNoDump
Indique que la variable ne doit pas être sauvegardée.
virtual int property() const =0
Retourne les propriétés de la variable.
virtual IDataFactoryMng * dataFactoryMng() const =0
Fabrique de données associées à la variable.
virtual void resizeFromGroup()=0
Positionne le nombre d'éléments pour une variable du maillage.
virtual ItemGroup itemGroup() const =0
Groupe du maillage associé.
virtual void compact(Int32ConstArrayView new_to_old_ids)=0
Compacte les valeurs de la variable.
virtual void copyItemsMeanValues(Int32ConstArrayView first_source, Int32ConstArrayView second_source, Int32ConstArrayView destination)=0
Copie les moyennes des valeurs des entités numéros first_source et second_source dans les entités num...
virtual IItemFamily * itemFamily() const =0
Famille d'entité associée.
virtual String name() const =0
Nom de la variable.
virtual void copyItemsValues(Int32ConstArrayView source, Int32ConstArrayView destination)=0
Copie les valeurs des entités numéros source dans les entités numéro destination.
Classe de base d'une vue sur une connectivité non structurée.
bool isSuppressed() const
Vrai si l'entité est supprimée.
ItemUniqueId uniqueId() const
Numéro unique de l'entité
MutableItemBase toMutable()
Interface modifiable de cette entité
Int32 flags() const
Flags de l'entité
ItemTypeInfo * typeInfo() const
Type de l'entité.
Int32 localId() const
Numéro local (au sous-domaine) de l'entité
Informations pour gérer le compactage des entités d'une famille.
Int32ConstArrayView newToOldLocalIds() const
Conversion entre les nouveaux et les anciens id locaux.
Int32ConstArrayView oldToNewLocalIds() const
Conversion entre les anciens et les nouveaux id locaux.
Arguments de l'évènement pour l'ajout ou la supression d'entités.
Flags pour les caractéristiques des entités.
@ II_NeedRemove
L'entité doit être supprimé
@ II_Shared
L'entité est partagée par un autre sous-domaine.
@ II_Suppressed
L'entité vient d'être supprimée.
Implémentation d'un groupe d'entités de maillage.
bool checkNeedUpdate()
Réactualise le groupe si nécessaire.
void destroy()
Détruit le groupe. Après cet appel, le groupe devient un groupe nul.
void removeSuppressedItems()
Supprime du groupe les entités dont le flag isSuppressed() est vrai.
bool hasComputeFunctor() const
Indique si le groupe est calculé
ItemGroup parentGroup()
Groupe parent.
void changeIds(Int32ConstArrayView old_to_new_ids)
Change les indices des entités du groupe.
Groupe d'entités de maillage.
ItemGroupImpl * internal() const
Retourne l'implémentation du groupe.
IVariableSynchronizer * synchronizer() const
Synchronizer du groupe.
const String & name() const
Nom du groupe.
bool isLocalToSubDomain() const
Vrai si le groupe est local au sous-domaine.
void invalidate(bool force_recompute=false)
Invalide le groupe.
ItemVectorView view() const
Vue sur les entités du groupe.
Integer size() const
Nombre d'éléments du groupe.
IItemFamily * itemFamily() const
Famille d'entité à laquelle appartient ce groupe (0 pour le group nul)
void setItems(Int32ConstArrayView items_local_id)
Positionne les entités du groupe.
eItemKind itemKind() const
Genre du groupe. Il s'agit du genre de ses éléments.
bool hasSynchronizer() const
Indique si le groupe possède un synchroniser actif.
bool isAllItems() const
Indique si le groupe est celui de toutes les entités.
void checkValid()
Vérification interne de la validité du groupe.
bool null() const
true is le groupe est le groupe nul
void setOwn(bool v)
Positionne la propriété de groupe local ou non.
Vue sur une liste pour obtenir des informations sur les entités.
Informations de connectivité, pour une famille d'entité, permettant la transition entre les anciennes...
Interface d'une fonction de tri des entités.
Structure interne d'une entité de maillage.
Index d'un Item dans une variable.
Implémentation d'un tableau de listes d'entités.
Tableau de listes d'entités.
Classe utilitaire pour imprimer les infos sur une entité.
Structure interne partagée d'une entité de maillage.
Type d'une entité (Item).
Gestionnaire des types d'entités d'un maillage.
ItemTypeInfo * typeFromId(Integer id) const
Type correspondant au numéro id.
Identifiant unique d'une entité.
Vue sur un vecteur d'entités.
Classe de base d'un élément de maillage.
Int32 owner() const
Numéro du sous-domaine propriétaire de l'entité
ItemUniqueId uniqueId() const
Identifiant unique sur tous les domaines.
Implémentation d'une collection d'éléments sous forme de vecteur.
ListEnumeratorT< ItemGroup > Enumerator
IMesh * mesh() const
Maillage associé.
Informations un maillage partitionné.
void setOwner(Integer suid, Int32 current_sub_domain)
Positionne le numéro du sous-domaine propriétaire de l'entité.
void setFlags(Int32 f)
Positionne les flags de l'entité
void setParent(Int32 aindex, Int32 parent_local_id)
Positionne le i-ème parent (actuellement aindex doit valoir 0)
Exception lorsqu'une fonction n'est pas implémentée.
Exception lorsqu'une opération n'est pas supportée.
Opérations parallèle sur les entités fantômes.
void applyOperation(IDataOperation *operation) override
Applique l'opération.
void addVariable(IVariable *variable) override
Ajoute variable à la liste des variables concernées par l'opération.
void setItemFamily(IItemFamily *family) override
Positionne la famille d'entité sur laquelle on souhaite opérer.
T * get() const
Retourne l'objet référé par l'instance.
Encapsulation d'un pointeur qui se détruit automatiquement.
Vecteur 1D de données avec sémantique par référence.
Constructeur de chaîne de caractère unicode.
String toString() const
Retourne la chaîne de caractères construite.
Chaîne de caractères unicode.
const char * localstr() const
Retourne la conversion de l'instance dans l'encodage UTF-8.
Classe d'accès aux traces.
TraceMessageDbg debug(Trace::eDebugLevel=Trace::Medium) const
Flot pour un message de debug.
TraceMessage fatal() const
Flot pour un message d'erreur fatale.
TraceMessage info() const
Flot pour un message d'information.
ITraceMng * traceMng() const
Gestionnaire de trace.
Vecteur 1D de données avec sémantique par valeur (style STL).
Paramètres nécessaires à la construction d'une variable.
Référence à une variable.
IVariable * variable() const
Variable associée.
Infos de maillage pour un genre donné d'entité.
Informations sur la connectivité par type d'entité.
Integer maxNodePerItem() const override
Nombre maximal de noeuds par entité
Integer maxCellPerItem() const override
Nombre maximal de mailles par entité
Integer maxFacePerItem() const override
Nombre maximal de faces par entité
Integer maxEdgePerItem() const override
Nombre maximal d'arêtes par entité
void resizeVariables(bool force_resize) override
Redimensionne les variables de cette famille.
void removeVariable(IVariable *var) override
Supprime une variable à cette famille.
void notifyEndUpdateFromMesh() override
Indique une fin de modification par le maillage.
ItemInternalConnectivityList * unstructuredItemInternalConnectivityList() override
Informations sur les connectivités non structurés.
void addVariable(IVariable *var) override
Ajoute une variable à cette famille.
void endAllocate() override
Indique une fin d'allocation.
ItemSharedInfo * commonItemSharedInfo() override
Instance de ItemSharedInfo pour les entités de la famille.
IItemFamilyTopologyModifier * topologyModifier() override
Interface du modificateur de topologie.
VariableArrayInt64 m_items_unique_id
Contient les uniqueIds() des entités de cette famille.
VariableArrayInteger m_items_shared_data_index
Indice dans le tableau des ItemSharedInfo pour chaque entité.
VariableArrayInt32 m_items_flags
Contient les flags() des entités de cette famille.
VariableArrayInt16 m_items_type_id
Contient les typeId() des entités de cette famille.
VariableArrayInt32 m_items_owner
Contient les owner() des entités de cette famille.
VariableItemInt32 m_items_new_owner
Contient le sous-domaine propriétaire de l'entité.
VariableArrayInt32 m_items_nb_parent
Contient le parent() des entités de cette famille.
bool hasUniqueIdMap() const override
Indique si la famille possède une table de conversion uniqueId vers localId.
IMesh * mesh() const override
Maillage associé
void partialEndUpdateVariable(IVariable *variable) override
Met à jour une variable.
void _compactItems(bool do_sort)
Compacte les entités.
void partialEndUpdate() override
Mise à jour partielle.
String fullName() const override
Nom complet de la famille (avec celui du maillage)
void _compactFromParentFamily(const ItemFamilyCompactInfos &compact_infos)
Compacte les connectivités.
void _checkComputeSynchronizeInfos(Int32 changed)
Test collectif permettant de savoir s'il faut mettre à jour les infos de synchro.
void _compactOnlyItems(bool do_sort)
Compacte les entités sans mise à jour des références.
EventObservableView< const ItemFamilyItemListChangedEventArgs & > itemListChangedEvent() override
Evènement pour l'ajout et la suppression d'entité
void clearItems() override
Supprime toutes les entités de la famille.
ItemPairGroup findAdjencyItems(const ItemGroup &group, const ItemGroup &sub_group, eItemKind link_kind, Integer layer) override
Cherche une liste d'adjacence.
void destroyGroups() override
Supprime tous les groupes de cette famille.
void prepareForDump() override
Prépare les données pour une protection.
ItemInternalConnectivityList m_item_connectivity_list
Accesseur pour les connectivités via Item et ItemInternal.
void addChildFamily(IItemFamily *family) override
Ajoute d'une famile en dépendance.
void checkValid() override
Vérification de la validité des structures internes (interne)
ItemInternal * findOneItem(Int64 uid) override
Entité de numéro unique unique_id.
IParallelMng * parallelMng() const override
Gestionnaire de parallélisme associé
void endUpdate() override
Notifie la fin de modification de la liste des entités.
void compactVariablesAndGroups(const ItemFamilyCompactInfos &compact_infos)
Compacte les variables et les groupes.
void usedVariables(VariableCollection collection) override
Ajoute à la collection collection la liste des variables utilisés de cette famille.
ITraceMng * traceMng() const override
Gestionnaire de trace associé
ItemGroup createGroup(const String &name, Int32ConstArrayView elements, bool do_override=false) override
Créé un groupe d'entités de nom name contenant les entités local_ids.
eItemKind itemKind() const override
Genre des entités.
Integer m_current_id
Identifiant de la famille.
VariableItemInt32 & itemsNewOwner() override
Variable contenant le numéro du nouveau sous-domaine propriétaire de l'entité.
void copyItemsValues(Int32ConstArrayView source, Int32ConstArrayView destination) override
void copyItemsMeanValues(Int32ConstArrayView first_source, Int32ConstArrayView second_source, Int32ConstArrayView destination) override
ItemGroup allItems() const override
Groupe de toutes les entités.
void internalRemoveItems(Int32ConstArrayView local_ids, bool keep_ghost=false) override
Supprime les entités donnés par local_ids.
void addGhostItems(Int64ConstArrayView unique_ids, Int32ArrayView items, Int32ConstArrayView owners) override
Alloue des entités fantômes.
void getCommunicatingSubDomains(Int32Array &sub_domains) const override
Liste des sous-domaines communiquants pour les entités.
void reduceFromGhostItems(IVariable *v, IDataOperation *operation) override
Applique une opération de réduction depuis les entités fantômes.
ItemConnectivitySet m_target_item_connectivities
connectivite ou ItemFamily == SourceFamily
IItemFamily * parentFamily() const override
IItemFamily parent.
void setHasUniqueIdMap(bool v) override
Indique si la famille possède une table de conversion uniqueId vers localId.
ItemInfoListView itemInfoListView() override
Vue sur la liste d'informations sur les entités.
static bool _cmpIVariablePtr(const IVariable *a, const IVariable *b)
Fonction permettant de comparer deux noms de variable (strcmp).
void setParentFamily(IItemFamily *parent) override
Positionne l'IItemFamily parent.
void compactItems(bool do_sort) override
Compacte les entités.
Integer nbItem() const override
Nombre d'entités.
void notifyItemsUniqueIdChanged() override
Notifie que les numéros uniques des entités ont été modifiées.
ItemVectorView view() override
Vue sur toutes les entités de la famille.
void synchronize(VariableCollection variables) override
Synchronise les variables variables.
ItemPairGroup findAdjacencyItems(const ItemGroup &group, const ItemGroup &sub_group, eItemKind link_kind, Integer layer) override
Cherche une liste d'adjacence.
ItemInternalList itemsInternal() override
Tableau interne des entités.
void computeSynchronizeInfos() override
Construit les structures nécessaires à la synchronisation.
void checkValidConnectivity() override
Vérification de la validité des structures internes concernant la connectivité.
void _updateItemsSharedFlag()
Positionne les infos Item::isShared() pour les entités de la famille.
IVariable * findVariable(const String &name, bool throw_exception) override
Recherche la variable de nom name associée à cette famille.
void _readGroups()
Relit les groupes depuis une protection et les recréer si besoin.
Int32 maxLocalId() const override
void setItemSortFunction(IItemInternalSortFunction *sort_function) override
Positionne la fonction de tri des entités.
IItemInternalSortFunction * itemSortFunction() const override
Fonction de tri des entités.
ISubDomain * subDomain() const override
Sous-domaine associé
virtual void _notifyEndUpdateFromMesh()
IVariableSynchronizer * allItemsSynchronizer() override
Synchroniseur sur toutes les entités de la famille.
void notifyItemsOwnerChanged() override
Notifie que les entités propres au sous-domaine de la famille ont été modifiées.
Integer parentFamilyDepth() const override
Donne la profondeur d'imbrication du maillage courant.
ItemGroupCollection groups() const override
Liste des groupes de cette famille.
IItemConnectivityMng * m_connectivity_mng
connectivite ou ItemFamily == TargetFamily
IItemConnectivityInfo * localConnectivityInfos() const override
Informations sur la connectivité locale au sous-domaine pour à cette famille.
IItemFamilyCollection childFamilies() override
Familles enfantes de cette famille.
void partialEndUpdateGroup(const ItemGroup &group) override
Met à jour un groupe.
IItemConnectivityInfo * globalConnectivityInfos() const override
Informations sur la connectivité globales à tous les sous-domaines.
void checkUniqueIds(Int64ConstArrayView unique_ids) override
Vérifie que les identifiants unique_ids sont bien uniques pour tous les sous-domaines.
ItemGroup findGroup(const String &name) const override
Recherche un groupe.
void readFromDump() override
Relit les données à partir d'une protection.
String name() const override
Nom de la famille.
Tableau associatif de ItemInternal.
void remove(Int64 key)
Supprime la valeur associée à la clé key.
void eachItem(const Lambda &lambda)
Fonction template pour itérer sur les entités de l'instance.
bool add(Int64 key, ItemInternal *v)
Ajoute la valeur v correspondant à la clé key.
Int32 count() const
Nombre d'éléments de la table.
Infos de maillage pour un genre donné d'entité.
Classe temporaire pour conserver un ItemSharedInfo et un type d'entité.
VariableRefArrayT< Int32 > VariableArrayInt32
Variable tableau de type entier 32 bits.
VariableRefArrayT< Int64 > VariableArrayInt64
Variable tableau de type entier 64 bits.
VariableRefArrayT< Int16 > VariableArrayInt16
Variable tableau de type entier 16 bits.
VariableRefScalarT< String > VariableScalarString
Variable scalaire de type chaine de caractère.
VariableRefArrayT< Integer > VariableArrayInteger
Variable tableau de type entier.
VariableRefArrayT< String > VariableArrayString
Variable tableau de type chaîne de caractères.
ItemVariableScalarRefT< Int32 > VariableItemInt32
Grandeur de type entier 32 bits.
VariableRefScalarT< Integer > VariableScalarInteger
Variable scalaire de type entier.
bool isLess(const char *s1, const char *s2)
Retourne true si s1 est inférieur (ordre alphabétique) à s2 , false sinon.
eReduceType
Types des réductions supportées.
@ ReduceMax
Maximum des valeurs.
Ref< IVariableSynchronizer > createSynchronizerRef(IParallelMng *pm, IItemFamily *family)
Retourne une interface pour synchroniser des variables sur le groupe de la famille family.
ArrayView< Int64 > Int64ArrayView
Equivalent C d'un tableau à une dimension d'entiers 64 bits.
bool arcaneIsCheck()
Vrai si on est en mode vérification.
UniqueArray< Int64 > Int64UniqueArray
Tableau dynamique à une dimension d'entiers 64 bits.
Collection< ItemGroup > ItemGroupCollection
Collection de groupes d'éléments du maillage.
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.
List< ItemGroup > ItemGroupList
Tableau de groupes d'éléments du maillage.
ArrayView< Integer > IntegerArrayView
Equivalent C d'un tableau à une dimension d'entiers.
ConstArrayView< ItemInternal * > ItemInternalList
Type de la liste interne des entités.
Collection< IItemFamily * > IItemFamilyCollection
Collection de familles d'entités.
ConstArrayView< Int64 > Int64ConstArrayView
Equivalent C d'un tableau à une dimension d'entiers 64 bits.
ArrayView< Int32 > Int32ArrayView
Equivalent C d'un tableau à une dimension d'entiers 32 bits.
eItemKind
Genre d'entité de maillage.
Array< Int32 > Int32Array
Tableau dynamique à une dimension d'entiers 32 bits.
std::int32_t Int32
Type entier signé sur 32 bits.