14#include "arccore/base/ReferenceCounter.h"
16#include "arccore/message_passing/PointToPointMessageInfo.h"
18#include "arcane/utils/Collection.h"
19#include "arcane/utils/ITraceMng.h"
20#include "arcane/utils/NotImplementedException.h"
21#include "arcane/utils/Real2.h"
22#include "arcane/utils/Real2x2.h"
23#include "arcane/utils/Real3.h"
24#include "arcane/utils/Real3x3.h"
25#include "arcane/utils/HPReal.h"
26#include "arcane/utils/NullThreadMng.h"
27#include "arcane/utils/ArgumentException.h"
29#include "arcane/core/IIOMng.h"
30#include "arcane/core/ISubDomain.h"
31#include "arcane/core/IApplication.h"
32#include "arcane/core/IParallelDispatch.h"
33#include "arcane/core/ParallelMngDispatcher.h"
34#include "arcane/core/ItemGroup.h"
35#include "arcane/core/IMesh.h"
36#include "arcane/core/IItemFamily.h"
37#include "arcane/core/MeshVariable.h"
38#include "arcane/core/Timer.h"
39#include "arcane/core/FactoryService.h"
40#include "arcane/core/AbstractService.h"
41#include "arcane/core/ISerializer.h"
42#include "arcane/core/internal/SerializeMessage.h"
43#include "arcane/core/internal/ParallelMngInternal.h"
44#include "arcane/core/internal/DynamicMachineMemoryWindowMemoryAllocator.h"
46#include "arcane/parallel/IStat.h"
48#include "arcane/impl/TimerMng.h"
49#include "arcane/impl/GetVariablesValuesParallelOperation.h"
50#include "arcane/impl/ParallelExchanger.h"
51#include "arcane/impl/ParallelTopology.h"
52#include "arcane/impl/ParallelReplication.h"
53#include "arcane/impl/SequentialParallelSuperMng.h"
54#include "arcane/impl/SequentialParallelMng.h"
55#include "arcane/impl/internal/ParallelMngUtilsFactoryBase.h"
56#include "arcane/impl/internal/VariableSynchronizer.h"
58#include "arccore/message_passing/RequestListBase.h"
59#include "arccore/message_passing/internal/SerializeMessageList.h"
60#include "arccore/message_passing/internal/IMachineMemoryWindowBaseInternal.h"
61#include "arccore/message_passing/internal/IDynamicMachineMemoryWindowBaseInternal.h"
82:
public RequestListBase
87 ARCANE_UNUSED(wait_mode);
97class SequentialParallelDispatchT
106 SequentialParallelDispatchT(
ITraceMng* tm)
108 void finalize()
override {}
112 ARCANE_UNUSED(send_buf);
117 ARCANE_UNUSED(send_buf);
122 recv_buf.
copy(send_buf);
126 recv_buf.
copy(send_buf);
131 recv_buf.
copy(send_buf);
136 recv_buf.
copy(send_buf);
141 recv_buf.
copy(send_buf);
146 recv_buf.
copy(send_buf);
150 gatherVariable(send_buf,recv_buf,0);
154 gatherVariable(send_buf,recv_buf,0);
159 recv_buf.resize(send_buf.
size());
166 recv_buf.resize(send_buf.
size());
172 ARCANE_UNUSED(count);
173 recv_buf.
copy(send_buf);
177 ARCANE_UNUSED(count);
178 recv_buf.
copy(send_buf);
187 ARCANE_UNUSED(send_count);
188 ARCANE_UNUSED(recv_count);
189 ARCANE_UNUSED(send_index);
190 ARCANE_UNUSED(recv_index);
191 recv_buf.
copy(send_buf);
200 ARCANE_UNUSED(send_count);
201 ARCANE_UNUSED(recv_count);
202 ARCANE_UNUSED(send_index);
203 ARCANE_UNUSED(recv_index);
204 recv_buf.
copy(send_buf);
212 ARCANE_UNUSED(send_buffer);
218 Request send(
Span<const Type> send_buffer,
const PointToPointMessageInfo& message)
override
220 ARCANE_UNUSED(send_buffer);
227 return receive(
Span<Type>(recv_buffer),rank,is_blocked);
231 ARCANE_UNUSED(send_buffer);
237 ARCANE_UNUSED(recv_buffer);
241 Request receive(
Span<Type> recv_buffer,
Int32 rank,
bool is_blocked)
override
243 ARCANE_UNUSED(recv_buffer);
249 Request receive(
Span<Type> recv_buffer,
const PointToPointMessageInfo& message)
override
251 ARCANE_UNUSED(recv_buffer);
259 recv_buffer.
copy(send_buffer);
261 Type allReduce(eReduceType op,
Type v)
override
269 ARCANE_UNUSED(send_buf);
271 void allReduce(eReduceType op,
Span<Type> send_buf)
override
274 ARCANE_UNUSED(send_buf);
279 ARCANE_UNUSED(send_buf);
280 ARCANE_UNUSED(recv_buf);
285 recv_buf.
copy(send_buf);
290 ARCANE_UNUSED(send_buf);
297 recv_buf.
copy(send_buf);
302 ARCANE_UNUSED(count);
303 recv_buf.
copy(send_buf);
310 ARCANE_UNUSED(send_count);
311 ARCANE_UNUSED(recv_count);
312 ARCANE_UNUSED(send_index);
313 ARCANE_UNUSED(recv_index);
314 recv_buf.
copy(send_buf);
317 Type scan(eReduceType op,
Type v)
override
325 ARCANE_UNUSED(send_buf);
329 Int32& max_rank)
override
331 min_val = max_val = sum_val = val;
332 min_rank = max_rank = 0;
343 min_values[i] = max_values[i] = sum_values[i] = values[i];
344 min_ranks[i] = max_ranks[i] = 0;
353class SequentialMachineMemoryWindowBaseInternal
358 SequentialMachineMemoryWindowBaseInternal(
Int64 sizeof_segment,
Int32 sizeof_type)
359 : m_sizeof_segment(sizeof_segment)
360 , m_max_sizeof_segment(sizeof_segment)
361 , m_sizeof_type(sizeof_type)
362 , m_segment(sizeof_segment)
365 ~SequentialMachineMemoryWindowBaseInternal()
override =
default;
371 return m_sizeof_type;
376 return m_segment.span().
subSpan(0, m_sizeof_segment);
381 ARCANE_FATAL(
"Rank {0} is unavailable (Sequential)", rank);
383 return m_segment.span().
subSpan(0, m_sizeof_segment);
387 return m_segment.span().
subSpan(0, m_sizeof_segment);
392 return m_segment.constSpan().
subSpan(0, m_sizeof_segment);
397 ARCANE_FATAL(
"Rank {0} is unavailable (Sequential)", rank);
399 return m_segment.constSpan().
subSpan(0, m_sizeof_segment);
403 return m_segment.constSpan().
subSpan(0, m_sizeof_segment);
408 if (new_sizeof_segment > m_max_sizeof_segment) {
409 ARCANE_FATAL(
"New size of window (sum of size of all segments) is superior than the old size");
411 m_sizeof_segment = new_sizeof_segment;
423 Int64 m_sizeof_segment = 0;
424 Int64 m_max_sizeof_segment = 0;
426 Int32 m_sizeof_type = 0;
434class SequentialDynamicMachineMemoryWindowBaseInternal
439 SequentialDynamicMachineMemoryWindowBaseInternal(
Int64 sizeof_segment,
Int32 sizeof_type)
440 : m_sizeof_type(sizeof_type)
441 , m_segment(sizeof_segment)
443 ~SequentialDynamicMachineMemoryWindowBaseInternal()
override =
default;
449 return m_sizeof_type;
464 ARCANE_FATAL(
"Rank {0} is unavailable (Sequential)", rank);
475 ARCANE_FATAL(
"Rank {0} is unavailable (Sequential)", rank);
481 if (elem.
size() % m_sizeof_type != 0) {
484 m_segment.addRange(elem);
490 ARCANE_FATAL(
"Rank {0} is unavailable (Sequential)", rank);
492 if (elem.
size() % m_sizeof_type != 0) {
495 m_segment.addRange(elem);
501 m_segment.reserve(new_capacity);
506 m_segment.resize(new_size);
538 return makeRef(createNullVariableSynchronizer(pm,group));
550class SequentialParallelMng
551:
public ParallelMngDispatcher
561 ~SequentialParallelMng();
571 void setBaseObject(
IBase* m);
586 recv_serializer->
copy(send_serializer);
590 ARCANE_UNUSED(values);
595 ARCANE_UNUSED(values);
597 ARCANE_UNUSED(bytes);
607 ARCANE_UNUSED(values);
616 void broadcastString(
String& str,
Int32 rank)
override
623 ARCANE_UNUSED(bytes);
628 ARCANE_UNUSED(values);
633 ARCANE_UNUSED(message);
638 ARCANE_UNUSED(message);
643 ARCANE_UNUSED(values);
644 ARCANE_UNUSED(message);
649 ARCANE_UNUSED(values);
650 ARCANE_UNUSED(message);
656 ARCANE_UNUSED(messages);
660 ARCANE_UNUSED(requests);
671 ARCANE_UNUSED(requests);
677 ARCANE_UNUSED(requests);
710 return createNullVariableSynchronizer(
this,family->
allItems());
714 return createNullVariableSynchronizer(
this,group);
725 return m_replication;
730 delete m_replication;
742 return m_utils_factory;
750 void build()
override;
777 ARCANE_UNUSED(kept_ranks);
778 SequentialParallelMngBuildInfo bi(m_timer_mng,m_world_parallel_mng);
779 bi.setThreadMng(m_thread_mng);
780 bi.setTraceMng(m_trace.get());
781 bi.setCommunicator(m_communicator);
787 ReferenceCounter<ITraceMng> m_trace;
788 IThreadMng* m_thread_mng =
nullptr;
789 ITimerMng* m_timer_mng =
nullptr;
790 IParallelMng* m_world_parallel_mng =
nullptr;
792 Parallel::IStat* m_stat;
793 IParallelReplication* m_replication;
794 MP::Communicator m_communicator;
795 Ref<IParallelMngUtilsFactory> m_utils_factory;
796 IParallelMngInternal* m_parallel_mng_internal =
nullptr;
811 return SequentialParallelMng::create(bi);
816 return SequentialParallelMng::createRef(bi);
823:
public ParallelMngInternal
827 explicit Impl(SequentialParallelMng* pm)
828 : ParallelMngInternal(pm)
832 ~Impl()
override =
default;
848 return m_alloc.get();
859SequentialParallelMng::
862, m_trace(bi.traceMng())
863, m_thread_mng(bi.threadMng())
864, m_timer_mng(bi.m_timer_mng)
865, m_world_parallel_mng(bi.m_world_parallel_mng)
869, m_communicator(bi.communicator())
871, m_parallel_mng_internal(new Impl(this))
873 ARCANE_CHECK_PTR(m_trace);
874 ARCANE_CHECK_PTR(m_thread_mng);
875 if (!m_world_parallel_mng)
876 m_world_parallel_mng =
this;
878 _messagePassingMng()->setCommunicator(m_communicator);
884SequentialParallelMng::
885~SequentialParallelMng()
887 delete m_parallel_mng_internal;
889 delete m_replication;
896void SequentialParallelMng::
897setBaseObject(IBase* sd)
911 DispatchCreator(ITraceMng* tm) : m_tm(tm){}
913 template<
typename DataType> SequentialParallelDispatchT<DataType>*
916 return new SequentialParallelDispatchT<DataType>(m_tm);
925 m_io_mng = arcaneCreateIOMng(
this);
926 DispatchCreator creator(m_trace.get());
927 this->createDispatchers(creator);
946SequentialParallelSuperMng::
949, m_application(sbi.application())
951, m_timer_mng(nullptr)
959SequentialParallelSuperMng::
962, m_application(sbi.application())
964, m_timer_mng(nullptr)
965, m_communicator(comm)
973SequentialParallelSuperMng::
974~SequentialParallelSuperMng()
991 _setDispatchers(c,i32,i64,r);
1002 m_timer_mng = m_owned_timer_mng.get();
1019 return SequentialParallelMng::createRef(bi);
1039class SequentialParallelMngBuilder
1046 ~SequentialParallelMngBuilder()
override
1049 delete m_thread_mng;
1075 bi.setThreadMng(m_thread_mng);
1076 bi.setCommunicator(m_communicator);
1077 return arcaneCreateSequentialParallelMngRef(bi);
1083class SequentialParallelMngContainerFactory
1094 ARCANE_UNUSED(nb_rank);
1095 ARCANE_UNUSED(machine_comm);
#define ARCANE_THROW(exception_class,...)
Macro pour envoyer une exception avec formattage.
#define ARCANE_FATAL(...)
Macro envoyant une exception FatalErrorException.
#define ARCCORE_FATAL(...)
Macro envoyant une exception FatalErrorException.
#define ARCANE_SERVICE_INTERFACE(ainterface)
Macro pour déclarer une interface lors de l'enregistrement d'un service.
#define ARCANE_REGISTER_APPLICATION_FACTORY(aclass, ainterface, aname)
Enregistre un service de fabrique pour la classe aclass.
Classe de base d'un service.
AbstractService(const ServiceBuildInfo &)
Constructeur à partir d'un ServiceBuildInfo.
Exception lorsqu'un argument est invalide.
Vue modifiable d'un tableau d'un type T.
void copy(const U ©_array)
Recopie le tableau copy_array dans l'instance.
constexpr Integer size() const noexcept
Retourne la taille du tableau.
Tableau d'items de types quelconques.
Vue constante d'un tableau de type T.
constexpr Integer size() const noexcept
Nombre d'éléments du tableau.
Opérations pour accéder aux valeurs de variables d'un autre sous-domaine.
Interface de l'application.
Interface de la classe de base des objets principaux arcane.
virtual ITraceMng * traceMng() const =0
Gestionnaire de traces.
Opérations pour accéder aux valeurs de variables d'un autre sous-domaine.
Interface du gestionnaire des entrées sorties.
Interface d'une famille d'entités.
virtual ItemGroup allItems() const =0
Groupe de toutes les entités.
Interface d'un allocateur pour la mémoire.
Gestion des messages parallèles pour le type Type.
Échange d'informations entre processeurs.
Interface d'une fabrique de conteneur de 'IParallelMng'.
Partie interne de IParallelMng.
Interface d'une fabrique pour les fonctions utilitaires de IParallelMng.
Interface du gestionnaire de parallélisme pour un sous-domaine.
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 des opérations parallèles collectives non bloquantes.
Informations sur la réplication des sous-domaines en parallèle.
Classe abstraite du superviseur de parallélisme.
Informations sur la topologie d'allocation des coeurs de calcul.
Interface d'un sérialiseur.
virtual void copy(const ISerializer *from)=0
Copie les données de from dans cette instance.
Interface d'un gestionnaire de thread.
Interface d'un gestionnaire de timer.
Interface du gestionnaire de traces.
virtual TraceMessage info()=0
Flot pour un message d'information.
Envoie de valeurs sur différents processeurs.
Interface d'un service de synchronisation de variable.
Groupe d'entités de maillage.
Communicateur pour l'échange de message.
Classe permettant de créer des fenêtres mémoires pour un noeud de calcul.
Classe permettant de créer une fenêtre mémoire pour un noeud de calcul.
Liste de requête de messages.
Interface d'une liste de messages de sérialisation.
Interface d'un message de sérialisation entre IMessagePassingMng.
Gestion des messages parallèles pour le type Type.
Informations sur la source d'un message.
Informations pour envoyer/recevoir un message point à point.
bool isBlocking() const
Indique si le message est bloquant.
Classe de base d'une liste de requêtes.
Liste de messages de sérialisation.
Exception lorsqu'une fonction n'est pas implémentée.
Exception lorsqu'une opération n'est pas supportée.
Gestionnaire de thread en mode mono-thread.
Echange d'informations entre processeurs.
Redirige la gestion des messages des sous-domaines suivant le type de l'argument.
IMessagePassingMng * messagePassingMng() const override
Gestionnaire de message de Arccore associé
Classe de base d'une fabrique pour les fonctions utilitaires de IParallelMng.
Informations sur la réplication des sous-domaines en parallèle.
Informations sur la topologie d'allocation des coeurs de calcul.
virtual void initialize()
Initialise l'instance. Cette opération est collective.
Statistiques sur le parallélisme.
Référence à une instance.
Span< std::byte > segmentView(Int32 rank) override
Méthode permettant d'obtenir une vue sur le segment d'un autre sous-domaine du noeud.
void resize(Int64 new_size) override
Méthode permettant de redimensionner notre segment.
void barrier() const override
Méthode permettant d'attendre que tous les processus/threads du noeud appellent cette méthode pour co...
void addToAnotherSegment() override
Int32 sizeofOneElem() const override
Méthode permettant d'obtenir la taille d'un élement de la fenêtre.
void addToAnotherSegment(Int32 rank, Span< const std::byte > elem) override
Méthode permettant d'ajouter des éléments dans le segment d'un autre sous-domaine.
ConstArrayView< Int32 > machineRanks() const override
Méthode permettant d'obtenir les rangs qui possèdent un segment dans la fenêtre.
Span< const std::byte > segmentConstView() const override
Méthode permettant d'obtenir une vue sur notre segment.
void add(Span< const std::byte > elem) override
Méthode permettant d'ajouter des élements dans notre segment.
Span< const std::byte > segmentConstView(Int32 rank) const override
Méthode permettant d'obtenir une vue sur le segment d'un autre sous-domaine du noeud.
Span< std::byte > segmentView() override
Méthode permettant d'obtenir une vue sur notre segment.
void reserve(Int64 new_capacity) override
Méthode permettant de réserver de l'espace mémoire dans notre segment.
void shrink() override
Méthode permettant de réduire l'espace mémoire réservé pour les segments au minimum nécessaire.
Span< std::byte > segmentView() override
Méthode permettant d'obtenir une vue sur son segment.
Span< std::byte > segmentView(const Int32 rank) override
Méthode permettant d'obtenir une vue sur le segment d'un autre sous-domaine du noeud.
void barrier() const override
Méthode permettant d'attendre que tous les processus/threads du noeud appellent cette méthode pour co...
void resizeSegment(const Int64 new_sizeof_segment) override
Méthode permettant de redimensionner les segments de la fenêtre.
ConstArrayView< Int32 > machineRanks() const override
Méthode permettant d'obtenir les rangs qui possèdent un segment dans la fenêtre.
Span< std::byte > windowView() override
Méthode permettant d'obtenir une vue sur toute la fenêtre.
Int32 sizeofOneElem() const override
Méthode permettant d'obtenir la taille d'un élement de la fenêtre.
Span< const std::byte > segmentConstView(const Int32 rank) const override
Méthode permettant d'obtenir une vue sur le segment d'un autre sous-domaine du noeud.
Span< const std::byte > segmentConstView() const override
Méthode permettant d'obtenir une vue sur son segment.
Span< const std::byte > windowConstView() const override
Méthode permettant d'obtenir une vue sur toute la fenêtre.
Interface des messages pour le type Type.
Ref< IParallelMng > _createParallelMng(Int32 local_rank, ITraceMng *tm) override
Créé le IParallelMng pour le rang local local_rank.
Ref< IParallelMngContainer > _createParallelMngBuilder(Int32 nb_rank, Parallel::Communicator comm, Parallel::Communicator machine_comm) override
Créé un conteneur pour nb_local_rank rangs locaux et avec comme communicateur communicator.
Ref< ITransferValuesParallelOperation > createTransferValuesOperation(IParallelMng *) override
Retourne une opération pour transférer des valeurs entre rangs.
Ref< IVariableSynchronizer > createSynchronizer(IParallelMng *pm, const ItemGroup &group) override
Retourne une interface pour synchroniser des variables sur le groupe group.
Ref< IVariableSynchronizer > createSynchronizer(IParallelMng *pm, IItemFamily *family) override
Retourne une interface pour synchroniser des variables sur le groupe de la famille family.
Ref< IMachineMemoryWindowBaseInternal > createMachineMemoryWindowBase(Int64 sizeof_segment, Int32 sizeof_type) override
Méthode permettant de créer une fenêtre mémoire sur le noeud.
Ref< IDynamicMachineMemoryWindowBaseInternal > createDynamicMachineMemoryWindowBase(Int64 sizeof_segment, Int32 sizeof_type) override
Méthode permettant de créer une fenêtre mémoire dynamique sur le noeud.
Gestionnaire du parallélisme en mode séquentiel.
Parallel::Communicator communicator() const override
Communicateur MPI associé à ce gestionnaire.
ISerializeMessage * createReceiveSerializer(Int32 rank) override
Créé un message non bloquant pour recevoir des données sérialisées du rang rank.
IParallelNonBlockingCollective * nonBlockingCollective() const override
Interface des opérations collectives non blocantes.
ITransferValuesParallelOperation * createTransferValuesOperation() override
Retourne une opération pour transférer des valeurs entre sous-domaine.
IThreadMng * threadMng() const override
Gestionnaire de threads.
UniqueArray< Integer > testSomeRequests(ArrayView< Request > requests) override
Test si une des requêtes rvalues est terminée.
Int32 commRank() const override
Rang de cette instance dans le communicateur.
ISerializeMessage * createSendSerializer(Int32 rank) override
Créé un message non bloquant pour envoyer des données sérialisées au rang rank.
Int32 commSize() const override
Nombre d'instance dans le communicateur.
IParallelMng * sequentialParallelMng() override
Retourne un gestionnaire de parallélisme séquentiel.
void build() override
Construit l'instance.
void barrier() override
Effectue une barière.
void allGather(ISerializer *send_serializer, ISerializer *recv_serializer) override
Redéfinit ici allGather pour éviter de cacher le symbole dans les classes dérivées.
Parallel::Communicator machineCommunicator() const override
Communicateur MPI issus du communicateur communicator() réunissant tous les processus du noeud de cal...
IGetVariablesValuesParallelOperation * createGetVariablesValuesOperation() override
Retourne une opération pour récupérer les valeurs d'une variable sur les entités d'un autre sous-doma...
IParallelReplication * replication() const override
Informations sur la réplication.
ITimerMng * timerMng() const override
Gestionnaire de timers.
MessageId probe(const PointToPointMessageInfo &message) override
Sonde si des messages sont disponibles.
Ref< IParallelMngUtilsFactory > _internalUtilsFactory() const override
Fabrique des fonctions utilitaires.
MessageSourceInfo legacyProbe(const PointToPointMessageInfo &message) override
Sonde si des messages sont disponibles.
void processMessages(ConstArrayView< ISerializeMessage * > messages) override
Exécute les opérations des messages messages.
bool isMasterIO() const override
true si l'instance est un gestionnaire maître des entrées/sorties.
bool isThreadImplementation() const override
Indique si l'implémentation utilise les threads.
Ref< IRequestList > createRequestListRef() override
Créé une liste de requêtes pour ce gestionnaire.
Parallel::IStat * stat() override
Gestionnaire des statistiques.
void printStats() override
Affiche des statistiques liées à ce gestionnaire du parallélisme.
ITraceMng * traceMng() const override
Gestionnaire de traces.
void initialize() override
Initialise le gestionnaire du parallélisme.
IParallelMng * worldParallelMng() const override
Gestionnaire de parallélisme sur l'ensemble des ressources allouées.
bool isHybridImplementation() const override
Indique si l'implémentation utilise le mode hybride.
IParallelTopology * createTopology() override
Créé une instance contenant les infos sur la topologie des rangs de ce gestionnnaire.
bool isParallel() const override
Retourne true si l'exécution est parallèle.
void setReplication(IParallelReplication *v) override
Positionne les Informations sur la réplication.
void freeRequests(ArrayView< Parallel::Request > requests) override
Libère les requêtes.
void waitAllRequests(ArrayView< Request > requests) override
Bloque en attendant que les requêtes rvalues soient terminées.
UniqueArray< Integer > waitSomeRequests(ArrayView< Request > requests) override
Bloque en attendant qu'une des requêtes rvalues soit terminée.
IParallelMngInternal * _internalApi() override
API interne à Arcane.
void broadcastMemoryBuffer(ByteArray &bytes, Int32 rank) override
Effectue un broadcast d'une zone mémoire.
IVariableSynchronizer * createSynchronizer(const ItemGroup &group) override
Retourne une interface pour synchroniser des variables sur le groupe group.
IIOMng * ioMng() const override
Gestionnaire des entrées/sorties.
Int32 masterIORank() const override
Rang de l'instance gérant les entrées/sorties (pour laquelle isMasterIO() est vrai)
IVariableSynchronizer * createSynchronizer(IItemFamily *family) override
Retourne une interface pour synchroniser des variables sur le groupe de la famille family.
IParallelExchanger * createExchanger() override
Retourne une interface pour transférer des messages entre processeurs.
Request sendSerializer(ISerializer *values, Int32 rank, ByteArray &bytes) override
void * getMPICommunicator() override
Adresse du communicateur MPI associé à ce gestionnaire.
Superviseur du parallélisme en mode séquentiel.
void initialize() override
Initialise l'instance.
Ref< IParallelMng > internalCreateWorldParallelMng(Int32 local_rank) override
Créé un gestionnaire de parallélisme pour l'ensemble des coeurs alloués.
MP::Communicator communicator() const override
Communicateur MPI associé à ce gestionnaire.
void tryAbort() override
Tente de faire un abort.
void build() override
Construction de niveau build du service.
IApplication * m_application
Superviseur associé
IThreadMng * threadMng() const override
Gestionnaire de thread.
void _wait(Parallel::eWaitType wait_mode)
Effectue l'attente ou le test.
Message utilisant un SerializeBuffer.
IApplication * application() const
Accès à l'application IApplication associé.
Structure contenant les informations pour créer un service.
Propriétés de création d'un service.
__host__ __device__ void copy(const U ©_array)
Recopie le tableau copy_array dans l'instance.
constexpr __host__ __device__ SizeType size() const noexcept
Retourne la taille du tableau.
Vue d'un tableau d'éléments de type T.
constexpr __host__ __device__ Span< T, DynExtent > subSpan(Int64 abegin, Int64 asize) const
Sous-vue à partir de l'élément abegin et contenant asize éléments.
Chaîne de caractères unicode.
TraceAccessor(ITraceMng *m)
Construit un accesseur via le gestionnaire de trace m.
ITraceMng * traceMng() const
Gestionnaire de trace.
Vecteur 1D de données avec sémantique par valeur (style STL).
#define ARCANE_REGISTER_SERVICE(aclass, a_service_property,...)
Macro pour enregistrer un service.
Déclarations des types et méthodes utilisés par les mécanismes d'échange de messages.
eReduceType
Types des réductions supportées.
IStat * createDefaultStat()
Créé une instance par défaut.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Ref< TrueType > createRef(Args &&... args)
Créé une instance de type TrueType avec les arguments Args et retourne une référence dessus.
std::int64_t Int64
Type entier signé sur 64 bits.
Int32 Integer
Type représentant un entier.
Array< Byte > ByteArray
Tableau dynamique à une dimension de caractères.
ConstArrayView< Int32 > Int32ConstArrayView
Equivalent C d'un tableau à une dimension d'entiers 32 bits.
@ ST_Application
Le service s'utilise au niveau de l'application.
auto makeRef(InstanceType *t) -> Ref< InstanceType >
Créé une référence sur un pointeur.
std::int32_t Int32
Type entier signé sur 32 bits.
Infos pour construire un SequentialParallelMng.