-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtensor.cpp
More file actions
67 lines (59 loc) · 1.11 KB
/
tensor.cpp
File metadata and controls
67 lines (59 loc) · 1.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include "tensor.h"
#include <iostream>
#include "sparsemat.h"
//==========================================================
// class Vec
Vec & Vec::operator=(const Vec & vec)
{
if(this == &vec)
return *this;
len = vec.len;
val = vec.val;
return *this;
}
Vec & Vec::operator=(Vec && vec)
{
if(this == &vec)
return *this;
len = vec.len;
val.swap(vec.val);
return *this;
}
INT Vec::GetLen() const
{
return len;
}
void Vec::PrintPartialTensor(INT num) const
{
for(INT i=0;i<num;i++)
std::cout<< val[i] <<std::endl;
}
Vec operator*(const SpaCSR & csr, const Vec & vec)
{
if(csr.col == vec.len)
{
Vec tmpvec(csr.row);
for(INT i=0;i<csr.row;i++)
{
DOUBLE row_sum = 0.0;
INT begin_idx = csr.row_vec[i];
INT end_idx = csr.row_vec[i+1];
for(INT j=0;j<(end_idx - begin_idx);j++ )
{
INT csr_idx = begin_idx + j;
row_sum += csr.val[csr_idx] * vec.val[csr.col_vec[csr_idx]];
}
tmpvec.val[i] = row_sum;
}
return tmpvec;
}
else
{
std::cout<<"the col number of matrix doesn't match the length of vec"<<std::endl;
exit(1);
}
}
DOUBLE & Vec::operator[](INT i)
{
return val[i];
}