source: roaraudio/libroardsp/filter_highp.c @ 683:61cb5393b9a5

Last change on this file since 683:61cb5393b9a5 was 683:61cb5393b9a5, checked in by phi, 16 years ago

added code for highp, seem not to work

File size: 2.7 KB
Line 
1//highp.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - August 2008
5 *
6 *  This file is part of libroardsp a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroardsp is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
22 *
23 */
24
25#include "libroardsp.h"
26
27int roardsp_highp_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id) {
28 struct roardsp_highp * self = malloc(sizeof(struct roardsp_highp));
29 float freq = 25;
30
31 if ( self == NULL )
32  return -1;
33
34 memset(self, 0, sizeof(struct roardsp_highp));
35
36 filter->inst = (void*) self;
37
38 roardsp_highp_ctl(filter, ROARDSP_FCTL_FREQ, &freq);
39
40 return 0;
41}
42
43int roardsp_highp_uninit(struct roardsp_filter * filter) {
44
45 free(filter->inst);
46 return 0;
47}
48
49int roardsp_highp_calc16(struct roardsp_filter * filter, void * data, size_t samples) {
50 struct roardsp_highp * self = (struct roardsp_highp *) filter->inst;
51 int16_t * samp = (int16_t *) data;
52 register int32_t s;
53 int i, c;
54 int channels = filter->channels;
55
56 if ( channels > ROAR_MAX_CHANNELS )
57  return -1;
58
59 samples /= channels;
60
61 ROAR_DBG("roardsp_highp_calc16(*): filtering %i frames of %i channels...", samples, channels);
62
63// *      output[N] = A0 * input[N] + A1 * input[N-1] + B1 * output[N-1]
64
65
66 for (i = 0; i < samples; i++) {
67  for (c = 0; c < channels; c++) {
68   s = samp[i*channels + c] * self->a + self->oldin[c] * self->b + self->oldout[c] * self->c;
69
70   s /= 65536;
71
72   self->oldin[      c] = s;
73   samp[i*channels + c] = s;
74   self->oldout[     c] = s;
75  }
76 }
77
78 return 0;
79}
80
81int roardsp_highp_ctl   (struct roardsp_filter * filter, int cmd, void * data) {
82 struct roardsp_highp * self = (struct roardsp_highp *) filter->inst;
83 float lp;
84 float oldfreq;
85 float newfreq;
86
87 if ( cmd != ROARDSP_FCTL_FREQ )
88  return -1;
89
90 newfreq = *(float*)data;
91
92 lp = exp(-2 * M_PI * newfreq / filter->rate) * 65536;
93
94 self->a =  (65536 + lp)/2;
95 self->b = -(65536 + lp)/2;
96 self->c =           lp;
97
98
99 oldfreq = self->freq / 1000;
100 self->freq = newfreq * 1000;
101
102 *(float*)data = oldfreq;
103
104 ROAR_DBG("roardsp_highp_ctl(); oldfreq=%f, newfreq=%f", oldfreq, newfreq);
105
106 return 0;
107}
108
109//ll
Note: See TracBrowser for help on using the repository browser.