GNU Radio 3.6.4 C++ API
single_pole_iir_filter_ff.h
Go to the documentation of this file.
1
/* -*- c++ -*- */
2
/*
3
* Copyright 2004,2005 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
#ifndef INCLUDED_SINGLE_POLE_IIR_FILTER_FF_H
24
#define INCLUDED_SINGLE_POLE_IIR_FILTER_FF_H
25
26
#include <
filter/api.h
>
27
#include <
filter/single_pole_iir.h
>
28
#include <
gr_sync_block.h
>
29
#include <
gr_complex.h
>
30
31
namespace
gr {
32
namespace
filter {
33
34
/*!
35
* \brief single pole IIR filter with float input, float output
36
* \ingroup filter_blk
37
*
38
* The input and output satisfy a difference equation of the form
39
\htmlonly
40
\f{
41
y[n] - (1-alpha) y[n-1] = alpha x[n]
42
\f}
43
\endhtmlonly
44
45
\xmlonly
46
y[n] - (1-alpha) y[n-1] = alpha x[n]
47
\endxmlonly
48
49
* with the corresponding rational system function
50
\htmlonly
51
\f{
52
H(z) = \frac{alpha}{1 - (1-alpha) z^{-1}}
53
\f}
54
\endhtmlonly
55
56
\xmlonly
57
H(z) = \ frac{alpha}{1 - (1-alpha) z^{-1}}
58
\endxmlonly
59
60
* Note that some texts define the system function with a + in the
61
* denominator. If you're using that convention, you'll need to
62
* negate the feedback tap.
63
*/
64
class
FILTER_API
single_pole_iir_filter_ff
:
virtual
public
gr_sync_block
65
{
66
public
:
67
// gr::filter::single_pole_iir_filter_ff::sptr
68
typedef
boost::shared_ptr<single_pole_iir_filter_ff>
sptr
;
69
70
static
sptr
make(
double
alpha,
unsigned
int
vlen=1);
71
72
virtual
void
set_taps (
double
alpha) = 0;
73
};
74
75
}
/* namespace filter */
76
}
/* namespace gr */
77
78
#endif
/* INCLUDED_SINGLE_POLE_IIR_FILTER_FF_H */
gnuradio
gr-filter
include
filter
single_pole_iir_filter_ff.h
Generated by
1.8.1.2