Arcane  4.1.12.0
Developer documentation
Loading...
Searching...
No Matches
IParallelMngUtilsFactory.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2026 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/* IParallelMngUtilsFactory.h (C) 2000-2025 */
9/* */
10/* Interface of a factory for the utility functions of IParallelMng. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_CORE_INTERNAL_IPARALLELMNGUTILSFACTORY_H
13#define ARCANE_CORE_INTERNAL_IPARALLELMNGUTILSFACTORY_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/utils/Ref.h"
18
20
21/*---------------------------------------------------------------------------*/
22/*---------------------------------------------------------------------------*/
23
24namespace Arcane
25{
26
27/*---------------------------------------------------------------------------*/
28/*---------------------------------------------------------------------------*/
29
95
96/*---------------------------------------------------------------------------*/
97/*---------------------------------------------------------------------------*/
98
99} // namespace Arcane
100
101/*---------------------------------------------------------------------------*/
102/*---------------------------------------------------------------------------*/
103
104#endif
File containing declarations concerning the message passing model.
Interface of an entity family.
Definition IItemFamily.h:83
Interface of a factory for the utility functions of IParallelMng.
virtual Ref< IVariableSynchronizer > createSynchronizer(IParallelMng *pm, IItemFamily *family)=0
Returns an interface to synchronize variables on the group of the family family.
virtual Ref< ISerializeMessage > createSendSerializeMessage(IParallelMng *pm, Int32 rank)=0
Creates a non-blocking serialization message for sending to rank rank.
virtual Ref< ITransferValuesParallelOperation > createTransferValuesOperation(IParallelMng *pm)=0
Returns an operation to transfer values between ranks.
virtual Ref< IGetVariablesValuesParallelOperation > createGetVariablesValuesOperation(IParallelMng *pm)=0
Returns an operation to retrieve the values of a variable on the entities of another subdomain.
virtual Ref< IVariableSynchronizer > createSynchronizer(IParallelMng *pm, const ItemGroup &group)=0
Returns an interface to synchronize variables on the group group.
virtual Ref< ISerializeMessage > createReceiveSerializeMessage(IParallelMng *pm, Int32 rank)=0
Creates a non-blocking serialization message for receiving from rank rank.
virtual Ref< IParallelExchanger > createExchanger(IParallelMng *pm)=0
Returns an interface to transfer messages between ranks.
virtual Ref< IParallelTopology > createTopology(IParallelMng *pm)=0
Creates an instance containing information about the rank topology of this manager.
Interface of the parallelism manager for a subdomain.
Mesh entity group.
Definition ItemGroup.h:51
Reference to an instance.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
std::int32_t Int32
Signed integer type of 32 bits.