Arcane  v3.15.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IParallelReplication.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/* IParallelReplicationInfo.h (C) 2000-2012 */
9/* */
10/* Informations sur la réplication de sous-domaines. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IPARALLELREPLICATION_H
13#define ARCANE_IPARALLELREPLICATION_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
18
19/*---------------------------------------------------------------------------*/
20/*---------------------------------------------------------------------------*/
21
22ARCANE_BEGIN_NAMESPACE
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27class IParallelMng;
28
29/*---------------------------------------------------------------------------*/
30/*---------------------------------------------------------------------------*/
31/*!
32 * \ingroup Parallel
33 * \brief Informations sur la réplication des sous-domaines en parallèle.
34 */
35class ARCANE_CORE_EXPORT IParallelReplication
36{
37 public:
38
39 virtual ~IParallelReplication(){}
40
41 public:
42
43 //! Indique si la réplication est active
44 virtual bool hasReplication() const =0;
45
46 //! Nombre de réplication
47 virtual Int32 nbReplication() const =0;
48
49 //! Rang dans la réplication (de 0 à nbReplication()-1)
50 virtual Int32 replicationRank() const =0;
51
52 /*!
53 * \brief Indique si ce rang de réplication est le maître.
54 *
55 * Cela est utile par exemple pour les sorties, afin qu'un seul
56 * réplicat ne sorte les informations.
57 */
58 virtual bool isMasterRank() const =0;
59
60 //! Rang dans la réplication du maître.
61 virtual Int32 masterReplicationRank() const =0;
62
63 /*!
64 * \brief Communicateur associé à tous les réplicats représentant un même sous-domaine.
65 *
66 * Vaut 0 s'il n'y a pas de réplication (hasReplication() est faux).
67 */
68 virtual IParallelMng* replicaParallelMng() const =0;
69};
70
71/*---------------------------------------------------------------------------*/
72/*---------------------------------------------------------------------------*/
73
74ARCANE_END_NAMESPACE
75
76/*---------------------------------------------------------------------------*/
77/*---------------------------------------------------------------------------*/
78
79#endif
Fichier de configuration d'Arcane.
Interface du gestionnaire de parallélisme pour un sous-domaine.
Informations sur la réplication des sous-domaines en parallèle.
virtual bool hasReplication() const =0
Indique si la réplication est active.
virtual IParallelMng * replicaParallelMng() const =0
Communicateur associé à tous les réplicats représentant un même sous-domaine.
virtual Int32 masterReplicationRank() const =0
Rang dans la réplication du maître.
virtual Int32 replicationRank() const =0
Rang dans la réplication (de 0 à nbReplication()-1)
virtual Int32 nbReplication() const =0
Nombre de réplication.
virtual bool isMasterRank() const =0
Indique si ce rang de réplication est le maître.