Arcane  4.1.12.0
Developer documentation
Loading...
Searching...
No Matches
ExtraGhostCellsBuilder.cc
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/* ExtraGhostCellsBuilder.cc (C) 2000-2024 */
9/* */
10/* Construction of extra ghost cells. */
11/*---------------------------------------------------------------------------*/
12/*---------------------------------------------------------------------------*/
13
14#include "arcane/utils/ScopedPtr.h"
15#include "arcane/utils/CheckedConvert.h"
16
17#include "arcane/core/IExtraGhostCellsBuilder.h"
18#include "arcane/core/IParallelExchanger.h"
19#include "arcane/core/IParallelMng.h"
20#include "arcane/core/ISerializeMessage.h"
21#include "arcane/core/ParallelMngUtils.h"
22
23#include "arcane/mesh/ExtraGhostCellsBuilder.h"
24#include "arcane/mesh/DynamicMesh.h"
25
26/*---------------------------------------------------------------------------*/
27/*---------------------------------------------------------------------------*/
28
29namespace Arcane::mesh
30{
31
32/*---------------------------------------------------------------------------*/
33/*---------------------------------------------------------------------------*/
34
35ExtraGhostCellsBuilder::
36ExtraGhostCellsBuilder(DynamicMesh* mesh)
37: TraceAccessor(mesh->traceMng())
38, m_mesh(mesh)
39{
40}
41
42/*---------------------------------------------------------------------------*/
43/*---------------------------------------------------------------------------*/
44
45void ExtraGhostCellsBuilder::
46addExtraGhostCellsBuilder(IExtraGhostCellsBuilder* builder)
47{
48 if (m_builders.contains(builder))
49 ARCANE_FATAL("Instance {0} is already registered", builder);
50 m_builders.add(builder);
51}
52
53/*---------------------------------------------------------------------------*/
54/*---------------------------------------------------------------------------*/
55
56void ExtraGhostCellsBuilder::
57removeExtraGhostCellsBuilder(IExtraGhostCellsBuilder* builder)
58{
59 auto iter_begin = m_builders.begin();
60 auto iter_end = m_builders.end();
61 auto x = std::find(iter_begin, iter_end, builder);
62 if (x == iter_end)
63 ARCANE_FATAL("Instance {0} is not registered", builder);
64 m_builders.remove(x - iter_begin);
65}
66
67/*---------------------------------------------------------------------------*/
68/*---------------------------------------------------------------------------*/
69
70bool ExtraGhostCellsBuilder::
71hasBuilder() const
72{
73 return !m_builders.empty();
74}
75
76/*---------------------------------------------------------------------------*/
77/*---------------------------------------------------------------------------*/
78
79void ExtraGhostCellsBuilder::
80computeExtraGhostCells()
81{
82 if (m_builders.empty())
83 return;
84
85 info() << "Compute extra ghost cells";
86
87 for (IExtraGhostCellsBuilder* v : m_builders) {
88 // Calculate extra cells to send
89 v->computeExtraCellsToSend();
90 }
91
92 IParallelMng* pm = m_mesh->parallelMng();
93
94 auto exchanger{ ParallelMngUtils::createExchangerRef(pm) };
95
96 const Int32 nsd = pm->commSize();
97
98 // Construction of items to send
99 UniqueArray<std::set<Integer>> to_sends(nsd);
100
101 // Initialisation of the data exchanger
102 for (Integer isd = 0; isd < nsd; ++isd) {
103 std::set<Integer>& cell_set = to_sends[isd];
104 for (IExtraGhostCellsBuilder* builder : m_builders) {
105 Int32ConstArrayView extra_cells = builder->extraCellsToSend(isd);
106 // We sort the IDs to send to avoid duplicates
107 for (Integer j = 0, size = extra_cells.size(); j < size; ++j)
108 cell_set.insert(extra_cells[j]);
109 }
110 if (!cell_set.empty())
111 exchanger->addSender(isd);
112 }
113 exchanger->initializeCommunicationsMessages();
114
115 // Sending the cells
116 for (Integer i = 0, ns = exchanger->nbSender(); i < ns; ++i) {
117 ISerializeMessage* sm = exchanger->messageToSend(i);
118 const Int32 rank = sm->destination().value();
119 ISerializer* s = sm->serializer();
120 const std::set<Integer>& cell_set = to_sends[rank];
121 Int32UniqueArray items_to_send(cell_set.size());
122 std::copy(std::begin(cell_set), std::end(cell_set), std::begin(items_to_send));
123 m_mesh->serializeCells(s, items_to_send);
124 }
125 exchanger->processExchange();
126
127 // Receiving the cells
128 for (Integer i = 0, ns = exchanger->nbReceiver(); i < ns; ++i) {
129 ISerializeMessage* sm = exchanger->messageToReceive(i);
130 ISerializer* s = sm->serializer();
131 m_mesh->addCells(s);
132 }
133}
134
135/*---------------------------------------------------------------------------*/
136/*---------------------------------------------------------------------------*/
137
138} // End namespace Arcane::mesh
139
140/*---------------------------------------------------------------------------*/
141/*---------------------------------------------------------------------------*/
#define ARCANE_FATAL(...)
Macro throwing a FatalErrorException.
Implementation of a mesh.
Definition DynamicMesh.h:98
ConstArrayView< Int32 > Int32ConstArrayView
C equivalent of a 1D array of 32-bit integers.
Definition UtilsTypes.h:482
UniqueArray< Int32 > Int32UniqueArray
Dynamic 1D array of 32-bit integers.
Definition UtilsTypes.h:341