10#ifndef EIGEN_PACKED_TRIANGULAR_MATRIX_VECTOR_H
11#define EIGEN_PACKED_TRIANGULAR_MATRIX_VECTOR_H
15template<
typename Index,
int Mode,
typename LhsScalar,
bool ConjLhs,
typename RhsScalar,
bool ConjRhs,
int StorageOrder>
18template<
typename Index,
int Mode,
typename LhsScalar,
bool ConjLhs,
typename RhsScalar,
bool ConjRhs>
21 typedef typename ScalarBinaryOpTraits<LhsScalar, RhsScalar>::ReturnType
ResScalar;
23 IsLower = (Mode & Lower) ==Lower,
24 HasUnitDiag = (Mode & UnitDiag)==UnitDiag,
25 HasZeroDiag = (Mode & ZeroDiag)==ZeroDiag
29 internal::conj_if<ConjRhs> cj;
30 typedef Map<const Matrix<LhsScalar,Dynamic,1> > LhsMap;
31 typedef typename conj_expr_if<ConjLhs,LhsMap>::type ConjLhsType;
32 typedef Map<Matrix<ResScalar,Dynamic,1> > ResMap;
36 Index
s = IsLower&&(HasUnitDiag||HasZeroDiag) ? 1 : 0;
37 Index r = IsLower ?
size-
i:
i+1;
39 ResMap(
res+(IsLower ?
s+
i : 0),r) +=
alpha * cj(rhs[
i]) * ConjLhsType(LhsMap(lhs+
s,r));
42 lhs += IsLower ?
size-
i:
i+1;
47template<
typename Index,
int Mode,
typename LhsScalar,
bool ConjLhs,
typename RhsScalar,
bool ConjRhs>
50 typedef typename ScalarBinaryOpTraits<LhsScalar, RhsScalar>::ReturnType
ResScalar;
52 IsLower = (Mode & Lower) ==Lower,
53 HasUnitDiag = (Mode & UnitDiag)==UnitDiag,
54 HasZeroDiag = (Mode & ZeroDiag)==ZeroDiag
58 internal::conj_if<ConjRhs> cj;
59 typedef Map<const Matrix<LhsScalar,Dynamic,1> > LhsMap;
60 typedef typename conj_expr_if<ConjLhs,LhsMap>::type ConjLhsType;
61 typedef Map<const Matrix<RhsScalar,Dynamic,1> > RhsMap;
62 typedef typename conj_expr_if<ConjRhs,RhsMap>::type ConjRhsType;
66 Index
s = !IsLower&&(HasUnitDiag||HasZeroDiag) ? 1 : 0;
67 Index r = IsLower ?
i+1 :
size-
i;
69 res[
i] +=
alpha * (ConjLhsType(LhsMap(lhs+
s,r)).cwiseProduct(ConjRhsType(RhsMap(rhs+(IsLower ? 0 :
s+
i),r)))).sum();
72 lhs += IsLower ?
i+1 :
size-
i;
int i
Definition BiCGSTAB_step_by_step.cpp:9
#define EIGEN_IMPLIES(a, b)
Definition Macros.h:1315
cout<< "Here is the matrix m:"<< endl<< m<< endl;Matrix< ptrdiff_t, 3, 1 > res
Definition PartialRedux_count.cpp:3
Scalar Scalar int size
Definition benchVecAdd.cpp:17
RealScalar s
Definition level1_cplx_impl.h:126
RealScalar alpha
Definition level1_cplx_impl.h:147
Definition BandTriangularSolver.h:13
ScalarBinaryOpTraits< LhsScalar, RhsScalar >::ReturnType ResScalar
Definition PackedTriangularMatrixVector.h:21
static void run(Index size, const LhsScalar *lhs, const RhsScalar *rhs, ResScalar *res, ResScalar alpha)
Definition PackedTriangularMatrixVector.h:27
static void run(Index size, const LhsScalar *lhs, const RhsScalar *rhs, ResScalar *res, ResScalar alpha)
Definition PackedTriangularMatrixVector.h:56
ScalarBinaryOpTraits< LhsScalar, RhsScalar >::ReturnType ResScalar
Definition PackedTriangularMatrixVector.h:50
Definition PackedTriangularMatrixVector.h:16