GNU Radio Manual and C++ API Reference
3.8.1.0
The Free & Open Software Radio Ecosystem
agc2_cc.h
Go to the documentation of this file.
1
/* -*- c++ -*- */
2
/*
3
* Copyright 2006,2012 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_ANALOG_AGC2_CC_H
24
#define INCLUDED_ANALOG_AGC2_CC_H
25
26
#include <
gnuradio/analog/agc2.h
>
27
#include <
gnuradio/analog/api.h
>
28
#include <
gnuradio/sync_block.h
>
29
30
namespace
gr
{
31
namespace
analog {
32
33
/*!
34
* \brief high performance Automatic Gain Control class with
35
* attack and decay rates.
36
* \ingroup level_controllers_blk
37
*
38
* \details
39
* For Power the absolute value of the complex number is used.
40
*/
41
class
ANALOG_API
agc2_cc
:
virtual
public
sync_block
42
{
43
public
:
44
// gr::analog::agc2_cc::sptr
45
typedef
boost::shared_ptr<agc2_cc>
sptr
;
46
47
/*!
48
* Build a complex value AGC loop block with attack and decay rates.
49
*
50
* \param attack_rate the update rate of the loop when in attack mode.
51
* \param decay_rate the update rate of the loop when in decay mode.
52
* \param reference reference value to adjust signal power to.
53
* \param gain initial gain value.
54
*/
55
static
sptr
make(
float
attack_rate = 1e-1,
56
float
decay_rate = 1e-2,
57
float
reference = 1.0,
58
float
gain = 1.0);
59
60
virtual
float
attack_rate()
const
= 0;
61
virtual
float
decay_rate()
const
= 0;
62
virtual
float
reference()
const
= 0;
63
virtual
float
gain()
const
= 0;
64
virtual
float
max_gain()
const
= 0;
65
66
virtual
void
set_attack_rate(
float
rate) = 0;
67
virtual
void
set_decay_rate(
float
rate) = 0;
68
virtual
void
set_reference(
float
reference) = 0;
69
virtual
void
set_gain(
float
gain) = 0;
70
virtual
void
set_max_gain(
float
max_gain) = 0;
71
};
72
73
}
/* namespace analog */
74
}
/* namespace gr */
75
76
#endif
/* INCLUDED_ANALOG_AGC2_CC_H */
ANALOG_API
#define ANALOG_API
Definition:
gr-analog/include/gnuradio/analog/api.h:30
gr::sync_block
synchronous 1:1 input to output with history
Definition:
sync_block.h:37
sync_block.h
agc2.h
gr::analog::agc2_cc::sptr
boost::shared_ptr< agc2_cc > sptr
Definition:
agc2_cc.h:45
gr
GNU Radio logging wrapper for log4cpp library (C++ port of log4j)
Definition:
basic_block.h:43
api.h
gr::analog::agc2_cc
high performance Automatic Gain Control class with attack and decay rates.
Definition:
agc2_cc.h:41
gr-analog
include
gnuradio
analog
agc2_cc.h
Generated by
1.8.16