Arcane  v3.15.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
ParallelReplication.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/* ParallelReplication.h (C) 2000-2020 */
9/* */
10/* Informations sur la réplication de sous-domaines. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IMPL_PARALLELREPLICATION_H
13#define ARCANE_IMPL_PARALLELREPLICATION_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/IParallelReplication.h"
18#include "arcane/Parallel.h"
19#include "arcane/utils/Ref.h"
20
21/*---------------------------------------------------------------------------*/
22/*---------------------------------------------------------------------------*/
23
24namespace Arcane
25{
26
27/*---------------------------------------------------------------------------*/
28/*---------------------------------------------------------------------------*/
29
30class IParallelMng;
31
32/*---------------------------------------------------------------------------*/
33/*---------------------------------------------------------------------------*/
48class ARCANE_IMPL_EXPORT ParallelReplication
50{
51 public:
52
56 ParallelReplication(Int32 rank,Int32 nb_rank,Ref<IParallelMng> replica_pm);
57 virtual ~ParallelReplication();
58
59 public:
60
61 virtual bool hasReplication() const { return m_is_active; }
62 virtual Int32 nbReplication() const { return m_nb_replication; }
63 virtual Int32 replicationRank() const { return m_replication_rank; }
64 virtual bool isMasterRank() const { return m_is_master_rank; }
65 virtual Int32 masterReplicationRank() const { return m_master_replication_rank; }
66 virtual IParallelMng* replicaParallelMng() const { return m_replica_parallel_mng.get(); }
67
68 private:
69
70 bool m_is_active;
71 Int32 m_nb_replication;
72 Int32 m_replication_rank;
73 bool m_is_master_rank;
74 Int32 m_master_replication_rank;
75 Ref<IParallelMng> m_replica_parallel_mng;
76};
77
78/*---------------------------------------------------------------------------*/
79/*---------------------------------------------------------------------------*/
80
81} // End namespace Arcane
82
83/*---------------------------------------------------------------------------*/
84/*---------------------------------------------------------------------------*/
85
86#endif
Interface du gestionnaire de parallélisme pour un sous-domaine.
Informations sur la réplication des sous-domaines en parallèle.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:149
Informations sur la réplication des sous-domaines en parallèle.
virtual bool isMasterRank() const
Indique si ce rang de réplication est le maître.
virtual IParallelMng * replicaParallelMng() const
Communicateur associé à tous les réplicats représentant un même sous-domaine.
virtual Int32 masterReplicationRank() const
Rang dans la réplication du maître.
virtual bool hasReplication() const
Indique si la réplication est active.
virtual Int32 replicationRank() const
Rang dans la réplication (de 0 à nbReplication()-1)
virtual Int32 nbReplication() const
Nombre de réplication.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-