Arcane  v3.15.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
MpiTypeDispatcher.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2022 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/* MpiTypeDispatcher.h (C) 2000-2024 */
9/* */
10/* Gestion des messages pour un type de données. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCCORE_MESSAGEPASSINGMPI_MPITYPEDISPATCHER_H
13#define ARCCORE_MESSAGEPASSINGMPI_MPITYPEDISPATCHER_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arccore/message_passing_mpi/MessagePassingMpiGlobal.h"
18#include "arccore/message_passing/ITypeDispatcher.h"
19
20/*---------------------------------------------------------------------------*/
21/*---------------------------------------------------------------------------*/
22
23namespace Arccore::MessagePassing::Mpi
24{
25
26/*---------------------------------------------------------------------------*/
27/*---------------------------------------------------------------------------*/
28
29template <typename Type>
31: public ITypeDispatcher<Type>
32{
33 public:
34
37
38 public:
39
40 void finalize() override {}
41 void broadcast(Span<Type> send_buf, Int32 rank) override;
42 void allGather(Span<const Type> send_buf,Span<Type> recv_buf) override;
43 void allGatherVariable(Span<const Type> send_buf,Array<Type>& recv_buf) override;
44 void gather(Span<const Type> send_buf,Span<Type> recv_buf,Int32 rank) override;
45 void gatherVariable(Span<const Type> send_buf,Array<Type>& recv_buf,Int32 rank) override;
46 void scatterVariable(Span<const Type> send_buf,Span<Type> recv_buf,Int32 root) override;
47 void allToAll(Span<const Type> send_buf,Span<Type> recv_buf,Int32 count) override;
48 void allToAllVariable(Span<const Type> send_buf,Int32ConstArrayView send_count,
49 Int32ConstArrayView send_index,Span<Type> recv_buf,
50 Int32ConstArrayView recv_count,Int32ConstArrayView recv_index) override;
51 Request send(Span<const Type> send_buffer,Int32 rank,bool is_blocked) override;
52 Request send(Span<const Type> send_buffer,const PointToPointMessageInfo& message) override;
53 Request receive(Span<Type> recv_buffer,Int32 rank,bool is_blocked) override;
54 Request receive(Span<Type> recv_buffer,const PointToPointMessageInfo& message) override;
55 Type allReduce(eReduceType op,Type send_buf) override;
56 void allReduce(eReduceType op,Span<Type> send_buf) override;
57 Request nonBlockingAllReduce(eReduceType op, Span<const Type> send_buf, Span<Type> recv_buf) override;
58 Request nonBlockingAllGather(Span<const Type> send_buf, Span<Type> recv_buf) override;
59 Request nonBlockingBroadcast(Span<Type> send_buf, Int32 rank) override;
60 Request nonBlockingGather(Span<const Type> send_buf, Span<Type> recv_buf, Int32 rank) override;
61 Request nonBlockingAllToAll(Span<const Type> send_buf, Span<Type> recv_buf, Int32 count) override;
62 Request nonBlockingAllToAllVariable(Span<const Type> send_buf, ConstArrayView<Int32> send_count,
63 ConstArrayView<Int32> send_index, Span<Type> recv_buf,
64 ConstArrayView<Int32> recv_count, ConstArrayView<Int32> recv_index) override;
66 void gatherVariable(Span<const Type> send_buf,Span<Type> recv_buf,Span<const Int32> displacements,
67 Span<const Int32> counts,Int32 rank);
68
69 public:
70
71 MpiDatatype* datatype() const { return m_datatype; }
72 IMessagePassingMng* messagePassingMng() const { return m_parallel_mng; }
73 MpiAdapter* adapter() const { return m_adapter; }
74 void setDestroyDatatype(bool v) { m_is_destroy_datatype = v; }
75 bool isDestroyDatatype() const { return m_is_destroy_datatype; }
76
77 private:
78
79 IMessagePassingMng* m_parallel_mng;
80 MpiAdapter* m_adapter;
81 MpiDatatype* m_datatype;
82 bool m_is_destroy_datatype = false;
83
84 private:
85
86 void _gatherVariable2(Span<const Type> send_buf, Array<Type>& recv_buf, Integer rank);
87};
88
89/*---------------------------------------------------------------------------*/
90/*---------------------------------------------------------------------------*/
91
92} // End namespace Arccore::MessagePassing::Mpi
93
94/*---------------------------------------------------------------------------*/
95/*---------------------------------------------------------------------------*/
96
97#endif
98
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:149
Vue constante d'un tableau de type T.
Interface du gestionnaire des échanges de messages.
Gestion des messages parallèles pour le type Type.
Informations pour envoyer/recevoir un message point à point.
Requête d'un message.
Definition Request.h:77
eReduceType
Types des réductions supportées.
Int32 Integer
Type représentant un entier.
Type
Type of JSON value.
Definition rapidjson.h:665