-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathposenc.cpp
77 lines (65 loc) · 1.95 KB
/
posenc.cpp
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
68
69
70
71
72
73
74
75
76
77
#include "posenc.h"
#include "layer_register.h"
#include "utils.h"
#include "math.h"
#include "omp.h"
Posenc::Posenc()
{
_use_last = 0;
}
Posenc::~Posenc()
{
}
int Posenc::load_model(const vector<string> ¶ms, FILE* fp)
{
vector<string> use_last_param = split(params[8], "=");
_use_last = atoi(use_last_param[1].c_str());
return 0;
}
void Posenc::forward(vector<Tensor*> &input, vector<Tensor*> &output)
{
Tensor* result;
if(output[0] == nullptr)
{
result = new Tensor();
}
else
{
result = output[0];
}
//TODO:判断更多尺寸情况
vector<float>* inputData = input[0]->get_data();
vector<int> outputShape = input[0]->get_shape();
result->set_shape(outputShape);
vector<float>* outputData = result->get_data();
vector<float>* freqs_cos = input[1]->get_data();
vector<float>* freqs_sin = input[2]->get_data();
for(int i=0; i<outputShape[0]; i++)
{
int freqOffset;
if(_use_last)
{
freqOffset = (input[1]->get_shape()[0]-1)*input[1]->get_shape()[1];
}
else
{
freqOffset = i*input[1]->get_shape()[1];
}
for(int j=0; j<outputShape[1]; j++)
{
for(int k=0; k<outputShape[2]/2; k++)
{
int dataOffset = (i*outputShape[1] + j)*outputShape[2];
outputData->data()[dataOffset+k*2] = inputData->data()[dataOffset+k*2] * freqs_cos->data()[freqOffset+k] - inputData->data()[dataOffset+k*2+1] * freqs_sin->data()[freqOffset+k];
outputData->data()[dataOffset+k*2+1] = inputData->data()[dataOffset+k*2] * freqs_sin->data()[freqOffset+k] + inputData->data()[dataOffset+k*2+1] * freqs_cos->data()[freqOffset+k];
}
}
}
output[0] = result;
}
int Posenc::CreateInstance(Layer* &layer)
{
layer = new Posenc();
return 0;
}
LayerRegistererWrapper posencCreateInstance("Posenc_t", Posenc::CreateInstance);