CPPLapack
 All Classes Files Functions Variables Friends Pages
Functions
zhsmatrix-calc.hpp File Reference

Go to the source code of this file.

Functions

_zhsmatrix t (const zhsmatrix &mat)
 
_zhsmatrix conj (const zhsmatrix &mat)
 
_zhsmatrix conjt (const zhsmatrix &mat)
 
void idamax (CPPL_INT &i, CPPL_INT &j, const zhsmatrix &mat)
 
comple damax (const zhsmatrix &mat)
 

Function Documentation

_zhsmatrix t ( const zhsmatrix mat)
inline

return transposed zhsmatrix

Definition at line 3 of file zhsmatrix-calc.hpp.

References _(), conj(), and zhsmatrix::data.

4 {CPPL_VERBOSE_REPORT;
5  zhsmatrix newmat(mat);
6 
7  const std::vector<zcomponent>::iterator newmat_data_end =newmat.data.end();
8  for(std::vector<zcomponent>::iterator it=newmat.data.begin(); it!=newmat_data_end; it++){
9  it->v =std::conj(it->v);
10  }
11 
12  return _(newmat);
13 }
_zhsmatrix conj(const zhsmatrix &mat)
Complex Double-precision Hermitian Sparse Matrix Class.
Definition: zhsmatrix.hpp:3
_dcovector _(dcovector &vec)
_zhsmatrix conj ( const zhsmatrix mat)
inline

return its conjugate matrix

Definition at line 21 of file zhsmatrix-calc.hpp.

References _(), and zhsmatrix::data.

Referenced by t().

22 {CPPL_VERBOSE_REPORT;
23  zhsmatrix newmat(mat);
24 
25  const std::vector<zcomponent>::iterator newmat_data_end =newmat.data.end();
26  for(std::vector<zcomponent>::iterator it=newmat.data.begin(); it!=newmat_data_end; it++){
27  it->v =std::conj(it->v);
28  }
29 
30  return _(newmat);
31 }
_zhsmatrix conj(const zhsmatrix &mat)
Complex Double-precision Hermitian Sparse Matrix Class.
Definition: zhsmatrix.hpp:3
_dcovector _(dcovector &vec)
_zhsmatrix conjt ( const zhsmatrix mat)
inline

return its conjugate matrix

Definition at line 35 of file zhsmatrix-calc.hpp.

References _().

36 {CPPL_VERBOSE_REPORT;
37 #ifdef CPPL_DEBUG
38  WARNING_REPORT;
39  std::cerr << "This function call has no effect since the matrix is Hermitian." << std::endl;
40 #endif//CPPL_DEBUG
41 
42  zhsmatrix newmat(mat);
43  return _(newmat);
44 }
Complex Double-precision Hermitian Sparse Matrix Class.
Definition: zhsmatrix.hpp:3
_dcovector _(dcovector &vec)
void idamax ( CPPL_INT &  i,
CPPL_INT &  j,
const zhsmatrix mat 
)
inline

search the index of element having the largest absolute value in 0-based numbering system

Definition at line 53 of file zhsmatrix-calc.hpp.

References zhsmatrix::data.

54 {CPPL_VERBOSE_REPORT;
55  std::vector<zcomponent>::const_iterator itx(mat.data.begin());
56  double vmax =0.;
57 
58  const std::vector<zcomponent>::const_iterator mat_data_end =mat.data.end();
59  for(std::vector<zcomponent>::const_iterator it=mat.data.begin(); it!=mat_data_end; it++){
60  if( vmax < norm(it->v) ){
61  vmax =norm(it->v);
62  itx =it;
63  }
64  }
65 
66  i =itx->i;
67  j =itx->j;
68 }
_dgematrix i(const _dgbmatrix &mat)
friend _dgematrix i(const _dgematrix &)
std::vector< zcomponent > data
matrix data
Definition: zhsmatrix.hpp:11
comple damax ( const zhsmatrix mat)
inline

return its largest absolute value

Definition at line 72 of file zhsmatrix-calc.hpp.

References zhsmatrix::data.

73 {CPPL_VERBOSE_REPORT;
74  std::vector<zcomponent>::const_iterator itx(mat.data.begin());
75  double vmax =0.;
76 
77  const std::vector<zcomponent>::const_iterator mat_data_end =mat.data.end();
78  for(std::vector<zcomponent>::const_iterator it=mat.data.begin(); it!=mat_data_end; it++){
79  if( vmax < norm(it->v) ){
80  vmax =norm(it->v);
81  itx =it;
82  }
83  }
84 
85  return itx->v;
86 }
std::vector< zcomponent > data
matrix data
Definition: zhsmatrix.hpp:11