Alien  1.3.0
User documentation
Loading...
Searching...
No Matches
BaseDoKDirectMatrixBuilder.h
1/*
2 * Copyright 2021 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#ifndef ALIEN_BASEDOKDIRECTMATRIXBUILDER_H
20#define ALIEN_BASEDOKDIRECTMATRIXBUILDER_H
21
22#include <alien/utils/Precomp.h>
23
24#include <optional>
25
26namespace Alien
27{
28// Forward declarations.
29class IMatrix;
30class DoKMatrix;
31
32namespace Common
33{
34
35 /*!
36 * Use DoKMatrix to implement DirectMatrixBuilder.
37 *
38 * This data structure is not compressed like CSR, allowing easy insertion of values.
39 */
40 class ALIEN_EXPORT BaseDoKDirectMatrixBuilder
41 {
42 public:
43 /*!
44 * Build a new representation of a matrix
45 * @param self the multi-representation handler. It is locked during the life of this object.
46 */
47 // FIXME: This should be implemented with move-semantic.
50
51 /*!
52 * Add a contribution to a non-zero. Will create the non-zero if needed.
53 * Non-zero does not have to be local.
54 *
55 * @param row
56 * @param col
57 * @param value of the contribution
58 * @return a value if insertion is ok
59 */
60 std::optional<Real> contribute(Integer row, Integer col, Real value);
61
62 /*!
63 * Set a value to a non-zero. Will create the non-zero if needed.
64 * Non-zero does not have to be local, but behavior for gathering non-local non-zero is undefined.
65 * It is not possible to choose between 2 nnz from different processes.
66 *
67 * @param row
68 * @param col
69 * @param value of the contribution
70 * @return a value if insertion is ok
71 */
72 std::optional<Real> setNNZ(Integer row, Integer col, Real value);
73
74 /*!
75 * Sort and compact data.
76 *
77 * @return if successful.
78 */
79 bool assemble();
80
81 private:
82 //! Convenience reference to multi-repr manager.
83 IMatrix& m_matrix;
84 //! Pointer to data storage. Managed by m_matrix.
85 DoKMatrix* m_impl;
86 };
87
88} // namespace Common
89} // namespace Alien
90#endif //ALIEN_BASEDOKDIRECTMATRIXBUILDER_H
std::optional< Real > setNNZ(Integer row, Integer col, Real value)
std::optional< Real > contribute(Integer row, Integer col, Real value)
Interface for all matrices.
Definition IMatrix.h:51
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17