From 362d45bb829a9b190586cca79717cc175f4d06d2 Mon Sep 17 00:00:00 2001 From: Tom Rondeau Date: Thu, 19 Apr 2012 16:29:39 -0400 Subject: digital: copying over rest of blocks from gnuradio-core to gr-digital. Includes moving GRC and QA code; new ones where missing. Have not removed blocks from gnuradio-core for compatibility. --- gr-digital/swig/digital_pfb_clock_sync_fff.i | 58 ++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 gr-digital/swig/digital_pfb_clock_sync_fff.i (limited to 'gr-digital/swig/digital_pfb_clock_sync_fff.i') diff --git a/gr-digital/swig/digital_pfb_clock_sync_fff.i b/gr-digital/swig/digital_pfb_clock_sync_fff.i new file mode 100644 index 000000000..956495e5d --- /dev/null +++ b/gr-digital/swig/digital_pfb_clock_sync_fff.i @@ -0,0 +1,58 @@ +/* -*- c++ -*- */ +/* + * Copyright 2009,2012 Free Software Foundation, Inc. + * + * This file is part of GNU Radio + * + * GNU Radio is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3, or (at your option) + * any later version. + * + * GNU Radio is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GNU Radio; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + +GR_SWIG_BLOCK_MAGIC(digital,pfb_clock_sync_fff); + +digital_pfb_clock_sync_fff_sptr +digital_make_pfb_clock_sync_fff(double sps, float loop_bw, + const std::vector &taps, + unsigned int filter_size=32, + float init_phase=0, + float max_rate_deviation=1.5, + int osps=1); + +class digital_pfb_clock_sync_fff : public gr_block +{ + public: + void set_taps (const std::vector &taps, + std::vector< std::vector > &ourtaps, + std::vector &ourfilter); + + std::vector< std::vector > get_taps(); + std::vector< std::vector > get_diff_taps(); + std::vector get_channel_taps(int channel); + std::vector get_diff_channel_taps(int channel); + std::string get_taps_as_string(); + std::string get_diff_taps_as_string(); + + void set_loop_bandwidth(float bw); + void set_damping_factor(float df); + void set_alpha(float alpha); + void set_beta(float beta); + void set_max_rate_deviation(float m); + + float get_loop_bandwidth() const; + float get_damping_factor() const; + float get_alpha() const; + float get_beta() const; + float get_clock_rate() const; +}; -- cgit