Arcane  v3.14.10.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
TransferValuesParallelOperation.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/* TransferValuesParallelOperation.h (C) 2000-2020 */
9/* */
10/* Transfert de valeurs sur différents processeurs. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IMPL_TRANSFERVALUESPARALLELOPERATION_H
13#define ARCANE_IMPL_TRANSFERVALUESPARALLELOPERATION_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/ITransferValuesParallelOperation.h"
18
19/*---------------------------------------------------------------------------*/
20/*---------------------------------------------------------------------------*/
21
22namespace Arcane
23{
24
25/*---------------------------------------------------------------------------*/
26/*---------------------------------------------------------------------------*/
30class ARCANE_IMPL_EXPORT TransferValuesParallelOperation
32{
33 public:
35 public:
38 public:
39 virtual IParallelMng* parallelMng();
40 public:
41 virtual void setTransferRanks(Int32ConstArrayView ranks);
45 virtual void transferValues();
46 private:
47 IParallelMng* m_parallel_mng;
48 Int32ConstArrayView m_ranks;
51 UniqueArray< RealConstArrayView > m_send_real_values;
52 UniqueArray< SharedArray<Int32> > m_recv32_values;
53 UniqueArray< SharedArray<Int64> > m_recv64_values;
54 UniqueArray< SharedArray<Real> > m_recv_real_values;
55 private:
56 template<typename U>
57 void _putArray(ISerializer* s,
61 template<typename U> void
62 _getArray(ISerializer* s, Integer nb,
65};
66
67/*---------------------------------------------------------------------------*/
68/*---------------------------------------------------------------------------*/
69
70} // End namespace Arcane
71
72/*---------------------------------------------------------------------------*/
73/*---------------------------------------------------------------------------*/
74
75#endif
Interface du gestionnaire de parallélisme pour un sous-domaine.
Envoie de valeurs sur différents processeurs.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:120
Opérations pour transférer des valeurs vers d'autres sous-domaine.
Vue constante d'un tableau de type T.
Vecteur 1D de données avec sémantique par valeur (style STL).
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-