30#ifndef FULLMATCLUSTER_HPP
31#define FULLMATCLUSTER_HPP
33#include "../DenseMat.hpp"
35#include <ezp/ezp/pgesv.hpp>
36#include <ezp/ezp/pposv.hpp>
41 int solve_trs(Mat<T>&, Mat<T>&&);
50 :
DenseMat<
T>(in_rows, in_cols, in_rows * in_cols)
53 unique_ptr<MetaMat<T>>
make_copy()
override {
return std::make_unique<FullMatBaseCluster>(*
this); }
61 T operator()(
const uword in_row,
const uword in_col)
const override {
return this->
memory[in_row + in_col * this->
n_rows]; }
63 T&
at(
const uword in_row,
const uword in_col)
override {
68 Mat<T>
operator*(
const Mat<T>&)
const override;
72 static constexpr char TRAN =
'N';
73 static constexpr T ALPHA =
T(1), BETA =
T(0);
75 Mat<T> C(arma::size(B));
77 const auto M =
static_cast<blas_int
>(this->n_rows);
78 const auto N =
static_cast<blas_int
>(this->n_cols);
81 static constexpr blas_int INC = 1;
83 if constexpr(std::is_same_v<T, float>) {
85 arma_fortran(arma_sgemv)(&TRAN, &
M, &
N, (
E*)&ALPHA, (
E*)this->memptr(), &
M, (
E*)B.memptr(), &INC, (
E*)&BETA, (
E*)C.memptr(), &INC);
89 arma_fortran(arma_dgemv)(&TRAN, &
M, &
N, (
E*)&ALPHA, (
E*)this->memptr(), &
M, (
E*)B.memptr(), &INC, (
E*)&BETA, (
E*)C.memptr(), &INC);
93 const auto K =
static_cast<blas_int
>(B.n_cols);
95 if constexpr(std::is_same_v<T, float>) {
97 arma_fortran(arma_sgemm)(&TRAN, &TRAN, &
M, &
K, &
N, (
E*)&ALPHA, (
E*)this->memptr(), &
M, (
E*)B.memptr(), &
N, (
E*)&BETA, (
E*)C.memptr(), &
M);
101 arma_fortran(arma_dgemm)(&TRAN, &TRAN, &
M, &
K, &
N, (
E*)&ALPHA, (
E*)this->memptr(), &
M, (
E*)B.memptr(), &
N, (
E*)&BETA, (
E*)C.memptr(), &
M);
108#pragma GCC diagnostic push
109#pragma GCC diagnostic ignored "-Wnarrowing"
111 if(this->factored)
return this->solve_trs(X, std::move(B));
113 suanpan_assert([&] {
if(this->n_rows != this->n_cols)
throw std::invalid_argument(
"requires a square matrix"); });
115 this->factored =
true;
117 const auto INFO =
bcast_from_root(solver.solve({this->n_rows, this->n_cols, this->memptr()}, {B.n_rows, B.n_cols, B.memptr()}));
120 else suanpan_error(
"Error code {} received, the matrix is probably singular.\n", INFO);
126 const auto INFO =
bcast_from_root(solver.solve({B.n_rows, B.n_cols, B.memptr()}));
129 else suanpan_error(
"Error code {} received, the matrix is probably singular.\n", INFO);
133#pragma GCC diagnostic pop
A DenseMat class that holds matrices.
Definition DenseMat.hpp:39
std::unique_ptr< T[]> memory
Definition DenseMat.hpp:48
Definition FullMatCluster.hpp:38
unique_ptr< MetaMat< T > > make_copy() override
Definition FullMatCluster.hpp:53
void nullify(const uword K) override
Definition FullMatCluster.hpp:55
FullMatBaseCluster(const uword in_rows, const uword in_cols)
Definition FullMatCluster.hpp:49
T & at(const uword in_row, const uword in_col) override
Access element with bound check.
Definition FullMatCluster.hpp:63
T operator()(const uword in_row, const uword in_col) const override
Access element (read-only), returns zero if out-of-bound.
Definition FullMatCluster.hpp:61
A FullMatCluster class that holds matrices.
void for_each(const IT start, const IT end, F &&FN)
Definition utility.h:28
void suanpan_assert(const std::function< void()> &F)
Definition suanPan.h:363
auto bcast_from_root(T &&object)
Definition suanPan.h:254
#define suanpan_error(...)
Definition suanPan.h:376