#include <gr_costas_loop_cc.h>


input: complex; output: complex
The Costas loop can have two output streams: stream 1 is the baseband I and Q; stream 2 is the normalized frequency of the loop.
order must be 2 or 4.
Public Member Functions | |
| int | work (int noutput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items) |
| just like gr_block::general_work, only this arranges to call consume_each for you | |
Friends | |
| gr_costas_loop_cc_sptr | gr_make_costas_loop_cc (float alpha, float beta, float max_freq, float min_freq, int order) throw (std::invalid_argument) |
| A Costas loop carrier recovery module. | |
| int gr_costas_loop_cc::work | ( | int | noutput_items, | |
| gr_vector_const_void_star & | input_items, | |||
| gr_vector_void_star & | output_items | |||
| ) | [virtual] |
just like gr_block::general_work, only this arranges to call consume_each for you
The user must override work to define the signal processing code
Implements gr_sync_block.
References M_TWOPI.
| gr_costas_loop_cc_sptr gr_make_costas_loop_cc | ( | float | alpha, | |
| float | beta, | |||
| float | max_freq, | |||
| float | min_freq, | |||
| int | order | |||
| ) | throw (std::invalid_argument) [friend] |
A Costas loop carrier recovery module.
The Costas loop locks to the center frequency of a signal and downconverts it to baseband. The second (order=2) order loop is used for BPSK where the real part of the output signal is the baseband BPSK signal and the imaginary part is the error signal. When order=4, it can be used for quadrature modulations where both I and Q (real and imaginary) are outputted.
More details can be found online:
J. Feigin, "Practical Costas loop design: Designing a simple and inexpensive BPSK Costas loop carrier recovery circuit," RF signal processing, pp. 20-36, 2002.
http://rfdesign.com/images/archive/0102Feigin20.pdf
| alpha | the loop gain used for phase adjustment | |
| beta | the loop gain for frequency adjustments | |
| max_freq | the maximum frequency deviation (normalized frequency) the loop can handle | |
| min_freq | the minimum frequency deviation (normalized frequency) the loop can handle | |
| order | the loop order, either 2 or 4 |
1.5.5