Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
RedistributorVector.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
23#include <alien/kernels/simple_csr/redistribution/SimpleCSRVectorRedistributor.h>
24#include <alien/utils/Precomp.h>
25
26namespace Alien
27{
28
29// Forward declarations
31
32class RedistributorVector : public IVectorImpl
33{
34 public:
35 RedistributorVector(const MultiVectorImpl* src_impl);
36 virtual ~RedistributorVector() {}
37
38 void init(const VectorDistribution& dist, const bool need_allocate) override;
39
41 void clear() override;
42
43 std::shared_ptr<MultiVectorImpl> updateTargetPM(const RedistributorCommPlan* commPlan);
44 void updateSuperPM(MultiVectorImpl* tgt_impl, const RedistributorCommPlan* commPlan);
45
46 std::shared_ptr<MultiVectorImpl> redistribute();
47 void redistributeBack(SimpleCSRVector<Real>& vec_tgt) const;
48
49 private:
50 const IMessagePassingMng* m_super_pm;
51 std::shared_ptr<MultiVectorImpl> m_tgt_impl;
52 std::shared_ptr<VectorDistribution> m_tgt_dist;
53 std::unique_ptr<SimpleCSRVectorRedistributor> m_distributor;
54};
55
56} // namespace Alien
IVectorImpl.h.
MultiVectorImpl.h.
IVectorImpl(const MultiVectorImpl *multi_impl, BackEndId backend="")
Constructor.
void clear() override
Clear data.
void init(const VectorDistribution &dist, const bool need_allocate) override
Initialize vector datas.
Computes a vector distribution.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17