~ubuntu-branches/ubuntu/trusty/gnuradio/trusty

« back to all changes in this revision

Viewing changes to gnuradio-core/src/lib/gengen/gr_moving_average_XX.cc.t

  • Committer: Bazaar Package Importer
  • Author(s): Kamal Mostafa
  • Date: 2010-03-13 07:46:01 UTC
  • mfrom: (2.1.2 sid)
  • Revision ID: james.westby@ubuntu.com-20100313074601-zjsa893a87bozyh7
Tags: 3.2.2.dfsg-1ubuntu1
* Fix build for Ubuntu lucid (LP: #260406)
  - add binary package dep for libusrp0, libusrp2-0: adduser
  - debian/rules clean: remove pre-built Qt moc files

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* -*- c++ -*- */
 
2
/*
 
3
 * Copyright 2008 Free Software Foundation, Inc.
 
4
 * 
 
5
 * This file is part of GNU Radio
 
6
 * 
 
7
 * GNU Radio is free software; you can redistribute it and/or modify
 
8
 * it under the terms of the GNU General Public License as published by
 
9
 * the Free Software Foundation; either version 3, or (at your option)
 
10
 * any later version.
 
11
 * 
 
12
 * GNU Radio is distributed in the hope that it will be useful,
 
13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
 * GNU General Public License for more details.
 
16
 * 
 
17
 * You should have received a copy of the GNU General Public License
 
18
 * along with GNU Radio; see the file COPYING.  If not, write to
 
19
 * the Free Software Foundation, Inc., 51 Franklin Street,
 
20
 * Boston, MA 02110-1301, USA.
 
21
 */
 
22
 
 
23
// @WARNING@
 
24
 
 
25
#ifdef HAVE_CONFIG_H
 
26
#include "config.h"
 
27
#endif
 
28
 
 
29
#include <@NAME@.h>
 
30
#include <gr_io_signature.h>
 
31
 
 
32
@SPTR_NAME@ 
 
33
gr_make_@BASE_NAME@ (int length, @O_TYPE@ scale, int max_iter)
 
34
{
 
35
  return @SPTR_NAME@ (new @NAME@ (length, scale, max_iter));
 
36
}
 
37
 
 
38
@NAME@::@NAME@ (int length, @O_TYPE@ scale, int max_iter)
 
39
  : gr_sync_block ("@BASE_NAME@",
 
40
                   gr_make_io_signature (1, 1, sizeof (@I_TYPE@)),
 
41
                   gr_make_io_signature (1, 1, sizeof (@O_TYPE@))),
 
42
  d_length(length),
 
43
  d_scale(scale),
 
44
  d_max_iter(max_iter),
 
45
  d_new_length(length),
 
46
  d_new_scale(scale),
 
47
  d_updated(false)
 
48
{
 
49
  set_history(length);
 
50
}
 
51
 
 
52
@NAME@::~@NAME@ ()
 
53
{
 
54
}
 
55
 
 
56
void
 
57
@NAME@::set_length_and_scale(int length, @O_TYPE@ scale)
 
58
{
 
59
  d_new_length = length;
 
60
  d_new_scale = scale;
 
61
  d_updated = true;
 
62
}
 
63
 
 
64
int 
 
65
@NAME@::work (int noutput_items,
 
66
              gr_vector_const_void_star &input_items,
 
67
              gr_vector_void_star &output_items)
 
68
{
 
69
  if (d_updated) {
 
70
    d_length = d_new_length;
 
71
    d_scale = d_new_scale;
 
72
    set_history(d_length);
 
73
    d_updated = false;
 
74
    return 0; // history requirements might have changed
 
75
  }
 
76
 
 
77
  const @I_TYPE@ *in = (const @I_TYPE@ *) input_items[0];
 
78
  @O_TYPE@ *out = (@O_TYPE@ *) output_items[0];
 
79
 
 
80
  @I_TYPE@ sum = 0;
 
81
  int num_iter = (noutput_items>d_max_iter) ? d_max_iter : noutput_items;
 
82
  for (int i = 0; i < d_length-1 ; i++) {
 
83
    sum += in[i];
 
84
  }
 
85
 
 
86
  for (int i = 0; i < num_iter; i++) {
 
87
    sum += in[i+d_length-1];
 
88
    out[i] = sum * d_scale;
 
89
    sum -= in[i];
 
90
  }
 
91
 
 
92
  return num_iter;
 
93
}