Spaces:
Runtime error
Runtime error
/* | |
* audio resampling | |
* Copyright (c) 2004-2012 Michael Niedermayer <[email protected]> | |
* | |
* This file is part of FFmpeg. | |
* | |
* FFmpeg is free software; you can redistribute it and/or | |
* modify it under the terms of the GNU Lesser General Public | |
* License as published by the Free Software Foundation; either | |
* version 2.1 of the License, or (at your option) any later version. | |
* | |
* FFmpeg is distributed in the hope that it will be useful, | |
* but WITHOUT ANY WARRANTY; without even the implied warranty of | |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
* Lesser General Public License for more details. | |
* | |
* You should have received a copy of the GNU Lesser General Public | |
* License along with FFmpeg; if not, write to the Free Software | |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
*/ | |
/** | |
* @file | |
* audio resampling | |
* @author Michael Niedermayer <[email protected]> | |
*/ | |
static void RENAME(resample_one)(void *dest, const void *source, | |
int dst_size, int64_t index2, int64_t incr) | |
{ | |
DELEM *dst = dest; | |
const DELEM *src = source; | |
int dst_index; | |
for (dst_index = 0; dst_index < dst_size; dst_index++) { | |
dst[dst_index] = src[index2 >> 32]; | |
index2 += incr; | |
} | |
} | |
static int RENAME(resample_common)(ResampleContext *c, | |
void *dest, const void *source, | |
int n, int update_ctx) | |
{ | |
DELEM *dst = dest; | |
const DELEM *src = source; | |
int dst_index; | |
int index= c->index; | |
int frac= c->frac; | |
int sample_index = 0; | |
while (index >= c->phase_count) { | |
sample_index++; | |
index -= c->phase_count; | |
} | |
for (dst_index = 0; dst_index < n; dst_index++) { | |
FELEM *filter = ((FELEM *) c->filter_bank) + c->filter_alloc * index; | |
FELEM2 val = FOFFSET; | |
FELEM2 val2= 0; | |
int i; | |
for (i = 0; i + 1 < c->filter_length; i+=2) { | |
val += src[sample_index + i ] * (FELEM2)filter[i ]; | |
val2 += src[sample_index + i + 1] * (FELEM2)filter[i + 1]; | |
} | |
if (i < c->filter_length) | |
val += src[sample_index + i ] * (FELEM2)filter[i ]; | |
OUT(dst[dst_index], val + (FELEML)val2); | |
OUT(dst[dst_index], val + val2); | |
frac += c->dst_incr_mod; | |
index += c->dst_incr_div; | |
if (frac >= c->src_incr) { | |
frac -= c->src_incr; | |
index++; | |
} | |
while (index >= c->phase_count) { | |
sample_index++; | |
index -= c->phase_count; | |
} | |
} | |
if(update_ctx){ | |
c->frac= frac; | |
c->index= index; | |
} | |
return sample_index; | |
} | |
static int RENAME(resample_linear)(ResampleContext *c, | |
void *dest, const void *source, | |
int n, int update_ctx) | |
{ | |
DELEM *dst = dest; | |
const DELEM *src = source; | |
int dst_index; | |
int index= c->index; | |
int frac= c->frac; | |
int sample_index = 0; | |
double inv_src_incr = 1.0 / c->src_incr; | |
while (index >= c->phase_count) { | |
sample_index++; | |
index -= c->phase_count; | |
} | |
for (dst_index = 0; dst_index < n; dst_index++) { | |
FELEM *filter = ((FELEM *) c->filter_bank) + c->filter_alloc * index; | |
FELEM2 val = FOFFSET, v2 = FOFFSET; | |
int i; | |
for (i = 0; i < c->filter_length; i++) { | |
val += src[sample_index + i] * (FELEM2)filter[i]; | |
v2 += src[sample_index + i] * (FELEM2)filter[i + c->filter_alloc]; | |
} | |
val += (v2 - val) * (FELEML) frac / c->src_incr; | |
val += (v2 - val) * inv_src_incr * frac; | |
val += (v2 - val) / c->src_incr * frac; | |
OUT(dst[dst_index], val); | |
frac += c->dst_incr_mod; | |
index += c->dst_incr_div; | |
if (frac >= c->src_incr) { | |
frac -= c->src_incr; | |
index++; | |
} | |
while (index >= c->phase_count) { | |
sample_index++; | |
index -= c->phase_count; | |
} | |
} | |
if(update_ctx){ | |
c->frac= frac; | |
c->index= index; | |
} | |
return sample_index; | |
} | |