GNU Radio 3.5.1 C++ API
|
00001 /* 00002 * Copyright 2006,2007 Free Software Foundation, Inc. 00003 * 00004 * This file is part of GNU Radio 00005 * 00006 * GNU Radio is free software; you can redistribute it and/or modify 00007 * it under the terms of the GNU General Public License as published by 00008 * the Free Software Foundation; either version 3, or (at your option) 00009 * any later version. 00010 * 00011 * GNU Radio is distributed in the hope that it will be useful, 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 * GNU General Public License for more details. 00015 * 00016 * You should have received a copy of the GNU General Public License 00017 * along with GNU Radio; see the file COPYING. If not, write to 00018 * the Free Software Foundation, Inc., 51 Franklin Street, 00019 * Boston, MA 02110-1301, USA. 00020 */ 00021 00022 #ifndef INCLUDED_PAGER_SLICER_FB_H 00023 #define INCLUDED_PAGER_SLICER_FB_H 00024 00025 #include <pager_api.h> 00026 #include <gr_sync_block.h> 00027 00028 class pager_slicer_fb; 00029 typedef boost::shared_ptr<pager_slicer_fb> pager_slicer_fb_sptr; 00030 00031 PAGER_API pager_slicer_fb_sptr pager_make_slicer_fb(float alpha); 00032 00033 /*! 00034 * \brief slicer description 00035 * \ingroup pager_blk 00036 */ 00037 class PAGER_API pager_slicer_fb : public gr_sync_block 00038 { 00039 private: 00040 friend PAGER_API pager_slicer_fb_sptr pager_make_slicer_fb(float alpha); 00041 pager_slicer_fb(float alpha); 00042 00043 unsigned char slice(float sample); 00044 00045 float d_alpha; // DC removal time constant 00046 float d_beta; // 1.0-d_alpha 00047 float d_avg; // Average value for DC offset subtraction 00048 00049 public: 00050 int work (int noutput_items, 00051 gr_vector_const_void_star &input_items, 00052 gr_vector_void_star &output_items); 00053 00054 float dc_offset() const { return d_avg; } 00055 }; 00056 00057 #endif /* INCLUDED_PAGER_SLICER_FB_H */