Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
RedistributorMatrix.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
22#include <alien/kernels/dok/DoKDistributor.h>
23#include <alien/kernels/simple_csr/redistribution/SimpleCSRDistributor.h>
24#include <alien/utils/Precomp.h>
25
26namespace Alien
27{
28
29// Forward declarations
31
32class ALIEN_EXPORT RedistributorMatrix : public IMatrixImpl
33{
34 public:
35 explicit RedistributorMatrix(const MultiMatrixImpl* src_impl, bool use_dok = true);
36 ~RedistributorMatrix() = default;
37
38 RedistributorMatrix(const RedistributorMatrix& src) = delete;
39 RedistributorMatrix(RedistributorMatrix&& src) = delete;
40 RedistributorMatrix& operator=(const RedistributorMatrix& src) = delete;
41 RedistributorMatrix& operator=(RedistributorMatrix&& src) = delete;
42
44 void clear() override;
45
46 void useCSRRedistributor();
47 std::shared_ptr<MultiMatrixImpl> updateTargetPM(const RedistributorCommPlan* commPlan);
48 void setSuperPM(IMessagePassingMng* pm);
49
50 std::shared_ptr<MultiMatrixImpl> redistribute();
51
52 private:
53 const IMessagePassingMng* m_super_pm;
54 std::shared_ptr<MultiMatrixImpl> m_tgt_impl;
55 std::shared_ptr<MatrixDistribution> m_tgt_dist;
56 std::unique_ptr<DoKDistributor> m_distributor;
57 bool m_use_dok = true;
58 std::unique_ptr<SimpleCSRDistributor> m_simple_csr_distibutor;
59};
60
61} // namespace Alien
IMatrixImpl.h.
IMatrixImpl(const MultiMatrixImpl *multi_impl, BackEndId backend="")
Constructor.
Multi matrices representation container.
void clear() override
Demande la lib�ration des donn�es.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17