Arcane  v3.16.4.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IParallelExchanger.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2025 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* IParallelExchanger.h (C) 2000-2025 */
9/* */
10/* Échange d'informations entre processeurs. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_CORE_IPARALLELEXCHANGER_H
13#define ARCANE_CORE_IPARALLELEXCHANGER_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
19#include "arcane/core/ParallelExchangerOptions.h"
20
21/*---------------------------------------------------------------------------*/
22/*---------------------------------------------------------------------------*/
23
24namespace Arcane
25{
26
27/*---------------------------------------------------------------------------*/
28/*---------------------------------------------------------------------------*/
29/*!
30 * \brief Échange d'informations entre processeurs.
31 *
32 * Cette classe permet d'envoyer et de recevoir des messages quelconques
33 * d'un nombre quelconque d'autre processeurs.
34 *
35 * Le fonctionnement est le suivant.
36 *
37 * 1. indiquer les autres PE avec lesquels on souhaite communiquer en appelant
38 * addSender(), éventuellement plusieurs fois.
39 * 2. appeler initializeCommunicationsMessages() pour déterminer la liste des
40 * PE pour lesquels on doit recevoir des infos. Il existe deux surcharges
41 * pour cette méthode suivant si on connait ou non le nombre de rangs pour
42 * lesquels on doit recevoir des informations.
43 * 3. pour chaque message d'envoi, sérialiser les informations qu'on souhaite
44 * envoyer.
45 * 4. effectuer les envoies et les réceptions en appelant processExchange()
46 * 5. récupérer les messages recus (via messageToReceive()) et désérialiser
47 * leurs informations.
48 *
49 * Il est possible de spécifier, avant appel à processExchange(), la manière dont
50 * les messages seront envoyés via setExchangeMode(). Par défaut, le mécanisme
51 * utilisé est celui des communications point à point (EM_Independant) mais il
52 * est possible d'utiliser un mode collectif (EM_Collective) qui utilise
53 * des messages de type 'all to all'.
54 */
55class ARCANE_CORE_EXPORT IParallelExchanger
56{
57 public:
58
60 {
61 //! Utilise les échanges point à point (send/recv)
63 //! Utilise les opération collectives (allToAll)
65 //! Choisi automatiquement entre point à point ou collective.
67 };
68
69 public:
70
71 virtual ~IParallelExchanger() = default;
72
73 public:
74
75 /*!
76 * \brief Calcule les communications.
77 *
78 * A partir de \a m_send_ranks donné par chaque processeur,
79 * détermine la liste des processeurs à qui on doit envoyer un message.
80 *
81 * Afin de connaître les processeurs desquels on attend des informations,
82 * il est nécessaire de faire une communication (allGatherVariable()). Si on connait
83 * à priori ces processeurs, il faut utiliser une des versions surchargée de cette
84 * méthode.
85 *
86 * \retval true s'il n'y a rien à échanger
87 * \retval false sinon.
88 */
90
91 /*! \brief Calcule les communications.
92 *
93 * Suppose que la liste des processeurs dont on veut les informations est dans
94 * \a recv_ranks.
95 */
97
98 //! Effectue l'échange avec les options par défaut de ParallelExchangerOptions.
99 virtual void processExchange() = 0;
100
101 //! Effectue l'échange avec les options \a options
102 virtual void processExchange(const ParallelExchangerOptions& options) = 0;
103
104 public:
105
106 virtual IParallelMng* parallelMng() const = 0;
107
108 //! Nombre de processeurs auquel on envoie
109 virtual Integer nbSender() const = 0;
110 //! Liste des rangs des processeurs auquel on envoie
111 virtual Int32ConstArrayView senderRanks() const = 0;
112 //! Ajoute un processeur à envoyer
113 virtual void addSender(Int32 rank) = 0;
114 //! Message destiné au \a ième processeur
116
117 //! Nombre de processeurs dont on va réceptionner les messages
118 virtual Integer nbReceiver() const = 0;
119 //! Liste des rangs des processeurs dont on va réceptionner les messages
121 //! Message reçu du \a ième processeur
123
124 //! Positionne le mode d'échange.
125 [[deprecated("Y2021: Use ParallelExchangerOptions::setExchangeMode()")]]
126 virtual void setExchangeMode(eExchangeMode mode) = 0;
127 //! Mode d'échange spécifié
128 [[deprecated("Y2021: Use ParallelExchangerOptions::exchangeMode()")]]
129 virtual eExchangeMode exchangeMode() const = 0;
130
131 //! Positionne le niveau de verbosité
132 virtual void setVerbosityLevel(Int32 v) = 0;
133 //! Niveau de verbosité
134 virtual Int32 verbosityLevel() const = 0;
135
136 //! Positionne le nom de l'instance. Ce nom est utilisé lors des impressions
137 virtual void setName(const String& name) = 0;
138 //! Nom de l'instance
139 virtual String name() const = 0;
140};
141
142/*---------------------------------------------------------------------------*/
143/*---------------------------------------------------------------------------*/
144
145} // namespace Arcane
146
147/*---------------------------------------------------------------------------*/
148/*---------------------------------------------------------------------------*/
149
150#endif
151
Déclarations des types généraux de Arcane.
Fichier contenant les déclarations concernant le modèle de programmation par échange de message.
Échange d'informations entre processeurs.
virtual void addSender(Int32 rank)=0
Ajoute un processeur à envoyer.
@ EM_Independant
Utilise les échanges point à point (send/recv)
@ EM_Collective
Utilise les opération collectives (allToAll)
@ EM_Auto
Choisi automatiquement entre point à point ou collective.
virtual void setName(const String &name)=0
Positionne le nom de l'instance. Ce nom est utilisé lors des impressions.
virtual Integer nbSender() const =0
Nombre de processeurs auquel on envoie.
virtual void setExchangeMode(eExchangeMode mode)=0
Positionne le mode d'échange.
virtual Integer nbReceiver() const =0
Nombre de processeurs dont on va réceptionner les messages.
virtual String name() const =0
Nom de l'instance.
virtual void initializeCommunicationsMessages(Int32ConstArrayView recv_ranks)=0
Calcule les communications.
virtual void setVerbosityLevel(Int32 v)=0
Positionne le niveau de verbosité
virtual Int32 verbosityLevel() const =0
Niveau de verbosité
virtual eExchangeMode exchangeMode() const =0
Mode d'échange spécifié
virtual bool initializeCommunicationsMessages()=0
Calcule les communications.
virtual ISerializeMessage * messageToSend(Integer i)=0
Message destiné au ième processeur.
virtual void processExchange()=0
Effectue l'échange avec les options par défaut de ParallelExchangerOptions.
virtual void processExchange(const ParallelExchangerOptions &options)=0
Effectue l'échange avec les options options.
virtual Int32ConstArrayView senderRanks() const =0
Liste des rangs des processeurs auquel on envoie.
virtual Int32ConstArrayView receiverRanks()=0
Liste des rangs des processeurs dont on va réceptionner les messages.
virtual ISerializeMessage * messageToReceive(Integer i)=0
Message reçu du ième processeur.
Interface du gestionnaire de parallélisme pour un sous-domaine.
Options pour IParallelMng::processExchange().
@ EM_Auto
Choisi automatiquement entre point à point ou collective.
@ EM_Collective
Utilise les opération collectives (allToAll)
@ EM_Independant
Utilise les échanges point à point (send/recv)
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Int32 Integer
Type représentant un entier.
ConstArrayView< Int32 > Int32ConstArrayView
Equivalent C d'un tableau à une dimension d'entiers 32 bits.
Definition UtilsTypes.h:569
std::int32_t Int32
Type entier signé sur 32 bits.