12#ifndef ARCANE_MESH_MESHEXCHANGER_H
13#define ARCANE_MESH_MESHEXCHANGER_H
17#include "arcane/utils/TraceAccessor.h"
18#include "arcane/utils/List.h"
19#include "arcane/core/IMeshExchanger.h"
20#include "arcane/core/ParallelExchangerOptions.h"
21#include "arcane/core/IMesh.h"
41class ARCANE_MESH_EXPORT MeshExchanger
47 typedef std::map<IItemFamily*,IItemFamilyExchanger*> ItemFamilyExchangerMap;
70 void _setNextPhase(ePhase next_phase);
76 ItemFamilyExchangerMap m_family_exchanger_map;
81 void _checkPhase(ePhase wanted_phase);
82 void _buildWithItemFamilyNetwork();
Échange des entités et leurs caractéristiques pour une famille donnée.
Interface d'une famille d'entités.
Gestion d'un échange de maillage entre sous-domaines.
ePhase
Indique les différentes phases de l'échange.
Interface gérant les statistiques sur les temps d'exécution.
Implémentation d'une collection d'éléments sous forme de vecteur.
Options pour IParallelMng::processExchange().
TraceAccessor(ITraceMng *m)
Construit un accesseur via le gestionnaire de trace m.
void updateVariables() override
Mise à jour des variables.
void processExchange() override
Procède à l'échange des informations entre les sous-domaines.
IItemFamilyExchanger * findExchanger(IItemFamily *family) override
Échangeur associé à la famille family. Lance une exception si non trouvé
void finalizeExchange() override
Finalise les échanges.
void allocateReceivedItems() override
Alloue les entités réceptionnées depuis les autre sous-domaines.
ePhase phase() const override
Phase de l'échange dans laquelle on se trouve.
bool computeExchangeInfos() override
Calcule les infos à envoyer/recevoir des autres sous-domaines.
void updateItemGroups() override
Mise à jour des groupes d'entités.
void removeNeededItems() override
Supprime de ce sous-domaine les entités qui ne doivent plus s'y trouver suite à l'échange.
IPrimaryMesh * mesh() const override
Maillage associé à cet échangeur.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-