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 
24 #include <symbolrate/symbolrate.h>
25 
26 namespace gr {
27  namespace symbolrate {
28 
29  class symbolrate_impl : public symbolrate
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)
<+description of block+>
Definition: symbolrate.h:36
Definition: symbolrate_impl.h:29
symbolrate_impl(float samp_rate, float valid_min, float valid_max, bool logRates)
int general_work(int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)