diff options
author | trondeau | 2007-04-04 14:56:44 +0000 |
---|---|---|
committer | trondeau | 2007-04-04 14:56:44 +0000 |
commit | abda07ea005562a7031ddeec80f86595632de889 (patch) | |
tree | db30b7dfa7c9a5cb0cf27ab8a7c2d65860010fac /gnuradio-core/src/lib/general | |
parent | bae47cc41eda30e96de5e6d640f467760ae05c23 (diff) | |
download | gnuradio-abda07ea005562a7031ddeec80f86595632de889.tar.gz gnuradio-abda07ea005562a7031ddeec80f86595632de889.tar.bz2 gnuradio-abda07ea005562a7031ddeec80f86595632de889.zip |
updating documentation for Costas loop
git-svn-id: http://gnuradio.org/svn/gnuradio/trunk@4874 221aa14e-8319-0410-a670-987f0aec2ac5
Diffstat (limited to 'gnuradio-core/src/lib/general')
-rw-r--r-- | gnuradio-core/src/lib/general/gr_costas_loop_cc.h | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/gnuradio-core/src/lib/general/gr_costas_loop_cc.h b/gnuradio-core/src/lib/general/gr_costas_loop_cc.h index caa158498..501d3459a 100644 --- a/gnuradio-core/src/lib/general/gr_costas_loop_cc.h +++ b/gnuradio-core/src/lib/general/gr_costas_loop_cc.h @@ -31,6 +31,30 @@ class gr_costas_loop_cc; typedef boost::shared_ptr<gr_costas_loop_cc> gr_costas_loop_cc_sptr; +/*! \brief 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 + * + * \param alpha the loop gain used for phase adjustment + * \param beta the loop gain for frequency adjustments + * \param max_freq the maximum frequency deviation the loop can handle + * \param min_freq the minimum frequency deviation the loop can + * handle + * \param order the loop order, either 2 or 4 + */ gr_costas_loop_cc_sptr gr_make_costas_loop_cc (float alpha, float beta, float max_freq, float min_freq, @@ -40,9 +64,10 @@ gr_make_costas_loop_cc (float alpha, float beta, /*! * \brief Carrier tracking PLL for QPSK + * \ingroup block * input: complex; output: complex * <br>The Costas loop can have two output streams: - * stream 1 is the baseband I&Q; + * stream 1 is the baseband I and Q; * stream 2 is the normalized frequency of the loop * * \p order must be 2 or 4. @@ -62,8 +87,19 @@ class gr_costas_loop_cc : public gr_sync_block int order ) throw (std::invalid_argument); + /*! \breif the phase detector circuit for fourth-order loops + * \param a complex sample + * \return the phase error + */ float phase_detector_4(gr_complex sample) const; // for QPSK + + /*! \breif the phase detector circuit for second-order loops + * \param a complex sample + * \return the phase error + */ float phase_detector_2(gr_complex sample) const; // for BPSK + + float (gr_costas_loop_cc::*d_phase_detector)(gr_complex sample) const; public: |