f4dee3d6ac0762271fa2de8e5c471ab1a19ecf0b
[debian/gnuradio] / gnuradio-core / src / lib / filter / gr_interp_fir_filter_fcc.h
1 /* -*- c++ -*- */
2 /*
3  * Copyright 2004 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 /*
24  * WARNING: This file is automatically generated by generate_gr_fir_filter_XXX.py
25  * Any changes made to this file will be overwritten.
26  */
27
28 #ifndef INCLUDED_GR_INTERP_FIR_FILTER_FCC_H
29 #define INCLUDED_GR_INTERP_FIR_FILTER_FCC_H
30
31 #include <gr_sync_interpolator.h>
32
33 class gr_interp_fir_filter_fcc;
34 typedef boost::shared_ptr<gr_interp_fir_filter_fcc> gr_interp_fir_filter_fcc_sptr;
35 gr_interp_fir_filter_fcc_sptr gr_make_interp_fir_filter_fcc (unsigned interpolation, const std::vector<gr_complex> &taps);
36
37 class gr_fir_fcc;
38
39 /*!
40  * \brief Interpolating FIR filter with float input, gr_complex output and gr_complex taps
41  * \ingroup filter_blk
42  */
43 class gr_interp_fir_filter_fcc : public gr_sync_interpolator
44 {
45  private:
46   friend gr_interp_fir_filter_fcc_sptr gr_make_interp_fir_filter_fcc (unsigned interpolation, const std::vector<gr_complex> &taps);
47
48   std::vector<gr_complex>       d_new_taps;
49   bool                  d_updated;
50   std::vector<gr_fir_fcc *> d_firs;
51
52   /*!
53    * Construct a FIR filter with the given taps
54    */
55   gr_interp_fir_filter_fcc (unsigned interpolation, const std::vector<gr_complex> &taps);
56
57   void install_taps (const std::vector<gr_complex> &taps);
58
59  public:
60   ~gr_interp_fir_filter_fcc ();
61
62   void set_taps (const std::vector<gr_complex> &taps);
63
64   int work (int noutput_items,
65             gr_vector_const_void_star &input_items,
66             gr_vector_void_star &output_items);
67 };
68
69 #endif