~ubuntu-branches/ubuntu/natty/pd-zexy/natty

« back to all changes in this revision

Viewing changes to src/mavg.c

  • Committer: Bazaar Package Importer
  • Author(s): Jonas Smedegaard, IOhannes m zmölnig, Jonas Smedegaard
  • Date: 2010-08-20 12:17:41 UTC
  • mfrom: (2.1.2 sid)
  • Revision ID: james.westby@ubuntu.com-20100820121741-4kxozn8b9rhee9fr
Tags: 2.2.3-1
* New upstream version

[ IOhannes m zmölnig ]
* Adopt package, on behalf of Multimedia Team.
  Closes: #546964
* Simply debian/rules with CDBS, and don't unconditionally strip
  binaries.
  Closes: #437763
* Install into /usr/lib/pd/extra/zexy/. Document usage in REAME.Debian
  and warn about change in NEWS.
* git'ify package. Add Vcs-* stanzas to control file.
* Use dpkg source format 3.0 (quilt). Drop build-dependency on quilt.

[ Jonas Smedegaard ]
* Enable CDBS copyright-check routine.
* Add copyright and licensing header to debian/rules.
* Add myself as uploader.
* Rewrite debian/copyright using rev. 135 of draft DEP5 format.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/******************************************************
 
2
 *
 
3
 * zexy - implementation file
 
4
 *
 
5
 * copyleft (c) IOhannes m zm�lnig
 
6
 *
 
7
 *   1999:forum::f�r::uml�ute:2004
 
8
 *
 
9
 *   institute of electronic music and acoustics (iem)
 
10
 *
 
11
 ******************************************************
 
12
 *
 
13
 * license: GNU General Public License v.2
 
14
 *
 
15
 ******************************************************/
 
16
 
 
17
 
 
18
#include "zexy.h"
 
19
 
 
20
/* mavg :: moving average filter */
 
21
 
 
22
static t_class *mavg_class;
 
23
 
 
24
typedef struct _mavg
 
25
{
 
26
  t_object x_obj;
 
27
 
 
28
  t_float n_inv;
 
29
  t_float avg;
 
30
  int size;
 
31
  t_float *buf, *wp;
 
32
} t_mavg;
 
33
 
 
34
static void mavg_resize(t_mavg *x, t_float f)
 
35
{
 
36
  int i;
 
37
  t_float *dumbuf;
 
38
 
 
39
  f = (int)f;
 
40
  if ((f<1) || (f == x->size)) return;
 
41
 
 
42
  freebytes(x->buf, sizeof(t_float)*x->size);
 
43
  x->n_inv = 1.0/f;
 
44
  x->size = f;
 
45
  x->buf = getbytes(sizeof(t_float)*x->size);
 
46
 
 
47
  dumbuf = x->wp = x->buf;
 
48
  i = x->size;
 
49
  while(i--) *dumbuf++ = x->avg;
 
50
}
 
51
 
 
52
static void mavg_set(t_mavg *x, t_symbol *s, int argc, t_atom *argv)
 
53
{
 
54
  int i = x->size;
 
55
  t_float *dummy = x->buf;
 
56
  t_float f=(argc)?atom_getfloat(argv):x->avg;
 
57
  ZEXY_USEVAR(s);
 
58
 
 
59
  while (i--) *dummy++=f;
 
60
 
 
61
  x->wp = x->buf;
 
62
}
 
63
 
 
64
static void mavg_float(t_mavg *x, t_float f)
 
65
{
 
66
  int i = x->size;
 
67
  t_float dummy = 0;
 
68
  t_float *dumb = x->buf;
 
69
 
 
70
  *x->wp++ = f;
 
71
  if (x->wp == x->buf + x->size) x->wp = x->buf;
 
72
 
 
73
  while (i--) dummy += *dumb++;
 
74
 
 
75
  x->avg = dummy*x->n_inv;
 
76
 
 
77
  outlet_float(x->x_obj.ob_outlet,x->avg);
 
78
}
 
79
 
 
80
static void *mavg_new(t_floatarg f)
 
81
{
 
82
  t_mavg *x = (t_mavg *)pd_new(mavg_class);
 
83
  int i = (f<1)?2:f;
 
84
  t_float *dumbuf;
 
85
 
 
86
  outlet_new(&x->x_obj, &s_float);
 
87
  inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym(""));
 
88
 
 
89
  x->buf = x->wp = (t_float *)getbytes(sizeof(t_float) * i);
 
90
  x->size = i;
 
91
  x->n_inv = 1.0f/(t_float)i;
 
92
 
 
93
  dumbuf = x->buf;
 
94
  while (i--) *dumbuf++=0;
 
95
 
 
96
  return (x);
 
97
}
 
98
 
 
99
static void mavg_help(void)
 
100
{
 
101
  post("mavg\t:: moving average filter");
 
102
}
 
103
 
 
104
void mavg_setup(void)
 
105
{
 
106
  mavg_class = class_new(gensym("mavg"), (t_newmethod)mavg_new, 0,
 
107
                         sizeof(t_mavg), 0, A_DEFFLOAT, 0);
 
108
 
 
109
  class_addfloat(mavg_class, (t_method)mavg_float);
 
110
 
 
111
  class_addmethod(mavg_class, (t_method)mavg_help, gensym("help"), 0);
 
112
  class_addmethod(mavg_class, (t_method)mavg_set, gensym("set"), A_GIMME, 0);
 
113
  class_addmethod(mavg_class, (t_method)mavg_resize, gensym(""), A_DEFFLOAT, 0);
 
114
 
 
115
  zexy_register("mavg");
 
116
}