spla
matrix.hpp
Go to the documentation of this file.
1 /**********************************************************************************/
2 /* This file is part of spla project */
3 /* https://github.com/SparseLinearAlgebra/spla */
4 /**********************************************************************************/
5 /* MIT License */
6 /* */
7 /* Copyright (c) 2023 SparseLinearAlgebra */
8 /* */
9 /* Permission is hereby granted, free of charge, to any person obtaining a copy */
10 /* of this software and associated documentation files (the "Software"), to deal */
11 /* in the Software without restriction, including without limitation the rights */
12 /* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell */
13 /* copies of the Software, and to permit persons to whom the Software is */
14 /* furnished to do so, subject to the following conditions: */
15 /* */
16 /* The above copyright notice and this permission notice shall be included in all */
17 /* copies or substantial portions of the Software. */
18 /* */
19 /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
20 /* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
21 /* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
22 /* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
23 /* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
24 /* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
25 /* SOFTWARE. */
26 /**********************************************************************************/
27 
28 #ifndef SPLA_MATRIX_HPP
29 #define SPLA_MATRIX_HPP
30 
31 #include "array.hpp"
32 #include "object.hpp"
33 #include "op.hpp"
34 #include "scalar.hpp"
35 #include "type.hpp"
36 
37 namespace spla {
38 
48  class Matrix : public Object {
49  public:
50  SPLA_API ~Matrix() override = default;
51  SPLA_API virtual uint get_n_rows() = 0;
52  SPLA_API virtual uint get_n_cols() = 0;
54  SPLA_API virtual Status set_format(FormatMatrix format) = 0;
55  SPLA_API virtual Status set_fill_value(const ref_ptr<Scalar>& value) = 0;
56  SPLA_API virtual Status set_reduce(ref_ptr<OpBinary> resolve_duplicates) = 0;
57  SPLA_API virtual Status set_int(uint row_id, uint col_id, std::int32_t value) = 0;
58  SPLA_API virtual Status set_uint(uint row_id, uint col_id, std::uint32_t value) = 0;
59  SPLA_API virtual Status set_float(uint row_id, uint col_id, float value) = 0;
60  SPLA_API virtual Status get_int(uint row_id, uint col_id, std::int32_t& value) = 0;
61  SPLA_API virtual Status get_uint(uint row_id, uint col_id, std::uint32_t& value) = 0;
62  SPLA_API virtual Status get_float(uint row_id, uint col_id, float& value) = 0;
63  SPLA_API virtual Status build(const ref_ptr<MemView>& keys1, const ref_ptr<MemView>& keys2, const ref_ptr<MemView>& values) = 0;
64  SPLA_API virtual Status read(ref_ptr<MemView>& keys1, ref_ptr<MemView>& keys2, ref_ptr<MemView>& values) = 0;
65  SPLA_API virtual Status clear() = 0;
66 
76  SPLA_API static ref_ptr<Matrix> make(uint n_rows, uint n_cols, const ref_ptr<Type>& type);
77  };
78 
83 }// namespace spla
84 
85 #endif//SPLA_MATRIX_HPP
Named storage format for library matrix data objects.
Status of library operation execution.
Generalized M x N dimensional matrix object.
Definition: matrix.hpp:48
virtual Status get_int(uint row_id, uint col_id, std::int32_t &value)=0
virtual Status read(ref_ptr< MemView > &keys1, ref_ptr< MemView > &keys2, ref_ptr< MemView > &values)=0
virtual Status set_fill_value(const ref_ptr< Scalar > &value)=0
virtual Status set_uint(uint row_id, uint col_id, std::uint32_t value)=0
virtual Status build(const ref_ptr< MemView > &keys1, const ref_ptr< MemView > &keys2, const ref_ptr< MemView > &values)=0
~Matrix() override=default
virtual ref_ptr< Type > get_type()=0
virtual uint get_n_cols()=0
static ref_ptr< Matrix > make(uint n_rows, uint n_cols, const ref_ptr< Type > &type)
Make new matrix instance with specified dim and values type.
Definition: matrix.cpp:33
virtual Status clear()=0
virtual Status get_uint(uint row_id, uint col_id, std::uint32_t &value)=0
virtual Status set_reduce(ref_ptr< OpBinary > resolve_duplicates)=0
virtual Status set_format(FormatMatrix format)=0
virtual Status get_float(uint row_id, uint col_id, float &value)=0
virtual Status set_float(uint row_id, uint col_id, float value)=0
virtual Status set_int(uint row_id, uint col_id, std::int32_t value)=0
virtual uint get_n_rows()=0
Base class for any library primitive.
Definition: object.hpp:47
Automates reference counting and behaves as shared smart pointer.
Definition: ref.hpp:117
#define SPLA_API
Definition: config.hpp:43
std::uint32_t uint
Library index and size type.
Definition: config.hpp:56
Definition: algorithm.hpp:37