source: roaraudio/include/libroardsp/libroardsp.h @ 3004:f117b3c0e4df

Last change on this file since 3004:f117b3c0e4df was 3004:f117b3c0e4df, checked in by phi, 15 years ago

a lit #defines needed by the speex_prep, more infos about data types

File size: 10.4 KB
Line 
1//libroardsp.h:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2008, 2009
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#ifndef _LIBROARDSP_H_
26#define _LIBROARDSP_H_
27
28#include <roaraudio.h>
29
30__BEGIN_DECLS
31
32// enable Speex preprocessing and better type handling if speex > 1.1.8
33#ifdef ROAR_HAVE_LIBSPEEX
34#include <speex/speex.h>
35#ifdef _SPEEX_TYPES_H
36#include <speex/speex_preprocess.h>
37#endif
38#endif
39
40#include "midi.h"
41#include "synth.h"
42#include "poly.h"
43#include "fader.h"
44#include "mixer.h"
45#include "amp.h"
46#include "convert.h"
47#include "midside.h"
48#include "point.h"
49#include "remove.h"
50#include "rms.h"
51#include "transcode.h"
52#include "vio_transcode.h"
53
54#ifdef ROAR_HAVE_LIBCELT
55#include "transcode_celt.h"
56#endif
57#ifdef ROAR_HAVE_LIBSPEEX
58#include "transcode_speex.h"
59#endif
60
61#ifdef ROAR_HAVE_LIBSAMPLERATE
62#include <samplerate.h>
63#endif
64
65// defines
66#define ROARDSP_MAX_FILTERS_PER_CHAIN 8
67
68#define ROARDSP_FILTER_NONE           0
69#define ROARDSP_FILTER_AMP            1
70#define ROARDSP_FILTER_LOWP           2
71#define ROARDSP_FILTER_HIGHP          3
72#define ROARDSP_FILTER_MODULATE       4
73#define ROARDSP_FILTER_QUANTIFY       5
74#define ROARDSP_FILTER_CLIP           6
75#define ROARDSP_FILTER_ADD            7
76#define ROARDSP_FILTER_DOWNMIX        8
77#define ROARDSP_FILTER_DCBLOCK        9
78#define ROARDSP_FILTER_SWAP          10
79#define ROARDSP_FILTER_SPEEX_PREP    11
80#define ROARDSP_FILTER_AGC           12
81
82// filter CTLs:
83
84#define ROARDSP_FCTL_FREQ             1 /* float */
85#define ROARDSP_FCTL_TIME             2
86#define ROARDSP_FCTL_MUL              3 /* int32_t */
87#define ROARDSP_FCTL_DIV              4 /* int32_t */
88#define ROARDSP_FCTL_N                5 /* int32_t */
89#define ROARDSP_FCTL_LIMIT            6 /* int32_t */
90#define ROARDSP_FCTL_PHASE            7
91#define ROARDSP_FCTL_Q                8 /* int32_t */
92#define ROARDSP_FCTL_MODE             9 /* int32_t */
93#define ROARDSP_FCTL_PACKET_SIZE     10 /* size_t */
94
95// consts for filter flags:
96#define ROARDSP_FFLAG_NONE            0x0000
97#define ROARDSP_FFLAG_FREE            0x0001
98
99// consts for filter(chain) reset:
100#define ROARDSP_RESET_NONE            0
101#define ROARDSP_RESET_FULL            1
102#define ROARDSP_RESET_STATE           2
103
104// filter specific constants:
105#define ROARDSP_DOWNMIX_LEFT          1
106#define ROARDSP_DOWNMIX_RIGHT         2
107#define ROARDSP_DOWNMIX_ARITHMETIC    3
108#define ROARDSP_DOWNMIX_RMS           4
109
110#define ROARDSP_DCBLOCK_NUMBLOCKS     100
111
112
113#define ROARDSP_SPEEX_PREP_ON          0x0001
114#define ROARDSP_SPEEX_PREP_OFF         0x0002
115#define ROARDSP_SPEEX_PREP_MASK        (ROARDSP_SPEEX_PREP_ON|ROARDSP_SPEEX_PREP_OFF)
116
117// Config Bit Vector
118#define ROARDSP_SPEEX_PREP_CBV(opt,sw) ((sw)<<((opt)*2))
119#define ROARDSP_SPEEX_PREP_CTB(opt,val) (((val) & ROARDSP_SPEEX_PREP_CBV((opt),ROARDSP_SPEEX_PREP_MASK)) >> ((opt)*2))
120
121#define ROARDSP_SPEEX_PREP_DENOISE     0
122#define ROARDSP_SPEEX_PREP_AGC         1
123#define ROARDSP_SPEEX_PREP_VAD         2
124
125#define ROARDSP_SPEEX_PREP_DENOISE_ON  ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_DENOISE, ROARDSP_SPEEX_PREP_ON)
126#define ROARDSP_SPEEX_PREP_DENOISE_OFF ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_DENOISE, ROARDSP_SPEEX_PREP_OFF)
127#define ROARDSP_SPEEX_PREP_AGC_ON      ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_AGC, ROARDSP_SPEEX_PREP_ON)
128#define ROARDSP_SPEEX_PREP_AGC_OFF     ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_AGC, ROARDSP_SPEEX_PREP_OFF)
129#define ROARDSP_SPEEX_PREP_VAD_ON      ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_VAD, ROARDSP_SPEEX_PREP_ON)
130#define ROARDSP_SPEEX_PREP_VAD_OFF     ROARDSP_SPEEX_PREP_CBV(ROARDSP_SPEEX_PREP_VAD, ROARDSP_SPEEX_PREP_OFF)
131
132
133// types:
134
135struct roardsp_filter {
136 int    channels;
137 int    bits;
138 int    rate;
139 void * inst;
140 uint_least16_t flags;
141 int (*calc  )(struct roardsp_filter * filter, void * data, size_t samples);
142 int (*uninit)(struct roardsp_filter * filter);
143 int (*ctl   )(struct roardsp_filter * filter, int cmd, void * data);
144 int (*reset )(struct roardsp_filter * filter, int what);
145};
146
147struct roardsp_filterchain {
148 int filters;
149 struct roardsp_filter * filter[ROARDSP_MAX_FILTERS_PER_CHAIN];
150};
151
152#ifdef ROAR_HAVE_LIBM
153struct roardsp_lowp {
154 uint32_t freq; // in mHz (0Hz..4MHz)
155 uint16_t a, b;
156 int32_t  old[ROAR_MAX_CHANNELS];
157};
158
159struct roardsp_highp {
160 uint32_t freq; // in mHz (0Hz..4MHz)
161 int32_t  a, b, c;
162 int32_t  oldout[ROAR_MAX_CHANNELS];
163 int32_t  oldin[ROAR_MAX_CHANNELS];
164};
165#endif
166
167struct roardsp_amp {
168 int32_t  mul;
169 int32_t  div;
170};
171
172struct roardsp_dcblock {
173 int cur;
174 int32_t dc[ROARDSP_DCBLOCK_NUMBLOCKS];
175};
176
177struct roardsp_swap {
178 int map[ROAR_MAX_CHANNELS];
179};
180
181struct roardsp_agc {
182 struct roardsp_filter * amp;
183};
184
185struct roardsp_speex_prep {
186#ifdef _SPEEX_TYPES_H
187 SpeexPreprocessState *preprocess;
188 int frame_size;
189#else
190 char dummy[8];
191#endif
192};
193
194// funcs:
195int    roardsp_filter_str2id(char * str);
196char * roardsp_filter_id2str(int id);
197int    roardsp_filter_new   (struct roardsp_filter ** filter, struct roar_stream * stream, int id);
198#define roardsp_filter_free(x) roar_dsp_filter_uninit((x))
199int    roardsp_filter_init  (struct roardsp_filter *  filter, struct roar_stream * stream, int id);
200int    roardsp_filter_uninit(struct roardsp_filter *  filter);
201int    roardsp_filter_calc  (struct roardsp_filter *  filter, void * data, size_t len);
202int    roardsp_filter_ctl   (struct roardsp_filter *  filter, int cmd, void * data);
203int    roardsp_filter_reset (struct roardsp_filter *  filter, int what);
204
205int roardsp_fchain_init  (struct roardsp_filterchain * chain);
206int roardsp_fchain_uninit(struct roardsp_filterchain * chain);
207int roardsp_fchain_add   (struct roardsp_filterchain * chain, struct roardsp_filter * filter);
208int roardsp_fchain_calc  (struct roardsp_filterchain * chain, void * data, size_t len);
209int roardsp_fchain_reset (struct roardsp_filterchain * chain, int what);
210int roardsp_fchain_num   (struct roardsp_filterchain * chain);
211
212// filter:
213
214#ifdef ROAR_HAVE_LIBM
215int roardsp_lowp_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id);
216int roardsp_lowp_uninit(struct roardsp_filter * filter);
217int roardsp_lowp_calc16(struct roardsp_filter * filter, void * data, size_t samples);
218int roardsp_lowp_ctl   (struct roardsp_filter * filter, int cmd, void * data);
219int roardsp_lowp_reset (struct roardsp_filter * filter, int what);
220
221int roardsp_highp_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id);
222int roardsp_highp_uninit(struct roardsp_filter * filter);
223int roardsp_highp_calc16(struct roardsp_filter * filter, void * data, size_t samples);
224int roardsp_highp_ctl   (struct roardsp_filter * filter, int cmd, void * data);
225int roardsp_highp_reset (struct roardsp_filter * filter, int what);
226#endif
227
228int roardsp_amp_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id);
229int roardsp_amp_uninit(struct roardsp_filter * filter);
230int roardsp_amp_calc16(struct roardsp_filter * filter, void * data, size_t samples);
231int roardsp_amp_calc8 (struct roardsp_filter * filter, void * data, size_t samples);
232int roardsp_amp_ctl   (struct roardsp_filter * filter, int cmd, void * data);
233int roardsp_amp_reset (struct roardsp_filter * filter, int what);
234
235int roardsp_add_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id);
236int roardsp_add_calc16(struct roardsp_filter * filter, void * data, size_t samples);
237int roardsp_add_reset (struct roardsp_filter * filter, int what);
238
239int roardsp_quantify_init  (struct roardsp_filter * filter, struct roar_stream * stream, int id);
240int roardsp_quantify_uninit(struct roardsp_filter * filter);
241int roardsp_quantify_calc16(struct roardsp_filter * filter, void * data, size_t samples);
242int roardsp_quantify_ctl   (struct roardsp_filter * filter, int cmd, void * data);
243int roardsp_quantify_reset (struct roardsp_filter * filter, int what);
244
245int roardsp_clip_calc16(struct roardsp_filter * filter, void * data, size_t samples);
246int roardsp_clip_ctl   (struct roardsp_filter * filter, int cmd, void * data);
247int roardsp_clip_reset (struct roardsp_filter * filter, int what);
248
249int roardsp_downmix_init   (struct roardsp_filter * filter, struct roar_stream * stream, int id);
250int roardsp_downmix_calc162(struct roardsp_filter * filter, void * data, size_t samples);
251int roardsp_downmix_ctl    (struct roardsp_filter * filter, int cmd, void * data);
252int roardsp_downmix_reset  (struct roardsp_filter * filter, int what);
253
254int roardsp_dcblock_init   (struct roardsp_filter * filter, struct roar_stream * stream, int id);
255int roardsp_dcblock_uninit (struct roardsp_filter * filter);
256int roardsp_dcblock_calc16 (struct roardsp_filter * filter, void * data, size_t samples);
257int roardsp_dcblock_reset  (struct roardsp_filter * filter, int what);
258
259int roardsp_swap_init   (struct roardsp_filter * filter, struct roar_stream * stream, int id);
260int roardsp_swap_uninit (struct roardsp_filter * filter);
261int roardsp_swap_calc162(struct roardsp_filter * filter, void * data, size_t samples);
262int roardsp_swap_ctl    (struct roardsp_filter * filter, int cmd, void * data);
263int roardsp_swap_reset  (struct roardsp_filter * filter, int what);
264
265#ifdef _SPEEX_TYPES_H
266int roardsp_speex_prep_init   (struct roardsp_filter * filter, struct roar_stream * stream, int id);
267int roardsp_speex_prep_uninit (struct roardsp_filter * filter);
268int roardsp_speex_prep_calc161(struct roardsp_filter * filter, void * data, size_t samples);
269int roardsp_speex_prep_ctl    (struct roardsp_filter * filter, int cmd, void * data);
270int roardsp_speex_prep_reset  (struct roardsp_filter * filter, int what);
271#endif
272
273// codecs:
274int roardsp_conv_alaw2pcm16 (int16_t * out, char * in, size_t len);
275int roardsp_conv_pcm162alaw (char * out, int16_t * in, size_t len);
276
277int roardsp_conv_mulaw2pcm16 (int16_t * out, char * in, size_t len);
278int roardsp_conv_pcm162mulaw (char * out, int16_t * in, size_t len);
279
280__END_DECLS
281
282#endif
283
284//ll
Note: See TracBrowser for help on using the repository browser.