Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
BlockMatrix.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 <memory>
22
23#include <alien/ref/AlienRefSemanticPrecomp.h>
24
26#include <alien/data/IMatrix.h>
27#include <alien/data/Space.h>
29
30/*---------------------------------------------------------------------------*/
31/*---------------------------------------------------------------------------*/
32
33namespace Alien
34{
35
36/*---------------------------------------------------------------------------*/
37/*---------------------------------------------------------------------------*/
38
39class ALIEN_REFSEMANTIC_EXPORT BlockMatrix final : public IMatrix
40{
41 public:
42 BlockMatrix();
43
44 BlockMatrix(const Block& block, const MatrixDistribution& dist);
45
46 BlockMatrix(Integer nrows, Integer ncols, Integer nrows_local, const Block& block,
47 IMessagePassingMng* parallel_mng);
48
49 BlockMatrix(
50 Integer nrows, Integer ncols, const Block& block, IMessagePassingMng* parallel_mng);
51
52 BlockMatrix(BlockMatrix&& m);
53
54 ~BlockMatrix() {}
55
56 BlockMatrix& operator=(BlockMatrix&& m);
57
58 BlockMatrix(const BlockMatrix&) = delete;
59 BlockMatrix& operator=(const BlockMatrix&) = delete;
60
61 public:
62 void init(const Block& block, const MatrixDistribution& dist);
63
64 void free();
65
66 void clear();
67
68 // Pour les expressions
69 void visit(ICopyOnWriteMatrix&) const;
70
71 const MatrixDistribution& distribution() const;
72
73 const ISpace& rowSpace() const;
74
75 const ISpace& colSpace() const;
76
77 void setUserFeature(String feature);
78
79 bool hasUserFeature(String feature) const;
80
81 const Block& block() const;
82
83 public:
85
86 const MultiMatrixImpl* impl() const;
87
88 private:
89 std::shared_ptr<MultiMatrixImpl> m_impl;
90};
91
92/*---------------------------------------------------------------------------*/
93/*---------------------------------------------------------------------------*/
94
95} // namespace Alien
96
97/*---------------------------------------------------------------------------*/
98/*---------------------------------------------------------------------------*/
Block.h.
IMatrix.h.
MatrixDistribution.h.
Space.h.
MultiMatrixImpl * impl()
Get the multimatrix implementation.
const ISpace & rowSpace() const
Get row space associated to the matrix.
void visit(ICopyOnWriteMatrix &) const
Visit method.
const ISpace & colSpace() const
Get col space associated to the matrix.
Block elements for block matrices.
Definition Block.h:45
IMatrix()
Constructor.
Definition IMatrix.h:54
Interface for algebraic space objects.
Definition ISpace.h:44
Computes a matrix distribution.
Multi matrices representation container.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17