CPPLapack
 All Classes Files Functions Variables Friends Pages
dssmatrix-_dssmatrix.hpp
Go to the documentation of this file.
1 //=============================================================================
2 /*! dssmatrix=_dssmatrix operator */
4 {CPPL_VERBOSE_REPORT;
5  shallow_copy(mat);
6  return *this;
7 }
8 
9 ///////////////////////////////////////////////////////////////////////////////
10 ///////////////////////////////////////////////////////////////////////////////
11 ///////////////////////////////////////////////////////////////////////////////
12 
13 //=============================================================================
14 /*! dssmatrix+=_dssmatrix operator */
16 {CPPL_VERBOSE_REPORT;
17 #ifdef CPPL_DEBUG
18  if(n!=mat.n){
19  ERROR_REPORT;
20  std::cerr << "These two matrises can not make a summation." << std::endl
21  << "Your input was (" << n << "x" << n << ") += (" << mat.n << "x" << mat.n << ")." << std::endl;
22  exit(1);
23  }
24 #endif//CPPL_DEBUG
25 
26  const std::vector<dcomponent>::const_iterator mat_data_end =mat.data.end();
27  for(std::vector<dcomponent>::const_iterator it=mat.data.begin(); it!=mat_data_end; it++){
28  (*this)(it->i,it->j) +=it->v;
29  }
30 
31  mat.destroy();
32  return *this;
33 }
34 
35 //=============================================================================
36 /*! dssmatrix-=_dssmatrix operator */
38 {CPPL_VERBOSE_REPORT;
39 #ifdef CPPL_DEBUG
40  if(n!=mat.n){
41  ERROR_REPORT;
42  std::cerr << "These two matrises can not make a sutraction." << std::endl
43  << "Your input was (" << n << "x" << n << ") -= (" << mat.n << "x" << mat.n << ")." << std::endl;
44  exit(1);
45  }
46 #endif//CPPL_DEBUG
47 
48  const std::vector<dcomponent>::const_iterator mat_data_end =mat.data.end();
49  for(std::vector<dcomponent>::const_iterator it=mat.data.begin(); it!=mat_data_end; it++){
50  (*this)(it->i,it->j) -=it->v;
51  }
52 
53  mat.destroy();
54  return *this;
55 }
56 
57 ///////////////////////////////////////////////////////////////////////////////
58 ///////////////////////////////////////////////////////////////////////////////
59 ///////////////////////////////////////////////////////////////////////////////
60 
61 //=============================================================================
62 /*! dssmatrix+_dssmatrix operator */
63 inline _dssmatrix operator+(const dssmatrix& matA, const _dssmatrix& matB)
64 {CPPL_VERBOSE_REPORT;
65 #ifdef CPPL_DEBUG
66  if(matA.n!=matB.n){
67  ERROR_REPORT;
68  std::cerr << "These two matrises can not make a summation." << std::endl
69  << "Your input was (" << matA.n << "x" << matA.n << ") + (" << matB.n << "x" << matB.n << ")." << std::endl;
70  exit(1);
71  }
72 #endif//CPPL_DEBUG
73 
74  dssmatrix newmat(matB);
75 
76  const std::vector<dcomponent>::const_iterator matA_data_end =matA.data.end();
77  for(std::vector<dcomponent>::const_iterator it=matA.data.begin(); it!=matA_data_end; it++){
78  newmat(it->i,it->j) +=it->v;
79  }
80 
81  return _(newmat);
82 }
83 
84 //=============================================================================
85 /*! dssmatrix-_dssmatrix operator */
86 inline _dssmatrix operator-(const dssmatrix& matA, const _dssmatrix& matB)
87 {CPPL_VERBOSE_REPORT;
88 #ifdef CPPL_DEBUG
89  if(matA.n!=matB.n){
90  ERROR_REPORT;
91  std::cerr << "These two matrises can not make a subtraction." << std::endl
92  << "Your input was (" << matA.n << "x" << matA.n << ") - (" << matB.n << "x" << matB.n << ")." << std::endl;
93  exit(1);
94  }
95 #endif//CPPL_DEBUG
96 
97  dssmatrix newmat(matB);
98 
99  const std::vector<dcomponent>::const_iterator matA_data_end =matA.data.end();
100  for(std::vector<dcomponent>::const_iterator it=matA.data.begin(); it!=matA_data_end; it++){
101  newmat(it->i,it->j) -=it->v;
102  }
103 
104  return _(newmat);
105 }
106 
107 //=============================================================================
108 /*! dssmatrix*_dssmatrix operator */
109 /*
110 inline _dgsmatrix operator*(const dssmatrix& matA, const _dssmatrix& matB)
111 {CPPL_VERBOSE_REPORT;
112 #ifdef CPPL_DEBUG
113  if(matA.n!=matB.n){
114  ERROR_REPORT;
115  std::cerr << "These two matrises can not make a product." << std::endl
116  << "Your input was (" << matA.n << "x" << matA.n << ") * (" << matB.n << "x" << matB.n << ")." << std::endl;
117  exit(1);
118  }
119 #endif//CPPL_DEBUG
120 
121  dssmatrix newmat( matA.n, 0 );
122 
123  for(CPPL_INT c=0; c<matA.vol; c++){
124  CPPL_INT k(matA.jndx[c]);
125  std::vector< std::pair<CPPL_INT,CPPL_INT> >::iterator p;
126  for(p=matB.line[k].begin(); p!=matB.line[k].end(); p++){
127  newmat(matA.indx[c],p->first) +=matA.array[c]*matB.array[p->second];
128  }
129  }
130 
131  matB.destroy();
132  return _(newmat);
133 }
134 */
std::vector< dcomponent > data
matrix data
Definition: dssmatrix.hpp:11
std::vector< dcomponent > data
matrix data
Definition: _dssmatrix.hpp:12
(DO NOT USE) Smart-temporary Real Double-precision Symmetric Sparse Matrix Class
Definition: _dssmatrix.hpp:3
dssmatrix & operator+=(const dssmatrix &)
void shallow_copy(const _dssmatrix &)
CPPL_INT n
matrix column size
Definition: _dssmatrix.hpp:11
_dssmatrix operator+(const dssmatrix &matA, const _dssmatrix &matB)
dssmatrix & operator=(const dssmatrix &)
dssmatrix & operator-=(const dssmatrix &)
Real Double-precision Symmetric Sparse Matrix Class.
Definition: dssmatrix.hpp:3
CPPL_INT n
matrix column size
Definition: dssmatrix.hpp:10
void destroy() const
_dcovector _(dcovector &vec)
_dssmatrix operator-(const dssmatrix &matA, const _dssmatrix &matB)