mirror of
https://github.com/f4exb/sdrangel.git
synced 2025-10-24 09:30:22 -04:00
Correctness.
This commit is contained in:
parent
0203283876
commit
cb8026b957
@ -40,6 +40,7 @@ SSBDemod::SSBDemod(AudioFifo* audioFifo, SampleSink* sampleSink) :
|
|||||||
|
|
||||||
m_audioBuffer.resize(512);
|
m_audioBuffer.resize(512);
|
||||||
m_audioBufferFill = 0;
|
m_audioBufferFill = 0;
|
||||||
|
m_undersampleCount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
SSBDemod::~SSBDemod()
|
SSBDemod::~SSBDemod()
|
||||||
@ -52,7 +53,6 @@ void SSBDemod::configure(MessageQueue* messageQueue, Real Bandwidth, Real volume
|
|||||||
cmd->submit(messageQueue, this);
|
cmd->submit(messageQueue, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
int undersamplecount = 0;
|
|
||||||
void SSBDemod::feed(SampleVector::const_iterator begin, SampleVector::const_iterator end, bool positiveOnly)
|
void SSBDemod::feed(SampleVector::const_iterator begin, SampleVector::const_iterator end, bool positiveOnly)
|
||||||
{
|
{
|
||||||
Complex ci;
|
Complex ci;
|
||||||
@ -69,7 +69,7 @@ void SSBDemod::feed(SampleVector::const_iterator begin, SampleVector::const_iter
|
|||||||
demod = 32768.0 * m_lowpass.filter(demod * 0.7);
|
demod = 32768.0 * m_lowpass.filter(demod * 0.7);
|
||||||
|
|
||||||
// Downsample by 4x for audio display
|
// Downsample by 4x for audio display
|
||||||
if (!(undersamplecount++ & 3))
|
if (!(m_undersampleCount++ & 3))
|
||||||
m_sampleBuffer.push_back(Sample(demod, 0.0));
|
m_sampleBuffer.push_back(Sample(demod, 0.0));
|
||||||
|
|
||||||
qint16 sample = (qint16)(demod * m_volume);
|
qint16 sample = (qint16)(demod * m_volume);
|
||||||
|
@ -72,6 +72,7 @@ private:
|
|||||||
|
|
||||||
Real m_Bandwidth;
|
Real m_Bandwidth;
|
||||||
Real m_volume;
|
Real m_volume;
|
||||||
|
int m_undersampleCount;
|
||||||
int m_sampleRate;
|
int m_sampleRate;
|
||||||
int m_frequency;
|
int m_frequency;
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@ RTLSDRThread::RTLSDRThread(rtlsdr_dev_t* dev, SampleFifo* sampleFifo, QObject* p
|
|||||||
m_sampleFifo(sampleFifo),
|
m_sampleFifo(sampleFifo),
|
||||||
m_decimation(2)
|
m_decimation(2)
|
||||||
{
|
{
|
||||||
|
m_localdecimation = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
RTLSDRThread::~RTLSDRThread()
|
RTLSDRThread::~RTLSDRThread()
|
||||||
@ -135,15 +136,14 @@ void RTLSDRThread::decimate16(SampleVector::iterator* it, const quint8* buf, qin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int localdecimation = 0;
|
|
||||||
void RTLSDRThread::callback(const quint8* buf, qint32 len)
|
void RTLSDRThread::callback(const quint8* buf, qint32 len)
|
||||||
{
|
{
|
||||||
qint16 xreal, yimag, phase;
|
qint16 xreal, yimag, phase;
|
||||||
SampleVector::iterator it = m_convertBuffer.begin();
|
SampleVector::iterator it = m_convertBuffer.begin();
|
||||||
int decimationFactor[] = {16, 8, 4, 2, 1, 0};
|
int decimationFactor[] = {16, 8, 4, 2, 1, 0};
|
||||||
|
|
||||||
if (++localdecimation < decimationFactor[m_decimation]) return;
|
if (++m_localdecimation < decimationFactor[m_decimation]) return;
|
||||||
localdecimation = 0;
|
m_localdecimation = 0;
|
||||||
|
|
||||||
switch(m_decimation) {
|
switch(m_decimation) {
|
||||||
case 0: // 1:1 = no decimation
|
case 0: // 1:1 = no decimation
|
||||||
|
@ -47,6 +47,7 @@ private:
|
|||||||
SampleFifo* m_sampleFifo;
|
SampleFifo* m_sampleFifo;
|
||||||
|
|
||||||
int m_decimation;
|
int m_decimation;
|
||||||
|
int m_localdecimation;
|
||||||
|
|
||||||
void run();
|
void run();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user