* Fix one more off-by-one error in the interpolating resampler

* Since it now doesn't crash anymore; set it as default.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@42436 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Adrien Destugues 2011-07-16 11:18:54 +00:00
parent 61215fd53d
commit eadad13a4f
2 changed files with 52 additions and 10 deletions

View File

@ -49,7 +49,7 @@ Interpolate::float_to_float(const void *_src, int32 srcSampleOffset,
#define SRC(n) *(const float*)(src + n * srcSampleOffset) #define SRC(n) *(const float*)(src + n * srcSampleOffset)
while (count--) { while (--count) {
*(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ; *(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ;
dest += destSampleOffset; dest += destSampleOffset;
current += delta; current += delta;
@ -59,6 +59,8 @@ Interpolate::float_to_float(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
*(float*)dest = SRC(0) * gain;
} }
@ -88,7 +90,7 @@ Interpolate::int32_to_float(const void *_src, int32 srcSampleOffset,
#undef SRC #undef SRC
#define SRC(n) *(const int32*)(src + n * srcSampleOffset) #define SRC(n) *(const int32*)(src + n * srcSampleOffset)
while (count--) { while (--count) {
*(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ; *(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ;
dest += destSampleOffset; dest += destSampleOffset;
current += delta; current += delta;
@ -98,6 +100,8 @@ Interpolate::int32_to_float(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
*(float*)dest = SRC(0) * gain;
} }
@ -127,7 +131,7 @@ Interpolate::int16_to_float(const void *_src, int32 srcSampleOffset,
#undef SRC #undef SRC
#define SRC(n) *(const int16*)(src + n * srcSampleOffset) #define SRC(n) *(const int16*)(src + n * srcSampleOffset)
while (count--) { while (--count) {
*(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current); *(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current);
dest += destSampleOffset; dest += destSampleOffset;
current += delta; current += delta;
@ -137,6 +141,8 @@ Interpolate::int16_to_float(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
*(float*)dest = SRC(0) * gain;
} }
@ -166,7 +172,7 @@ Interpolate::int8_to_float(const void *_src, int32 srcSampleOffset,
#undef SRC #undef SRC
#define SRC(n) *(const int8*)(src + n * srcSampleOffset) #define SRC(n) *(const int8*)(src + n * srcSampleOffset)
while (count--) { while (--count) {
*(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ; *(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current) ;
dest += destSampleOffset; dest += destSampleOffset;
current += delta; current += delta;
@ -176,6 +182,8 @@ Interpolate::int8_to_float(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
*(float*)dest = SRC(0) * gain;
} }
@ -205,7 +213,7 @@ Interpolate::uint8_to_float(const void *_src, int32 srcSampleOffset,
#undef SRC #undef SRC
#define SRC(n) ( *(const uint8*)(src + n * srcSampleOffset) - 128) #define SRC(n) ( *(const uint8*)(src + n * srcSampleOffset) - 128)
while (count--) { while (--count) {
*(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current); *(float*)dest = gain * (SRC(0) + (SRC(1) - SRC(0)) * current);
dest += destSampleOffset; dest += destSampleOffset;
current += delta; current += delta;
@ -215,6 +223,8 @@ Interpolate::uint8_to_float(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
*(float*)dest = SRC(0) * gain;
} }
@ -250,7 +260,7 @@ Interpolate::float_to_int32(const void *_src, int32 srcSampleOffset,
#undef SRC #undef SRC
#define SRC(n) *(const float*)(src + n * srcSampleOffset) #define SRC(n) *(const float*)(src + n * srcSampleOffset)
while (count--) { while (--count) {
register float sample = gain * (SRC(0) + (SRC(1) - SRC(0)) register float sample = gain * (SRC(0) + (SRC(1) - SRC(0))
* current); * current);
if (sample > 2147483647.0f) if (sample > 2147483647.0f)
@ -267,6 +277,14 @@ Interpolate::float_to_int32(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
register float sample = SRC(0)*gain;
if (sample > 2147483647.0f)
*(int32 *)dest = 2147483647L;
else if (sample < -2147483647.0f)
*(int32 *)dest = -2147483647L;
else
*(int32 *)dest = (int32)sample;
} }
@ -299,7 +317,7 @@ Interpolate::float_to_int16(const void *_src, int32 srcSampleOffset,
register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1); register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1);
register float current = 0.0f; register float current = 0.0f;
while (count--) { while (--count) {
register float sample = gain * (SRC(0) + (SRC(1) - SRC(0)) register float sample = gain * (SRC(0) + (SRC(1) - SRC(0))
* current); * current);
if (sample > 32767.0f) if (sample > 32767.0f)
@ -316,6 +334,14 @@ Interpolate::float_to_int16(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
register float sample = SRC(0) * gain;
if (sample > 32767.0f)
*(int16 *)dest = 32767;
else if (sample < -32767.0f)
*(int16 *)dest = -32767;
else
*(int16 *)dest = (int16)sample;
} }
@ -348,7 +374,7 @@ Interpolate::float_to_int8(const void *_src, int32 srcSampleOffset,
register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1); register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1);
register float current = 0.0f; register float current = 0.0f;
while (count--) { while (--count) {
register float sample = gain * (SRC(0) + (SRC(1) - SRC(0)) register float sample = gain * (SRC(0) + (SRC(1) - SRC(0))
* current); * current);
if (sample > 127.0f) if (sample > 127.0f)
@ -365,6 +391,14 @@ Interpolate::float_to_int8(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
register float sample = SRC(0) * gain;
if (sample > 127.0f)
*(int8 *)dest = 127;
else if (sample < -127.0f)
*(int8 *)dest = -127;
else
*(int8 *)dest = (int8)sample;
} }
@ -397,7 +431,7 @@ Interpolate::float_to_uint8(const void *_src, int32 srcSampleOffset,
register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1); register float delta = float(srcSampleCount - 1) / float(destSampleCount - 1);
register float current = 0.0f; register float current = 0.0f;
while (count--) { while (--count) {
register float sample = gain * (SRC(0) + (SRC(1) - SRC(0)) register float sample = gain * (SRC(0) + (SRC(1) - SRC(0))
* current); * current);
if (sample > 255.0f) if (sample > 255.0f)
@ -414,5 +448,13 @@ Interpolate::float_to_uint8(const void *_src, int32 srcSampleOffset,
src += srcSampleOffset * (int)ipart; src += srcSampleOffset * (int)ipart;
} }
} }
register float sample = SRC(0) * gain;
if (sample > 255.0f)
*(uint8 *)dest = 255;
else if (sample < 1.0f)
*(uint8 *)dest = 1;
else
*(uint8 *)dest = (uint8)sample;
} }

View File

@ -423,7 +423,7 @@ MixerSettings::Load()
fSettings.AllowOutputChannelRemapping = false; fSettings.AllowOutputChannelRemapping = false;
fSettings.AllowInputChannelRemapping = false; fSettings.AllowInputChannelRemapping = false;
fSettings.InputGainControls = 0; fSettings.InputGainControls = 0;
fSettings.ResamplingAlgorithm = 0; fSettings.ResamplingAlgorithm = 1;
fSettings.RefuseOutputFormatChange = true; fSettings.RefuseOutputFormatChange = true;
fSettings.RefuseInputFormatChange = true; fSettings.RefuseInputFormatChange = true;