diff options
author | Johnathan Corgan | 2012-06-29 08:30:23 -0700 |
---|---|---|
committer | Johnathan Corgan | 2012-06-29 08:30:23 -0700 |
commit | bfcc9dc634cc8d7da77b109a7ad9cd90714fd768 (patch) | |
tree | 2f739f2b13068294b4fe5846bb27eb2f160313f1 /gr-blocks/lib/integrate_XX_impl.cc.t | |
parent | f2e815329402f170231c054e108b531094d046be (diff) | |
download | gnuradio-bfcc9dc634cc8d7da77b109a7ad9cd90714fd768.tar.gz gnuradio-bfcc9dc634cc8d7da77b109a7ad9cd90714fd768.tar.bz2 gnuradio-bfcc9dc634cc8d7da77b109a7ad9cd90714fd768.zip |
blocks: added gr::blocks::integrate_XX with ss ii ff cc
Diffstat (limited to 'gr-blocks/lib/integrate_XX_impl.cc.t')
-rw-r--r-- | gr-blocks/lib/integrate_XX_impl.cc.t | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/gr-blocks/lib/integrate_XX_impl.cc.t b/gr-blocks/lib/integrate_XX_impl.cc.t new file mode 100644 index 000000000..4c82729e3 --- /dev/null +++ b/gr-blocks/lib/integrate_XX_impl.cc.t @@ -0,0 +1,68 @@ +/* -*- c++ -*- */ +/* + * Copyright 2004,2009,2010,2012 Free Software Foundation, Inc. + * + * This file is part of GNU Radio + * + * GNU Radio is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3, or (at your option) + * any later version. + * + * GNU Radio is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GNU Radio; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + +// @WARNING@ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <@NAME_IMPL@.h> +#include <gr_io_signature.h> + +namespace gr { + namespace blocks { + + @NAME@::sptr @NAME@::make(int decim) + { + return gnuradio::get_initial_sptr(new @NAME_IMPL@(decim)); + } + + @NAME_IMPL@::@NAME_IMPL@(int decim) + : gr_sync_decimator("@NAME@", + gr_make_io_signature(1, 1, sizeof (@I_TYPE@)), + gr_make_io_signature(1, 1, sizeof (@O_TYPE@)), + decim), + d_decim(decim), + d_count(0) + { + } + + int + @NAME_IMPL@::work(int noutput_items, + gr_vector_const_void_star &input_items, + gr_vector_void_star &output_items) + { + const @I_TYPE@ *in = (const @I_TYPE@ *)input_items[0]; + @O_TYPE@ *out = (@O_TYPE@ *)output_items[0]; + + for (int i = 0; i < noutput_items; i++) { + out[i] = (@O_TYPE@)0; + for (int j = 0; j < d_decim; j++) + out[i] += in[i*d_decim+j]; + } + + return noutput_items; + } + + } /* namespace blocks */ +} /* namespace gr */ |