Arcane  v3.15.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
ParallelTopology.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/* ParallelTopology.h (C) 2000-2011 */
9/* */
10/* Informations sur la topologie d'allocation des coeurs de calcul. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IMPL_PARALLELTOPOLOGY_H
13#define ARCANE_IMPL_PARALLELTOPOLOGY_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/IParallelTopology.h"
18
19/*---------------------------------------------------------------------------*/
20/*---------------------------------------------------------------------------*/
21
22ARCANE_BEGIN_NAMESPACE
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27class IParallelMng;
28
29/*---------------------------------------------------------------------------*/
30/*---------------------------------------------------------------------------*/
37class ARCANE_IMPL_EXPORT ParallelTopology
38: public IParallelTopology
39{
40 public:
41
43 virtual ~ParallelTopology() {}
44
45 public:
46
48 virtual void initialize();
49
50 public:
51
52 virtual IParallelMng* parallelMng() const;
53 virtual bool isMasterMachine() const;
54 virtual Int32ConstArrayView machineRanks() const;
55 virtual Int32 machineRank() const;
57 virtual bool isMasterProcess() const;
58 virtual Int32ConstArrayView processRanks() const;
59 virtual Int32 processRank() const;
61
62 private:
63
64 IParallelMng* m_parallel_mng;
65 Int32UniqueArray m_machine_ranks;
66 Int32UniqueArray m_process_ranks;
67 Int32 m_machine_rank;
68 Int32 m_process_rank;
69 bool m_is_machine_master;
70 bool m_is_process_master;
71 Int32UniqueArray m_master_machine_ranks;
72 Int32UniqueArray m_master_process_ranks;
73
74 private:
75
76 void _init();
77};
78
79/*---------------------------------------------------------------------------*/
80/*---------------------------------------------------------------------------*/
81
82ARCANE_END_NAMESPACE
83
84/*---------------------------------------------------------------------------*/
85/*---------------------------------------------------------------------------*/
86
87#endif
88
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 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).
Informations sur la topologie d'allocation des coeurs de calcul.
virtual ~ParallelTopology()
Libère les ressources.
Vue constante d'un tableau de type T.
Vecteur 1D de données avec sémantique par valeur (style STL).