10#ifndef EIGEN_PACKED_TRIANGULAR_SOLVER_VECTOR_H
11#define EIGEN_PACKED_TRIANGULAR_SOLVER_VECTOR_H
15template<
typename LhsScalar,
typename RhsScalar,
typename Index,
int S
ide,
int Mode,
bool Conjugate,
int StorageOrder>
19template<
typename LhsScalar,
typename RhsScalar,
typename Index,
int Mode,
bool Conjugate>
23 IsLower = (Mode&Lower)==Lower
25 static void run(Index
size,
const LhsScalar* lhs, RhsScalar* rhs)
27 internal::conj_if<Conjugate> cj;
28 typedef Map<const Matrix<LhsScalar,Dynamic,1> > LhsMap;
29 typedef typename conj_expr_if<Conjugate,LhsMap>::type ConjLhsType;
31 lhs += IsLower ? 0 : (
size*(
size+1)>>1)-1;
32 for(Index pi=0; pi<
size; ++pi)
34 Index
i = IsLower ? pi :
size-pi-1;
35 Index
s = IsLower ? 0 : 1;
37 rhs[
i] -= (ConjLhsType(LhsMap(lhs+
s,pi))
38 .cwiseProduct(Map<
const Matrix<RhsScalar,Dynamic,1> >(rhs+(IsLower ? 0 :
i+1),pi))).sum();
39 if (!(Mode & UnitDiag))
40 rhs[
i] /= cj(lhs[IsLower ?
i : 0]);
41 IsLower ? lhs += pi+1 : lhs -= pi+2;
47template<
typename LhsScalar,
typename RhsScalar,
typename Index,
int Mode,
bool Conjugate>
51 IsLower = (Mode&Lower)==Lower
53 static void run(Index
size,
const LhsScalar* lhs, RhsScalar* rhs)
55 internal::conj_if<Conjugate> cj;
56 typedef Map<const Matrix<LhsScalar,Dynamic,1> > LhsMap;
57 typedef typename conj_expr_if<Conjugate,LhsMap>::type ConjLhsType;
59 lhs += IsLower ? 0 :
size*(
size-1)>>1;
60 for(Index pi=0; pi<
size; ++pi)
62 Index
i = IsLower ? pi :
size-pi-1;
63 Index r =
size - pi - 1;
64 if (!(Mode & UnitDiag))
65 rhs[
i] /= cj(lhs[IsLower ? 0 :
i]);
67 Map<Matrix<RhsScalar,Dynamic,1> >(rhs+(IsLower?
i+1 : 0),r) -=
68 rhs[
i] * ConjLhsType(LhsMap(lhs+(IsLower? 1 : 0),r));
69 IsLower ? lhs +=
size-pi : lhs -= r;
74template<
typename LhsScalar,
typename RhsScalar,
typename Index,
int Mode,
bool Conjugate,
int StorageOrder>
77 static void run(Index
size,
const LhsScalar* lhs, RhsScalar* rhs)
80 ((Mode&Upper)==Upper ? Lower : Upper) | (Mode&UnitDiag),
81 Conjugate,StorageOrder==RowMajor?ColMajor:RowMajor
82 >::run(
size, lhs, rhs);
int i
Definition BiCGSTAB_step_by_step.cpp:9
Scalar Scalar int size
Definition benchVecAdd.cpp:17
RealScalar s
Definition level1_cplx_impl.h:126
Definition BandTriangularSolver.h:13
static void run(Index size, const LhsScalar *lhs, RhsScalar *rhs)
Definition PackedTriangularSolverVector.h:53
static void run(Index size, const LhsScalar *lhs, RhsScalar *rhs)
Definition PackedTriangularSolverVector.h:77
static void run(Index size, const LhsScalar *lhs, RhsScalar *rhs)
Definition PackedTriangularSolverVector.h:25
Definition PackedTriangularSolverVector.h:16