1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2024-11-22 16:08:39 -05:00

Corrected number of audio samples pulled considering interpolation

This commit is contained in:
f4exb 2016-12-26 02:15:24 +01:00
parent e02ac85e50
commit 437891da43
4 changed files with 22 additions and 16 deletions

View File

@ -121,7 +121,6 @@ void AMMod::pull(Sample& sample)
}
}
m_audioBufferFill++;
m_interpolatorDistanceRemain += m_interpolatorDistance;
ci *= m_carrierNco.nextIQ(); // shift to carrier frequency
@ -140,13 +139,14 @@ void AMMod::pull(Sample& sample)
void AMMod::pullAudio(int nbSamples)
{
// qDebug("AMMod::pullAudio: %d", nbSamples);
int nbAudioSamples = nbSamples * m_interpolatorDistance;
if (nbSamples > m_audioBuffer.size())
if (nbAudioSamples > m_audioBuffer.size())
{
m_audioBuffer.resize(nbSamples);
m_audioBuffer.resize(nbAudioSamples);
}
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamples*sizeof(AudioSample), 10);
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbAudioSamples*sizeof(AudioSample), 10);
m_audioBufferFill = 0;
}
@ -156,6 +156,7 @@ void AMMod::modulateSample()
pullAF(t);
calculateLevel(t);
m_audioBufferFill++;
m_modSample.real((t*m_running.m_modFactor + 1.0f) * 16384.0f); // modulate and scale zero frequency carrier
m_modSample.imag(0.0f);

View File

@ -136,7 +136,6 @@ void NFMMod::pull(Sample& sample)
}
}
m_audioBufferFill++;
m_interpolatorDistanceRemain += m_interpolatorDistance;
ci *= m_carrierNco.nextIQ(); // shift to carrier frequency
@ -154,12 +153,14 @@ void NFMMod::pull(Sample& sample)
void NFMMod::pullAudio(int nbSamples)
{
if (nbSamples > m_audioBuffer.size())
int nbSamplesAudio = nbSamples * m_interpolatorDistance;
if (nbSamplesAudio > m_audioBuffer.size())
{
m_audioBuffer.resize(nbSamples);
m_audioBuffer.resize(nbSamplesAudio);
}
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamples*sizeof(AudioSample), 10);
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamplesAudio*sizeof(AudioSample), 10);
m_audioBufferFill = 0;
}
@ -169,6 +170,7 @@ void NFMMod::modulateSample()
pullAF(t);
calculateLevel(t);
m_audioBufferFill++;
if (m_running.m_ctcssOn)
{

View File

@ -166,7 +166,6 @@ void SSBMod::pull(Sample& sample)
}
}
m_audioBufferFill++;
m_interpolatorDistanceRemain += m_interpolatorDistance;
ci *= m_carrierNco.nextIQ(); // shift to carrier frequency
@ -185,12 +184,14 @@ void SSBMod::pull(Sample& sample)
void SSBMod::pullAudio(int nbSamples)
{
if (nbSamples > m_audioBuffer.size())
int nbSamplesAudio = nbSamples * m_interpolatorDistance;
if (nbSamplesAudio > m_audioBuffer.size())
{
m_audioBuffer.resize(nbSamples);
m_audioBuffer.resize(nbSamplesAudio);
}
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamples*sizeof(AudioSample), 10);
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamplesAudio*sizeof(AudioSample), 10);
m_audioBufferFill = 0;
}
@ -198,6 +199,7 @@ void SSBMod::modulateSample()
{
pullAF(m_modSample);
calculateLevel(m_modSample);
m_audioBufferFill++;
}
void SSBMod::pullAF(Complex& sample)

View File

@ -119,7 +119,6 @@ void WFMMod::pull(Sample& sample)
m_audioBufferFill++;
}
m_audioBufferFill++;
m_interpolatorDistanceRemain += m_interpolatorDistance;
m_modPhasor += (m_running.m_fmDeviation / (float) m_running.m_outputSampleRate) * ri.real() * M_PI;
@ -143,12 +142,14 @@ void WFMMod::pull(Sample& sample)
void WFMMod::pullAudio(int nbSamples)
{
if (nbSamples > m_audioBuffer.size())
int nbSamplesAudio = nbSamples * m_interpolatorDistance;
if (nbSamplesAudio > m_audioBuffer.size())
{
m_audioBuffer.resize(nbSamples);
m_audioBuffer.resize(nbSamplesAudio);
}
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamples*sizeof(AudioSample), 10);
m_audioFifo.read(reinterpret_cast<quint8*>(&m_audioBuffer[0]), nbSamplesAudio*sizeof(AudioSample), 10);
m_audioBufferFill = 0;
}