diff options
author | Tom Rondeau | 2011-12-30 11:35:15 -0500 |
---|---|---|
committer | Tom Rondeau | 2011-12-30 11:35:15 -0500 |
commit | 6e52e9f86b40ccc38ee21068983936113e6b53dc (patch) | |
tree | 5634b85caae9bedf71b7a1e4f2e24b0f968e88ab /gr-digital/lib/digital_probe_mpsk_snr_est_c.cc | |
parent | 1091192d27aab20694e1597868df4962b39ad060 (diff) | |
download | gnuradio-6e52e9f86b40ccc38ee21068983936113e6b53dc.tar.gz gnuradio-6e52e9f86b40ccc38ee21068983936113e6b53dc.tar.bz2 gnuradio-6e52e9f86b40ccc38ee21068983936113e6b53dc.zip |
digital: added tag_nsamples placeholder into SNR probe block.
The intent of this block is to be able to pass messages containing the SNR at a set number of samples.
Diffstat (limited to 'gr-digital/lib/digital_probe_mpsk_snr_est_c.cc')
-rw-r--r-- | gr-digital/lib/digital_probe_mpsk_snr_est_c.cc | 38 |
1 files changed, 33 insertions, 5 deletions
diff --git a/gr-digital/lib/digital_probe_mpsk_snr_est_c.cc b/gr-digital/lib/digital_probe_mpsk_snr_est_c.cc index 3d97ff899..5cdfea96d 100644 --- a/gr-digital/lib/digital_probe_mpsk_snr_est_c.cc +++ b/gr-digital/lib/digital_probe_mpsk_snr_est_c.cc @@ -30,14 +30,17 @@ digital_probe_mpsk_snr_est_c_sptr digital_make_probe_mpsk_snr_est_c(snr_est_type_t type, + int msg_nsamples, double alpha) { return gnuradio::get_initial_sptr( - new digital_probe_mpsk_snr_est_c(type, alpha)); + new digital_probe_mpsk_snr_est_c(type, msg_nsamples, alpha)); } digital_probe_mpsk_snr_est_c::digital_probe_mpsk_snr_est_c( - snr_est_type_t type, double alpha) + snr_est_type_t type, + int msg_nsamples, + double alpha) : gr_sync_block ("probe_mpsk_snr_est_c", gr_make_io_signature(1, 1, sizeof(gr_complex)), gr_make_io_signature(0, 0, 0)) @@ -45,12 +48,16 @@ digital_probe_mpsk_snr_est_c::digital_probe_mpsk_snr_est_c( d_snr_est = NULL; d_type = type; + d_nsamples = msg_nsamples; + d_count = 0; set_alpha(alpha); set_type(type); // at least 1 estimator has to look back set_history(2); + + d_key = pmt::pmt_string_to_symbol("snr"); } digital_probe_mpsk_snr_est_c::~digital_probe_mpsk_snr_est_c() @@ -83,6 +90,12 @@ digital_probe_mpsk_snr_est_c::type() const return d_type; } +int +digital_probe_mpsk_snr_est_c::msg_nsample() const +{ + return d_nsamples; +} + double digital_probe_mpsk_snr_est_c::alpha() const { @@ -116,9 +129,24 @@ digital_probe_mpsk_snr_est_c::set_type(snr_est_type_t t) } void +digital_probe_mpsk_snr_est_c::set_msg_nsample(int n) +{ + if(n > 0) { + d_nsamples = n; + d_count = 0; // reset state + } + else + throw std::invalid_argument("digital_probe_mpsk_snr_est_c: msg_nsamples can't be <= 0\n"); +} + +void digital_probe_mpsk_snr_est_c::set_alpha(double alpha) { - d_alpha = alpha; - if(d_snr_est) - d_snr_est->set_alpha(d_alpha); + if((alpha >= 0) && (alpha <= 1.0)) { + d_alpha = alpha; + if(d_snr_est) + d_snr_est->set_alpha(d_alpha); + } + else + throw std::invalid_argument("digital_probe_mpsk_snr_est_c: alpha must be in [0,1]\n"); } |