GNU Radio 3.4.2 C++ API
|
00001 /* -*- c++ -*- */ 00002 /* 00003 * Copyright 2007 Free Software Foundation, Inc. 00004 * 00005 * This file is part of GNU Radio 00006 * 00007 * GNU Radio is free software; you can redistribute it and/or modify 00008 * it under the terms of the GNU General Public License as published by 00009 * the Free Software Foundation; either version 3, or (at your option) 00010 * any later version. 00011 * 00012 * GNU Radio is distributed in the hope that it will be useful, 00013 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00014 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00015 * GNU General Public License for more details. 00016 * 00017 * You should have received a copy of the GNU General Public License 00018 * along with GNU Radio; see the file COPYING. If not, write to 00019 * the Free Software Foundation, Inc., 51 Franklin Street, 00020 * Boston, MA 02110-1301, USA. 00021 */ 00022 00023 // WARNING: this file is machine generated. Edits will be over written 00024 00025 #ifndef INCLUDED_GR_PEAK_DETECTOR_SB_H 00026 #define INCLUDED_GR_PEAK_DETECTOR_SB_H 00027 00028 #include <gr_sync_block.h> 00029 00030 class gr_peak_detector_sb; 00031 typedef boost::shared_ptr<gr_peak_detector_sb> gr_peak_detector_sb_sptr; 00032 00033 gr_peak_detector_sb_sptr gr_make_peak_detector_sb (float threshold_factor_rise = 0.25, 00034 float threshold_factor_fall = 0.40, 00035 int look_ahead = 10, 00036 float alpha = 0.001); 00037 00038 /*! 00039 * \brief Detect the peak of a signal 00040 * \ingroup level_blk 00041 * 00042 * If a peak is detected, this block outputs a 1, 00043 * or it outputs 0's. 00044 * 00045 * \param threshold_factor_rise The threshold factor determins when a peak 00046 * has started. An average of the signal is calculated and when the 00047 * value of the signal goes over threshold_factor_rise*average, we 00048 * start looking for a peak. 00049 * \param threshold_factor_fall The threshold factor determins when a peak 00050 * has ended. An average of the signal is calculated and when the 00051 * value of the signal goes bellow threshold_factor_fall*average, we 00052 * stop looking for a peak. 00053 * \param look_ahead The look-ahead value is used when the threshold is 00054 * found to look if there another peak within this step range. 00055 * If there is a larger value, we set that as the peak and look ahead 00056 * again. This is continued until the highest point is found with 00057 * This look-ahead range. 00058 * \param alpha The gain value of a moving average filter 00059 */ 00060 class gr_peak_detector_sb : public gr_sync_block 00061 { 00062 friend gr_peak_detector_sb_sptr gr_make_peak_detector_sb (float threshold_factor_rise, 00063 float threshold_factor_fall, 00064 int look_ahead, float alpha); 00065 00066 gr_peak_detector_sb (float threshold_factor_rise, 00067 float threshold_factor_fall, 00068 int look_ahead, float alpha); 00069 00070 private: 00071 float d_threshold_factor_rise; 00072 float d_threshold_factor_fall; 00073 int d_look_ahead; 00074 float d_avg_alpha; 00075 float d_avg; 00076 unsigned char d_found; 00077 00078 public: 00079 00080 /*! \brief Set the threshold factor value for the rise time 00081 * \param thr new threshold factor 00082 */ 00083 void set_threshold_factor_rise(float thr) { d_threshold_factor_rise = thr; } 00084 00085 /*! \brief Set the threshold factor value for the fall time 00086 * \param thr new threshold factor 00087 */ 00088 void set_threshold_factor_fall(float thr) { d_threshold_factor_fall = thr; } 00089 00090 /*! \brief Set the look-ahead factor 00091 * \param look new look-ahead factor 00092 */ 00093 void set_look_ahead(int look) { d_look_ahead = look; } 00094 00095 /*! \brief Set the running average alpha 00096 * \param alpha new alpha for running average 00097 */ 00098 void set_alpha(int alpha) { d_avg_alpha = alpha; } 00099 00100 /*! \brief Get the threshold factor value for the rise time 00101 * \return threshold factor 00102 */ 00103 float threshold_factor_rise() { return d_threshold_factor_rise; } 00104 00105 /*! \brief Get the threshold factor value for the fall time 00106 * \return threshold factor 00107 */ 00108 float threshold_factor_fall() { return d_threshold_factor_fall; } 00109 00110 /*! \brief Get the look-ahead factor value 00111 * \return look-ahead factor 00112 */ 00113 int look_ahead() { return d_look_ahead; } 00114 00115 /*! \brief Get the alpha value of the running average 00116 * \return alpha 00117 */ 00118 float alpha() { return d_avg_alpha; } 00119 00120 int work (int noutput_items, 00121 gr_vector_const_void_star &input_items, 00122 gr_vector_void_star &output_items); 00123 }; 00124 00125 #endif