Arcane  v3.14.10.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IParallelTopology.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/* IParallelTopology.h (C) 2000-2011 */
9/* */
10/* Informations sur la topologie d'allocation des coeurs de calcul. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IPARALLELTOPOLOGY_H
13#define ARCANE_IPARALLELTOPOLOGY_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 topologie d'allocation des coeurs de calcul.
34 *
35 * Une instance de cette classe est liée à un IParallelMng.
36 *
37 * Elle permet de savoir comment les rangs de ce IParallelMng sont alloués
38 * sur le cluster et dans les processus.
39 *
40 */
41class ARCANE_CORE_EXPORT IParallelTopology
42{
43 public:
44
45 virtual ~IParallelTopology() {} //!< Libère les ressources.
46
47 public:
48
49 //! Gestionnaire de parallélisme associé
50 virtual IParallelMng* parallelMng() const =0;
51
52 //! Indique si ce rang est le rang maître pour une machine (noeud)
53 virtual bool isMasterMachine() const =0;
54
55 //! Liste des rangs qui sont sur la même machine
57
58 /*!
59 * \brief Rang de cette instance dans la liste des machines (noeuds).
60 *
61 * Ce rang est compris entre 0 et masterMachineRanks().size().
62 */
63 virtual Int32 machineRank() const =0;
64
65 /*!
66 * \brief Liste des rangs maîtres pour chaque machine (noeud).
67 *
68 * Cette liste est la même pour tous les rangs.
69 */
71
72 //! Indique si ce rang est le maitre dans les rangs de ce processus.
73 virtual bool isMasterProcess() const =0;
74
75 //! Liste des rangs qui sont dans le même processus (en multi-threading)
77
78 /*!
79 * \brief Rang de cette instance dans la liste des processus.
80 *
81 * Ce rang est compris entre 0 et masterProcessRanks().size().
82 */
83 virtual Int32 processRank() const =0;
84
85 /*!
86 * \brief Liste des rangs maitres pour chaque processus.
87 *
88 * Cette liste est la même pour tous les rangs.
89 */
91};
92
93/*---------------------------------------------------------------------------*/
94/*---------------------------------------------------------------------------*/
95
96ARCANE_END_NAMESPACE
97
98/*---------------------------------------------------------------------------*/
99/*---------------------------------------------------------------------------*/
100
101#endif
102
Déclarations des types utilisés dans Arcane.
Interface du gestionnaire de parallélisme pour un sous-domaine.
Informations sur la topologie d'allocation des coeurs de calcul.
virtual IParallelMng * parallelMng() const =0
Gestionnaire de parallélisme associé
virtual Int32ConstArrayView masterMachineRanks() const =0
Liste des rangs maîtres pour chaque machine (noeud).
virtual Int32ConstArrayView masterProcessRanks() const =0
Liste des rangs maitres pour chaque processus.
virtual bool isMasterMachine() const =0
Indique si ce rang est le rang maître pour une machine (noeud)
virtual ~IParallelTopology()
Libère les ressources.
virtual Int32ConstArrayView processRanks() const =0
Liste des rangs qui sont dans le même processus (en multi-threading)
virtual bool isMasterProcess() const =0
Indique si ce rang est le maitre dans les rangs de ce processus.
virtual Int32 processRank() const =0
Rang de cette instance dans la liste des processus.
virtual Int32ConstArrayView machineRanks() const =0
Liste des rangs qui sont sur la même machine.
virtual Int32 machineRank() const =0
Rang de cette instance dans la liste des machines (noeuds).
Vue constante d'un tableau de type T.