spla
Loading...
Searching...
No Matches
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
37namespace 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;
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;
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
virtual ref_ptr< Type > get_type()=0
~Matrix() override=default
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