SPU2Ghz: Part one of a bigger update

git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@202 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
ramapcsx2 2008-10-16 13:46:17 +00:00 committed by Gregory Hainaut
parent e6d4aaf114
commit 6c2d95f27d
2 changed files with 28 additions and 22 deletions

View File

@ -363,7 +363,8 @@ void GetVoiceValues(s32& Value) {
vc.SP+=pitch; vc.SP+=pitch;
while(vc.SP>=4096) while(vc.SP>=4096)
{ {
DT=0; //this isn't needed. it's garaunteed to be assigned a valid value.
//DT=0;
if(vc.Noise) if(vc.Noise)
GetNoiseValues(DT); GetNoiseValues(DT);
@ -379,7 +380,6 @@ void GetVoiceValues(s32& Value) {
} }
CalculateADSR(); CalculateADSR();
// CalculateADSR();
if(vc.ADSR.Phase==0) if(vc.ADSR.Phase==0)
{ {
@ -388,12 +388,18 @@ void GetVoiceValues(s32& Value) {
} }
else else
{ {
if(Interpolation==0) { // if SP is zero then we landed perfectly on a sample source, no
// interpolation necessary (this is important too, since the
// interpolator will pick the wrong sample to mix).
if(Interpolation==0 || vc.SP == 0) {
Data = vc.PV1; Data = vc.PV1;
} }
else if(Interpolation==1) //linear else if(Interpolation==1) //linear
{ {
s64 t0 = vc.PV1 - vc.PV2; // [Air]: Inverted the interpolation delta. The old way was generating
// inverted waveforms.
s64 t0 = vc.PV2 - vc.PV1;
s64 t1 = vc.PV1; s64 t1 = vc.PV1;
Data = (((t0*vc.SP)>>12) + t1); Data = (((t0*vc.SP)>>12) + t1);
} }
@ -403,11 +409,11 @@ void GetVoiceValues(s32& Value) {
s64 a1 = vc.PV4 - vc.PV3 - a0; s64 a1 = vc.PV4 - vc.PV3 - a0;
s64 a2 = vc.PV1 - vc.PV4; s64 a2 = vc.PV1 - vc.PV4;
s64 a3 = vc.PV2; s64 a3 = vc.PV2;
s64 mu = vc.SP; s64 mu = 4096-vc.SP;
s64 t0 = ((a0 )*mu)>>12; s64 t0 = ((a0 )*mu)>>18; //all 3 were >>12, was causing ugly, loud overflow sound
s64 t1 = ((t0+a1)*mu)>>12; s64 t1 = ((t0+a1)*mu)>>18;
s64 t2 = ((t1+a2)*mu)>>12; s64 t2 = ((t1+a2)*mu)>>18;
s64 t3 = ((t2+a3)); s64 t3 = ((t2+a3));
Data = t3; Data = t3;
@ -417,7 +423,7 @@ void GetVoiceValues(s32& Value) {
vc.OutX=abs(Value); vc.OutX=abs(Value);
} }
if(vc.PeakX<vc.OutX) vc.PeakX=vc.OutX; //if(vc.PeakX<vc.OutX) vc.PeakX=vc.OutX;
} }
///////////////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////////////////

View File

@ -282,7 +282,7 @@ float valAccum1 = 1.0f;
float valAccum2 = 1.0f; float valAccum2 = 1.0f;
u32 numAccum = 1; u32 numAccum = 1;
const u32 numUpdates = 112; const u32 numUpdates = 96;
float lastTempo=1; float lastTempo=1;
float cTempo=1; float cTempo=1;
@ -312,21 +312,21 @@ void UpdateTempoChange()
s32 bufferSize = sndBuffer->GetBufferSize(); s32 bufferSize = sndBuffer->GetBufferSize();
//Emergency stretch to compensate for FPS fluctuations and keep the buffers happy //Emergency stretch to compensate for FPS fluctuations and keep the buffers happy
bool a=(bufferUsage < CurBufferSize * 2.5); bool a=(bufferUsage < CurBufferSize * 4);
bool b=(bufferUsage >= (bufferSize - CurBufferSize * 2.5)); bool b=(bufferUsage >= (bufferSize - CurBufferSize * 4));
if(a!=b) if(a!=b)
{ {
if (bufferUsage < CurBufferSize) { cTempo*=0.7f; } if (bufferUsage < CurBufferSize * 1.5) { cTempo*=0.70f; }
else if(bufferUsage < CurBufferSize * 2) { cTempo*=0.90f; } else if(bufferUsage < CurBufferSize * 2) { cTempo*=0.90f; }
else if(bufferUsage < CurBufferSize * 2.5) { cTempo*=0.95f; } else if(bufferUsage < CurBufferSize * 3.9) { cTempo*=0.95f; }
if (bufferUsage > (bufferSize - CurBufferSize)) { cTempo*=1.3f; } if (bufferUsage > (bufferSize - CurBufferSize * 1.5)) { cTempo*=1.30f; }
else if(bufferUsage > (bufferSize - CurBufferSize * 2)) { cTempo*=1.10f; } else if(bufferUsage > (bufferSize - CurBufferSize * 2)) { cTempo*=1.10f; }
else if(bufferUsage > (bufferSize - CurBufferSize * 2.5)) { cTempo*=1.05f; } else if(bufferUsage > (bufferSize - CurBufferSize * 3.9)) { cTempo*=1.05f; }
if (cTempo != lastTempo) { if (cTempo != lastTempo) {
printf("%f %d\n",cTempo,bufferUsage); //printf("%f %d\n",cTempo,bufferUsage);
pSoundTouch->setTempo(cTempo); pSoundTouch->setTempo(cTempo);
} }
} }
@ -354,12 +354,12 @@ void UpdateTempoChange()
if((valAccum < 1.05f) && (valAccum > 0.95f) /*&& (valAccum != 1)*/) if((valAccum < 1.05f) && (valAccum > 0.95f) /*&& (valAccum != 1)*/)
{ {
printf("Timestretch Debug > Playbackpeed: %f (difference disregarded, using 1.0).\n",valAccum); //printf("Timestretch Debug > Playbackpeed: %f (difference disregarded, using 1.0).\n",valAccum);
valAccum = 1.0f; valAccum = 1.0f;
} }
else else
{ {
printf("Timestretch Debug > Playbackpeed: %f\n",valAccum); // printf("Timestretch Debug > Playbackpeed: %f\n",valAccum);
} }
if (valAccum != lastTempo) //only update soundtouch object when needed if (valAccum != lastTempo) //only update soundtouch object when needed