summaryrefslogtreecommitdiffstats
path: root/gst/speexresample/resample.c
diff options
context:
space:
mode:
Diffstat (limited to 'gst/speexresample/resample.c')
-rw-r--r--gst/speexresample/resample.c304
1 files changed, 117 insertions, 187 deletions
diff --git a/gst/speexresample/resample.c b/gst/speexresample/resample.c
index 5b20f5ef..29b95f23 100644
--- a/gst/speexresample/resample.c
+++ b/gst/speexresample/resample.c
@@ -74,6 +74,7 @@ speex_realloc (void *ptr, int size)
{
return g_realloc (ptr, size);
}
+
static inline void
speex_free (void *ptr)
{
@@ -395,10 +396,13 @@ resampler_basic_direct_single (SpeexResamplerState * st,
}
/* Do the new part */
- ptr = in + st->in_stride * (last_sample - N + 1 + j);
- for (; j < N; j++) {
- sum += MULT16_16 (*ptr, st->sinc_table[samp_frac_num * st->filt_len + j]);
- ptr += st->in_stride;
+ if (in != NULL) {
+ ptr = in + st->in_stride * (last_sample - N + 1 + j);
+ for (; j < N; j++) {
+ sum +=
+ MULT16_16 (*ptr, st->sinc_table[samp_frac_num * st->filt_len + j]);
+ ptr += st->in_stride;
+ }
}
*out = PSHR32 (sum, 15);
@@ -447,12 +451,14 @@ resampler_basic_direct_double (SpeexResamplerState * st,
}
/* Do the new part */
- ptr = in + st->in_stride * (last_sample - N + 1 + j);
- for (; j < N; j++) {
- sum +=
- MULT16_16 (*ptr,
- (double) st->sinc_table[samp_frac_num * st->filt_len + j]);
- ptr += st->in_stride;
+ if (in != NULL) {
+ ptr = in + st->in_stride * (last_sample - N + 1 + j);
+ for (; j < N; j++) {
+ sum +=
+ MULT16_16 (*ptr,
+ (double) st->sinc_table[samp_frac_num * st->filt_len + j]);
+ ptr += st->in_stride;
+ }
}
*out = sum;
@@ -524,24 +530,27 @@ resampler_basic_interpolate_single (SpeexResamplerState * st,
MULT16_16 (curr_mem,
st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
}
- ptr = in + st->in_stride * (last_sample - N + 1 + j);
- /* Do the new part */
- for (; j < N; j++) {
- spx_word16_t curr_in = *ptr;
- ptr += st->in_stride;
- accum[0] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset - 2]);
- accum[1] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset - 1]);
- accum[2] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset]);
- accum[3] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
+ if (in != NULL) {
+ ptr = in + st->in_stride * (last_sample - N + 1 + j);
+ /* Do the new part */
+ for (; j < N; j++) {
+ spx_word16_t curr_in = *ptr;
+
+ ptr += st->in_stride;
+ accum[0] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset - 2]);
+ accum[1] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset - 1]);
+ accum[2] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset]);
+ accum[3] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
+ }
}
cubic_coef (frac, interp);
sum =
@@ -611,24 +620,26 @@ resampler_basic_interpolate_double (SpeexResamplerState * st,
MULT16_16 (curr_mem,
st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
}
- ptr = in + st->in_stride * (last_sample - N + 1 + j);
- /* Do the new part */
- for (; j < N; j++) {
- double curr_in = *ptr;
-
- ptr += st->in_stride;
- accum[0] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset - 2]);
- accum[1] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset - 1]);
- accum[2] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset]);
- accum[3] +=
- MULT16_16 (curr_in,
- st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
+ if (in != NULL) {
+ ptr = in + st->in_stride * (last_sample - N + 1 + j);
+ /* Do the new part */
+ for (; j < N; j++) {
+ double curr_in = *ptr;
+
+ ptr += st->in_stride;
+ accum[0] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset - 2]);
+ accum[1] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset - 1]);
+ accum[2] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset]);
+ accum[3] +=
+ MULT16_16 (curr_in,
+ st->sinc_table[4 + (j + 1) * st->oversample - offset + 1]);
+ }
}
cubic_coef (frac, interp);
sum =
@@ -971,9 +982,13 @@ speex_resampler_process_native (SpeexResamplerState * st,
for (j = 0; j < N - 1 - (spx_int32_t) * in_len; j++)
mem[j] = mem[j + *in_len];
- for (; j < N - 1; j++)
- mem[j] = in[st->in_stride * (j + *in_len - N + 1)];
-
+ if (in != NULL) {
+ for (; j < N - 1; j++)
+ mem[j] = in[st->in_stride * (j + *in_len - N + 1)];
+ } else {
+ for (; j < N - 1; j++)
+ mem[j] = 0;
+ }
return RESAMPLER_ERR_SUCCESS;
}
@@ -998,10 +1013,16 @@ speex_resampler_process_float (SpeexResamplerState * st,
ALLOC(y, *out_len, spx_word16_t); */
istride_save = st->in_stride;
ostride_save = st->out_stride;
- for (i = 0; i < *in_len; i++)
- x[i] = WORD2INT (in[i * st->in_stride]);
- st->in_stride = st->out_stride = 1;
- speex_resampler_process_native (st, channel_index, x, in_len, y, out_len);
+ if (in != NULL) {
+ for (i = 0; i < *in_len; i++)
+ x[i] = WORD2INT (in[i * st->in_stride]);
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, x, in_len, y, out_len);
+ } else {
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, NULL, in_len, y,
+ out_len);
+ }
st->in_stride = istride_save;
st->out_stride = ostride_save;
for (i = 0; i < *out_len; i++)
@@ -1022,10 +1043,17 @@ speex_resampler_process_float (SpeexResamplerState * st,
ichunk = FIXED_STACK_ALLOC;
if (ochunk > FIXED_STACK_ALLOC)
ochunk = FIXED_STACK_ALLOC;
- for (i = 0; i < ichunk; i++)
- x[i] = WORD2INT (in[i * st->in_stride]);
- st->in_stride = st->out_stride = 1;
- speex_resampler_process_native (st, channel_index, x, &ichunk, y, &ochunk);
+ if (in != NULL) {
+ for (i = 0; i < ichunk; i++)
+ x[i] = WORD2INT (in[i * st->in_stride]);
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, x, &ichunk, y,
+ &ochunk);
+ } else {
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, NULL, &ichunk, y,
+ &ochunk);
+ }
st->in_stride = istride_save;
st->out_stride = ostride_save;
for (i = 0; i < ochunk; i++)
@@ -1077,10 +1105,16 @@ speex_resampler_process_int (SpeexResamplerState * st,
ALLOC(y, *out_len, spx_word16_t); */
istride_save = st->in_stride;
ostride_save = st->out_stride;
- for (i = 0; i < *in_len; i++)
- x[i] = in[i * st->in_stride];
- st->in_stride = st->out_stride = 1;
- speex_resampler_process_native (st, channel_index, x, in_len, y, out_len);
+ if (in != NULL) {
+ for (i = 0; i < *in_len; i++)
+ x[i] = in[i * st->in_stride];
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, x, in_len, y, out_len);
+ } else {
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, NULL, in_len, y,
+ out_len);
+ }
st->in_stride = istride_save;
st->out_stride = ostride_save;
for (i = 0; i < *out_len; i++)
@@ -1101,10 +1135,17 @@ speex_resampler_process_int (SpeexResamplerState * st,
ichunk = FIXED_STACK_ALLOC;
if (ochunk > FIXED_STACK_ALLOC)
ochunk = FIXED_STACK_ALLOC;
- for (i = 0; i < ichunk; i++)
- x[i] = in[i * st->in_stride];
- st->in_stride = st->out_stride = 1;
- speex_resampler_process_native (st, channel_index, x, &ichunk, y, &ochunk);
+ if (in != NULL) {
+ for (i = 0; i < ichunk; i++)
+ x[i] = in[i * st->in_stride];
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, x, &ichunk, y,
+ &ochunk);
+ } else {
+ st->in_stride = st->out_stride = 1;
+ speex_resampler_process_native (st, channel_index, NULL, &ichunk, y,
+ &ochunk);
+ }
st->in_stride = istride_save;
st->out_stride = ostride_save;
for (i = 0; i < ochunk; i++)
@@ -1134,7 +1175,10 @@ speex_resampler_process_interleaved_float (SpeexResamplerState * st,
st->in_stride = st->out_stride = st->nb_channels;
for (i = 0; i < st->nb_channels; i++) {
*out_len = bak_len;
- speex_resampler_process_float (st, i, in + i, in_len, out + i, out_len);
+ if (in != NULL)
+ speex_resampler_process_float (st, i, in + i, in_len, out + i, out_len);
+ else
+ speex_resampler_process_float (st, i, NULL, in_len, out + i, out_len);
}
st->in_stride = istride_save;
st->out_stride = ostride_save;
@@ -1156,7 +1200,10 @@ speex_resampler_process_interleaved_int (SpeexResamplerState * st,
st->in_stride = st->out_stride = st->nb_channels;
for (i = 0; i < st->nb_channels; i++) {
*out_len = bak_len;
- speex_resampler_process_int (st, i, in + i, in_len, out + i, out_len);
+ if (in != NULL)
+ speex_resampler_process_int (st, i, in + i, in_len, out + i, out_len);
+ else
+ speex_resampler_process_int (st, i, NULL, in_len, out + i, out_len);
}
st->in_stride = istride_save;
st->out_stride = ostride_save;
@@ -1273,133 +1320,16 @@ speex_resampler_get_output_stride (SpeexResamplerState * st,
}
int
-speex_resampler_get_latency (SpeexResamplerState * st)
+speex_resampler_get_input_latency (SpeexResamplerState * st)
{
return st->filt_len / 2;
}
int
-speex_resampler_drain_float (SpeexResamplerState * st,
- spx_uint32_t channel_index, float *out, spx_uint32_t * out_len)
+speex_resampler_get_output_latency (SpeexResamplerState * st)
{
- spx_uint32_t in_len;
- int ret;
- float *in;
-
- in_len = speex_resampler_get_latency (st);
-
- in = speex_alloc (sizeof (float) * in_len);
- *out_len =
- MIN (in_len * st->den_rate + (st->num_rate >> 1) / st->num_rate,
- *out_len);
-
- ret =
- speex_resampler_process_float (st, channel_index, in, &in_len, out,
- out_len);
-
- speex_free (in);
-
- speex_resampler_reset_mem (st);
-
- return ret;
-}
-
-int
-speex_resampler_drain_int (SpeexResamplerState * st,
- spx_uint32_t channel_index, spx_int16_t * out, spx_uint32_t * out_len)
-{
- spx_uint32_t in_len;
- int ret;
- spx_int16_t *in;
-
- in_len = speex_resampler_get_latency (st);
-
- in = speex_alloc (sizeof (spx_int16_t) * in_len);
- *out_len =
- MIN (in_len * st->den_rate + (st->num_rate >> 1) / st->num_rate,
- *out_len);
-
- ret =
- speex_resampler_process_int (st, channel_index, in, &in_len, out,
- out_len);
-
- speex_free (in);
-
- speex_resampler_reset_mem (st);
-
- return ret;
-}
-
-int
-speex_resampler_drain_interleaved_float (SpeexResamplerState * st,
- float *out, spx_uint32_t * out_len)
-{
- spx_uint32_t i;
- int istride_save, ostride_save;
- spx_uint32_t bak_len;
- spx_uint32_t in_len;
- float *in;
-
- in_len = speex_resampler_get_latency (st);
-
- in = speex_alloc (sizeof (float) * in_len);
- *out_len =
- MIN (in_len * st->den_rate + (st->num_rate >> 1) / st->num_rate,
- *out_len);
- bak_len = *out_len;
-
- istride_save = st->in_stride;
- ostride_save = st->out_stride;
- st->in_stride = 1;
- st->out_stride = st->nb_channels;
- for (i = 0; i < st->nb_channels; i++) {
- *out_len = bak_len;
- speex_resampler_process_float (st, i, in, &in_len, out + i, out_len);
- }
- st->in_stride = istride_save;
- st->out_stride = ostride_save;
-
- speex_free (in);
-
- speex_resampler_reset_mem (st);
-
- return RESAMPLER_ERR_SUCCESS;
-}
-
-int
-speex_resampler_drain_interleaved_int (SpeexResamplerState * st,
- spx_int16_t * out, spx_uint32_t * out_len)
-{
- spx_uint32_t i;
- int istride_save, ostride_save;
- spx_uint32_t bak_len;
- spx_uint32_t in_len;
- spx_int16_t *in;
-
- in_len = speex_resampler_get_latency (st);
-
- in = speex_alloc (sizeof (spx_int16_t) * in_len);
- *out_len =
- MIN (in_len * st->den_rate + (st->num_rate >> 1) / st->num_rate,
- *out_len);
- bak_len = *out_len;
-
- istride_save = st->in_stride;
- ostride_save = st->out_stride;
- st->in_stride = 1;
- st->out_stride = st->nb_channels;
- for (i = 0; i < st->nb_channels; i++) {
- *out_len = bak_len;
- speex_resampler_process_int (st, i, in, &in_len, out + i, out_len);
- }
- st->in_stride = istride_save;
- st->out_stride = ostride_save;
-
- speex_free (in);
-
- speex_resampler_reset_mem (st);
-
- return RESAMPLER_ERR_SUCCESS;
+ return ((st->filt_len / 2) * st->den_rate +
+ (st->num_rate >> 1)) / st->num_rate;
}
int