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

« back to all changes in this revision

Viewing changes to gnuradio-core/src/lib/general/gr_multiply_vii.cc

  • 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 2004 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: this file is machine generated.  Edits will be over written
24
 
 
25
 
#ifdef HAVE_CONFIG_H
26
 
#include "config.h"
27
 
#endif
28
 
 
29
 
#include <gr_multiply_vii.h>
30
 
#include <gr_io_signature.h>
31
 
 
32
 
gr_multiply_vii_sptr
33
 
gr_make_multiply_vii (size_t nitems_per_block)
34
 
{
35
 
  return gr_multiply_vii_sptr (new gr_multiply_vii (nitems_per_block));
36
 
}
37
 
 
38
 
gr_multiply_vii::gr_multiply_vii (size_t nitems_per_block)
39
 
  : gr_sync_block ("multiply_vii",
40
 
                   gr_make_io_signature (1, -1, sizeof (int)*nitems_per_block),
41
 
                   gr_make_io_signature (1,  1, sizeof (int)*nitems_per_block))
42
 
{
43
 
}
44
 
 
45
 
int
46
 
gr_multiply_vii::work (int noutput_items,
47
 
                   gr_vector_const_void_star &input_items,
48
 
                   gr_vector_void_star &output_items)
49
 
{
50
 
  int *optr = (int *) output_items[0];
51
 
 
52
 
  int ninputs = input_items.size ();
53
 
  int nitems_per_block = output_signature()->sizeof_stream_item(0)/sizeof(int);
54
 
 
55
 
  for (int i = 0; i < noutput_items; i++){
56
 
    for (int j = 0; j < nitems_per_block; j++){
57
 
      int acc = ((int *) input_items[0])[i*nitems_per_block+j];
58
 
      for (int k = 1; k < ninputs; k++)
59
 
        acc *= ((int *) input_items[k])[i*nitems_per_block+j];
60
 
 
61
 
      *optr++ = (int) acc;
62
 
    }
63
 
  }
64
 
  return noutput_items;
65
 
}