-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathutils.cpp
52 lines (45 loc) · 1.3 KB
/
utils.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
#include "utils.h"
#include <cstdint>
#include <math.h>
int16_t sin_table[2048];
//from: http://dspguru.com/dsp/tricks/magnitude-estimator/
uint16_t rectangular_2_magnitude(int16_t i, int16_t q)
{
//Measure magnitude
const int16_t absi = i>0?i:-i;
const int16_t absq = q>0?q:-q;
return absi > absq ? absi + absq / 4 : absq + absi / 4;
}
//from: https://dspguru.com/dsp/tricks/fixed-point-atan2-with-self-normalization/
//converted to fixed point
int16_t rectangular_2_phase(int16_t i, int16_t q)
{
//handle condition where phase is unknown
if(i==0 && q==0) return 0;
const int16_t absi=i>0?i:-i;
int16_t angle=0;
if (q>=0)
{
//scale r so that it lies in range -8192 to 8192
const int16_t r = ((int32_t)(q - absi) << 13) / (q + absi);
angle = 8192 - r;
}
else
{
//scale r so that it lies in range -8192 to 8192
const int16_t r = ((int32_t)(q + absi) << 13) / (absi - q);
angle = (3 * 8192) - r;
}
//angle lies in range -32768 to 32767
if (i < 0) return(-angle); // negate if in quad III or IV
else return(angle);
}
void initialise_luts()
{
//pre-generate sin/cos lookup tables
float scaling_factor = (1 << 15) - 1;
for(uint16_t idx=0; idx<2048; idx++)
{
sin_table[idx] = roundf(sinf(2.0*M_PI*idx/2048.0) * scaling_factor);
}
}