2 * Copyright (c) 2005 Boris Mikhaylov
4 * Permission is hereby granted, free of charge, to any person obtaining
5 * a copy of this software and associated documentation files (the
6 * "Software"), to deal in the Software without restriction, including
7 * without limitation the rights to use, copy, modify, merge, publish,
8 * distribute, sublicense, and/or sell copies of the Software, and to
9 * permit persons to whom the Software is furnished to do so, subject to
10 * the following conditions:
12 * The above copyright notice and this permission notice shall be
13 * included in all copies or substantial portions of the Software.
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
18 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
19 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
20 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
21 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27 /* Number of crossfeed levels */
28 #define BS2B_CLEVELS 3
30 /* Normal crossfeed levels */
31 #define BS2B_HIGH_CLEVEL 3
32 #define BS2B_MIDDLE_CLEVEL 2
33 #define BS2B_LOW_CLEVEL 1
35 /* Easy crossfeed levels */
36 #define BS2B_HIGH_ECLEVEL BS2B_HIGH_CLEVEL + BS2B_CLEVELS
37 #define BS2B_MIDDLE_ECLEVEL BS2B_MIDDLE_CLEVEL + BS2B_CLEVELS
38 #define BS2B_LOW_ECLEVEL BS2B_LOW_CLEVEL + BS2B_CLEVELS
40 /* Default crossfeed levels */
41 #define BS2B_DEFAULT_CLEVEL BS2B_HIGH_ECLEVEL
42 /* Default sample rate (Hz) */
43 #define BS2B_DEFAULT_SRATE 44100
47 #endif /* __cplusplus */
50 int level
; /* Crossfeed level */
51 int srate
; /* Sample rate (Hz) */
53 /* Lowpass IIR filter coefficients */
57 /* Highboost IIR filter coefficients */
62 /* Global gain against overloading */
65 /* Buffer of last filtered sample.
66 * [0] - first channel, [1] - second channel
68 struct t_last_sample
{
75 /* Clear buffers and set new coefficients with new crossfeed level value.
76 * level - crossfeed level of *LEVEL values.
78 void bs2b_set_level(struct bs2b
*bs2b
, int level
);
80 /* Return current crossfeed level value */
81 int bs2b_get_level(struct bs2b
*bs2b
);
83 /* Clear buffers and set new coefficients with new sample rate value.
84 * srate - sample rate by Hz.
86 void bs2b_set_srate(struct bs2b
*bs2b
, int srate
);
88 /* Return current sample rate value */
89 int bs2b_get_srate(struct bs2b
*bs2b
);
92 void bs2b_clear(struct bs2b
*bs2b
);
94 /* Return 1 if buffer is clear */
95 int bs2b_is_clear(struct bs2b
*bs2b
);
97 /* Crossfeeds one stereo sample that are pointed by sample.
98 * [0] - first channel, [1] - second channel.
99 * Returns crossfided samle by sample pointer.
102 /* sample poits to floats */
103 void bs2b_cross_feed(struct bs2b
*bs2b
, float *sample
);
107 #endif /* __cplusplus */