-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcomplex_ops.cpp
77 lines (67 loc) · 1.77 KB
/
complex_ops.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 "complex_ops.h"
void evenHC2magnitude(int samples, real *hc, real *magnitude)
{
magnitude[0] = hc[0];
idx I = samples/2;
for (idx i=1; i < I; ++i)
magnitude[i] = abs(hc[i], hc[samples-i]);
}
void evenHC2power(int samples, real *hc, real *power)
{
power[0] = hc[0];
idx I = samples/2;
for (idx i=1; i < I; ++i)
power[i] = abs2(hc[i], hc[samples-i]);
}
void evenHC2magnitude(Buffer<real> &hc, Buffer<real> &magnitude)
{
magnitude[0] = hc[0];
idx I = hc.size()/2, samples = hc.size();
for (idx i=1; i < I; ++i)
magnitude[i] = abs(hc[i], hc[samples-i]);
}
void evenHC2power(Buffer<real> &hc, Buffer<real> &power)
{
power[0] = hc[0];
idx I = hc.size()/2, samples = hc.size();
for (idx i=1; i < I; ++i)
power[i] = abs2(hc[i], hc[samples-i]);
}
/**
Z = Z1*Z2
@param[in] re1 - Re{Z1}
@param[in] im1 - Im{Z1}
@param[in] re2 - Re{Z2}
@param[in] im2 - Im{Z2}
@param[out] re - Re{Z}
@param[out] im - Im{Z}
*/
void complex_multiply(real re1, real im1, real re2, real im2, real *re, real *im)
{
*re = re1*re2 - im1*im2;
*im = re1*im2 + im1*re2;
}
// z = z1/z2
void complex_divide(real re1, real im1, real re2, real im2, real *re, real *im)
{
real denominator = re2*re2 + im2*im2;
*re = (re1*re2 + im1*im2) / denominator;
*im = (im1*re2 - re1*im2) / denominator;
}
/**
HalfComplex representation multiply
@param[in] z1 - Input HC array
@param[in] z2 - Input HC array
@param[out] z - Output HC array
@param[in] size - Size of the HC array
@warn: ONLY FOR EVEN TRANSFORMATIONS!!!
*/
void hc_multiply (real *z1, real *z2, real *z, idx size)
{
z[0] = z1[0]*z2[0];
const idx max_i = size/2;
for (idx i=1; i < max_i; ++i)
complex_multiply(z1[i], z1[size-i],
z2[i], z2[size-i],
&z[i], &z[size-i]);
}