GNU Radio 3.6.4.1 C++ API
gr_rotator.h
Go to the documentation of this file.
1
/* -*- c++ -*- */
2
/*
3
* Copyright 2003,2008 Free Software Foundation, Inc.
4
*
5
* This file is part of GNU Radio
6
*
7
* GNU Radio is free software; you can redistribute it and/or modify
8
* it under the terms of the GNU General Public License as published by
9
* the Free Software Foundation; either version 3, or (at your option)
10
* any later version.
11
*
12
* GNU Radio is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
* GNU General Public License for more details.
16
*
17
* You should have received a copy of the GNU General Public License
18
* along with GNU Radio; see the file COPYING. If not, write to
19
* the Free Software Foundation, Inc., 51 Franklin Street,
20
* Boston, MA 02110-1301, USA.
21
*/
22
23
#ifndef _GR_ROTATOR_H_
24
#define _GR_ROTATOR_H_
25
26
#include <
gr_core_api.h
>
27
#include <
gr_complex.h
>
28
29
class
GR_CORE_API
gr_rotator
{
30
gr_complex
d_phase;
31
gr_complex
d_phase_incr;
32
unsigned
int
d_counter;
33
34
public
:
35
gr_rotator
() : d_phase (1), d_phase_incr (1), d_counter(0) { }
36
37
void
set_phase
(
gr_complex
phase) { d_phase = phase / abs(phase); }
38
void
set_phase_incr
(
gr_complex
incr) { d_phase_incr = incr / abs(incr); }
39
40
gr_complex
rotate
(
gr_complex
in){
41
d_counter++;
42
43
gr_complex
z = in * d_phase;
// rotate in by phase
44
d_phase *= d_phase_incr;
// incr our phase (complex mult == add phases)
45
46
if
((d_counter % 512) == 0)
47
d_phase /= abs(d_phase);
// Normalize to ensure multiplication is rotation
48
49
return
z;
50
}
51
52
};
53
54
#endif
/* _GR_ROTATOR_H_ */
gnuradio-core
src
lib
filter
gr_rotator.h
Generated on Sun Apr 28 2013 20:26:35 for GNU Radio 3.6.4.1 C++ API by
1.8.3.1