GNU Radio's SYMBOLRATE Package
symbolrate_impl.h
Go to the documentation of this file.
1/* -*- c++ -*- */
2/*
3 * Copyright 2017 <+YOU OR YOUR COMPANY+>.
4 *
5 * This is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 3, or (at your option)
8 * any later version.
9 *
10 * This software is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this software; see the file COPYING. If not, write to
17 * the Free Software Foundation, Inc., 51 Franklin Street,
18 * Boston, MA 02110-1301, USA.
19 */
20
21#ifndef INCLUDED_SYMBOLRATE_SYMBOLRATE_IMPL_H
22#define INCLUDED_SYMBOLRATE_SYMBOLRATE_IMPL_H
23
25
26namespace gr {
27 namespace symbolrate {
28
30 {
31 private:
32 // Nothing to declare in this block.
33 float d_samp_rate = 0.0f;
34
35 float d_valid_min = 0.0f;
36 float d_valid_max = 0.0f;
37
38 bool bLogRates = false;
39
40 // transition tracking
41 unsigned long samples_since_transition = 0;
42 float lastSymbolRate = 0.0f;
43 bool lastSymbol = false; // Used a boolean so I can NOT it to flip it.
44
45 float long_average = 0.0f;
46 unsigned long long_avg_samples = 0;
47
48 public:
49 symbolrate_impl(float samp_rate, float valid_min, float valid_max, bool logRates);
51
52 // Where all the action really happens
53 void forecast (int noutput_items, gr_vector_int &ninput_items_required);
54
55 int general_work(int noutput_items,
56 gr_vector_int &ninput_items,
57 gr_vector_const_void_star &input_items,
58 gr_vector_void_star &output_items);
59 };
60
61 } // namespace symbolrate
62} // namespace gr
63
64#endif /* INCLUDED_SYMBOLRATE_SYMBOLRATE_IMPL_H */
65
void forecast(int noutput_items, gr_vector_int &ninput_items_required)
int general_work(int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
symbolrate_impl(float samp_rate, float valid_min, float valid_max, bool logRates)
<+description of block+>
Definition symbolrate.h:37
Definition symbolrate.h:29
Definition symbolrate.h:28