Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
RedistributorCommPlan.h
1/*
2 * Copyright 2020 IFPEN-CEA
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *
16 * SPDX-License-Identifier: Apache-2.0
17 */
18
19#pragma once
20
21#include <alien/kernels/redistributor/RedistributorBackEnd.h>
22#include <memory>
23
25
26namespace Alien
27{
28
29class ALIEN_EXPORT RedistributorCommPlan
30{
31 public:
32 RedistributorCommPlan(
33 int globalSize, IMessagePassingMng* super_pm, IMessagePassingMng* tgt_pm);
34 virtual ~RedistributorCommPlan();
35
36 std::shared_ptr<IMessagePassingMng> tgtParallelMng() const;
37 IMessagePassingMng* superParallelMng() const;
38
39 const VectorDistribution& distribution() const;
40
41 ConstArrayView<Int32> tgtDist() const;
42
43 [[nodiscard]] Int32 procNum(Int32) const;
44
45 private:
46 void _buildTgtDist();
47
48 IMessagePassingMng* m_super_pm;
49 IMessagePassingMng* m_tgt_pm;
50 std::unique_ptr<VectorDistribution> m_tgt_distribution;
51 UniqueArray<Int32> m_proc_num;
52 UniqueArray<Int32> m_tgt_dist;
54};
55
56} // namespace Alien
VectorDistribution.h.
UniqueArray< Int32 > m_proc_num
Distribution in the target pm.
UniqueArray< Int32 > m_tgt_dist
Array for converting ranks from super to dst.
Computes a vector distribution.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17