From a8880656241826b297b3c9658401bd9d8ed61152 Mon Sep 17 00:00:00 2001 From: Ryzerth Date: Fri, 23 Jul 2021 16:18:47 +0200 Subject: [PATCH] more fixes to stereo FM --- core/src/dsp/demodulator.h | 2 +- core/src/dsp/stereo_fm.h | 9 ++++++--- radio/src/wfm_demod.h | 25 ++++++++++++++++++++----- 3 files changed, 27 insertions(+), 9 deletions(-) diff --git a/core/src/dsp/demodulator.h b/core/src/dsp/demodulator.h index 74a9c853..756e6542 100644 --- a/core/src/dsp/demodulator.h +++ b/core/src/dsp/demodulator.h @@ -686,7 +686,7 @@ namespace dsp { pilotFilter.init(&r2c.out, &PilotFirWin); - demux.init(&pilotFilter.dataOut, &pilotFilter.pilotOut, 1.0f); + demux.init(&pilotFilter.dataOut, &pilotFilter.pilotOut, 0.1f); recon.init(&demux.AplusBOut, &demux.AminusBOut); diff --git a/core/src/dsp/stereo_fm.h b/core/src/dsp/stereo_fm.h index f925cc74..a71cbde1 100644 --- a/core/src/dsp/stereo_fm.h +++ b/core/src/dsp/stereo_fm.h @@ -157,8 +157,9 @@ namespace dsp { for (int i = 0; i < count; i++) { // Double the VCO, then mix it with the input data. + // IMPORTANT: THERE SHOULDN'T BE A NEED FOR A GAIN HERE doubledVCO = lastVCO*lastVCO; - AminusBOut.writeBuf[i] = (_data->readBuf[i].re * doubledVCO.re) + (_data->readBuf[i].im * doubledVCO.im); + AminusBOut.writeBuf[i] = (_data->readBuf[i].re * doubledVCO.re) * 2.0f; // Calculate the phase error estimation error = _pilot->readBuf[i].phase() - vcoPhase; @@ -191,6 +192,8 @@ namespace dsp { stream AplusBOut; stream AminusBOut; + float gain = 2.0f; + private: float _loopBandwidth = 0.01f; @@ -257,8 +260,8 @@ namespace dsp { return 0; } - volk_32f_x2_add_32f(leftBuf, _aplusb->readBuf, _aminusb->readBuf, a_count); - volk_32f_x2_subtract_32f(rightBuf, _aplusb->readBuf, _aminusb->readBuf, a_count); + volk_32f_x2_add_32f(rightBuf, _aplusb->readBuf, _aminusb->readBuf, a_count); + volk_32f_x2_subtract_32f(leftBuf, _aplusb->readBuf, _aminusb->readBuf, a_count); _aplusb->flush(); _aminusb->flush(); diff --git a/radio/src/wfm_demod.h b/radio/src/wfm_demod.h index 5bbf4d28..d0c898c5 100644 --- a/radio/src/wfm_demod.h +++ b/radio/src/wfm_demod.h @@ -26,22 +26,29 @@ public: _config->acquire(); if(_config->conf.contains(prefix)) { if(!_config->conf[prefix].contains("WFM")) { - if (!_config->conf[prefix]["WFM"].contains("bandwidth")) { _config->conf[prefix]["WFM"]["bandwidth"] = bw; } - if (!_config->conf[prefix]["WFM"].contains("snapInterval")) { _config->conf[prefix]["WFM"]["snapInterval"] = snapInterval; } - if (!_config->conf[prefix]["WFM"].contains("deempMode")) { _config->conf[prefix]["WFM"]["deempMode"] = deempId; } - if (!_config->conf[prefix]["WFM"].contains("squelchLevel")) { _config->conf[prefix]["WFM"]["squelchLevel"] = squelchLevel; } + _config->conf[prefix]["WFM"]["bandwidth"] = bw; + _config->conf[prefix]["WFM"]["snapInterval"] = snapInterval; + _config->conf[prefix]["WFM"]["deempMode"] = deempId; + _config->conf[prefix]["WFM"]["squelchLevel"] = squelchLevel; + _config->conf[prefix]["WFM"]["stereo"] = false; } + + // Correct for new settings + if (!config->conf[prefix]["WFM"].contains("stereo")) { _config->conf[prefix]["WFM"]["stereo"] = false;} + json conf = _config->conf[prefix]["WFM"]; bw = conf["bandwidth"]; snapInterval = conf["snapInterval"]; deempId = conf["deempMode"]; squelchLevel = conf["squelchLevel"]; + stereo = conf["stereo"]; } else { _config->conf[prefix]["WFM"]["bandwidth"] = bw; _config->conf[prefix]["WFM"]["snapInterval"] = snapInterval; _config->conf[prefix]["WFM"]["deempMode"] = deempId; _config->conf[prefix]["WFM"]["squelchLevel"] = squelchLevel; + _config->conf[prefix]["WFM"]["stereo"] = false; } _config->release(true); @@ -52,7 +59,12 @@ public: float audioBW = std::min(audioSampleRate / 2.0f, 16000.0f); win.init(audioBW, audioBW, bbSampRate); - resamp.init(&demod.out, &win, bbSampRate, audioSampRate); + if (stereo) { + resamp.init(demodStereo.out, &win, bbSampRate, audioSampRate); + } + else { + resamp.init(&demod.out, &win, bbSampRate, audioSampRate); + } win.setSampleRate(bbSampRate * resamp.getInterpolation()); resamp.updateWindow(&win); @@ -190,6 +202,9 @@ public: if (ImGui::Checkbox("Stereo##radio_wfm_demod", &stereo)) { setStereo(stereo); + _config->acquire(); + _config->conf[uiPrefix]["WFM"]["stereo"] = stereo; + _config->release(true); } }