Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
RedistributedVector.cc
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#include <alien/ref/data/scalar/RedistributedVector.h>
20
22#include <alien/kernels/simple_csr/SimpleCSRBackEnd.h>
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27namespace Alien
28{
29
30using namespace Arccore;
31
32/*---------------------------------------------------------------------------*/
33/*---------------------------------------------------------------------------*/
34
35RedistributedVector::RedistributedVector(IVector& vector, Redistributor& redist)
36: m_impl(redist.redistribute(vector.impl()))
37{}
38
39RedistributedVector::~RedistributedVector() {}
40
41/*---------------------------------------------------------------------------*/
42
44{
45 v.accept(m_impl);
46}
47
48/*---------------------------------------------------------------------------*/
49
51RedistributedVector::distribution() const
52{
53 return m_impl->distribution();
54}
55
56/*---------------------------------------------------------------------------*/
57
58const ISpace&
60{
61 return m_impl->space();
62}
63
64/*---------------------------------------------------------------------------*/
65
66void RedistributedVector::setUserFeature(String feature)
67{
68 m_impl->setFeature(feature);
69}
70
71/*---------------------------------------------------------------------------*/
72
73bool RedistributedVector::hasUserFeature(String feature) const
74{
75 return m_impl->hasFeature(feature);
76}
77
78/*---------------------------------------------------------------------------*/
79
80MultiVectorImpl*
82{
83 if (!m_impl) {
84 m_impl.reset(new MultiVectorImpl());
85 }
86 /* JMG ????
87 else if (!m_impl.unique()) { // Need to clone due to other references.
88 m_impl.reset(m_impl->clone());
89 } */
90 return m_impl.get();
91}
92
93/*---------------------------------------------------------------------------*/
94
95const MultiVectorImpl*
97{
98 return m_impl.get();
99}
100
101/*---------------------------------------------------------------------------*/
102/*---------------------------------------------------------------------------*/
103
104} // namespace Alien
105
106/*---------------------------------------------------------------------------*/
107/*---------------------------------------------------------------------------*/
MultiVectorImpl.h.
Interface for all vectors.
Definition IVector.h:51
const ISpace & space() const
Get the space associated to the vector.
MultiVectorImpl * impl()
Get the multivector implementation.
void visit(ICopyOnWriteVector &) const
Visit method.
Change MultiObj current representation to another communicator.
Computes a vector distribution.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17