SoapySDR support: output: tunable elements GUIs

This commit is contained in:
f4exb 2018-11-06 20:19:20 +01:00
parent 6ea676d5c4
commit e17828c7ee
7 changed files with 105 additions and 4 deletions

View File

@ -766,6 +766,31 @@ bool SoapySDROutput::applySettings(const SoapySDROutputSettings& settings, bool
} }
} }
for (const auto &oname : m_settings.m_tunableElements.keys())
{
auto nvalue = settings.m_tunableElements.find(oname);
if (nvalue != settings.m_tunableElements.end() && (m_settings.m_tunableElements[oname] != *nvalue))
{
if (dev != 0)
{
try
{
dev->setFrequency(SOAPY_SDR_TX, requestedChannel, oname.toStdString(), *nvalue);
qDebug("SoapySDROutput::applySettings: tunable element %s frequency set to %lf",
oname.toStdString().c_str(), *nvalue);
}
catch (const std::exception &ex)
{
qCritical("SoapySDROutput::applySettings: cannot set tunable element %s to %lf: %s",
oname.toStdString().c_str(), *nvalue, ex.what());
}
}
m_settings.m_tunableElements[oname] = *nvalue;
}
}
if (forwardChangeOwnDSP) if (forwardChangeOwnDSP)
{ {
int sampleRate = settings.m_devSampleRate/(1<<settings.m_log2Interp); int sampleRate = settings.m_devSampleRate/(1<<settings.m_log2Interp);

View File

@ -26,6 +26,7 @@
#include "soapygui/discreterangegui.h" #include "soapygui/discreterangegui.h"
#include "soapygui/intervalrangegui.h" #include "soapygui/intervalrangegui.h"
#include "soapygui/stringrangegui.h" #include "soapygui/stringrangegui.h"
#include "soapygui/dynamicitemsettinggui.h"
#include "soapysdroutputgui.h" #include "soapysdroutputgui.h"
@ -157,6 +158,28 @@ void SoapySDROutputGui::createAntennasControl(const std::vector<std::string>& an
connect(m_antennas, SIGNAL(valueChanged()), this, SLOT(antennasChanged())); connect(m_antennas, SIGNAL(valueChanged()), this, SLOT(antennasChanged()));
} }
void SoapySDROutputGui::createTunableElementsControl(const std::vector<DeviceSoapySDRParams::FrequencySetting>& tunableElementsList)
{
if (tunableElementsList.size() <= 1) { // This list is created for other elements than the main one (RF) which is always at index 0
return;
}
std::vector<DeviceSoapySDRParams::FrequencySetting>::const_iterator it = tunableElementsList.begin() + 1;
for (int i = 0; it != tunableElementsList.end(); ++it, i++)
{
ItemSettingGUI *rangeGUI;
createRangesControl(
&rangeGUI,
it->m_ranges,
QString("%1 freq").arg(it->m_name.c_str()),
QString((it->m_name == "CORR") ? "ppm" : "Hz"));
DynamicItemSettingGUI *gui = new DynamicItemSettingGUI(rangeGUI, QString(it->m_name.c_str()));
m_tunableElementsGUIs.push_back(gui);
connect(m_tunableElementsGUIs.back(), SIGNAL(valueChanged(QString, double)), this, SLOT(tunableElementChanged(QString, double)));
}
}
void SoapySDROutputGui::setName(const QString& name) void SoapySDROutputGui::setName(const QString& name)
{ {
setObjectName(name); setObjectName(name);
@ -279,6 +302,11 @@ void SoapySDROutputGui::bandwidthChanged(double bandwidth)
sendSettings(); sendSettings();
} }
void SoapySDROutputGui::tunableElementChanged(QString name, double value)
{
m_settings.m_tunableElements[name] = value;
sendSettings();
}
void SoapySDROutputGui::on_centerFrequency_changed(quint64 value) void SoapySDROutputGui::on_centerFrequency_changed(quint64 value)
{ {
@ -341,9 +369,23 @@ void SoapySDROutputGui::displaySettings()
ui->LOppm->setValue(m_settings.m_LOppmTenths); ui->LOppm->setValue(m_settings.m_LOppmTenths);
ui->LOppmText->setText(QString("%1").arg(QString::number(m_settings.m_LOppmTenths/10.0, 'f', 1))); ui->LOppmText->setText(QString("%1").arg(QString::number(m_settings.m_LOppmTenths/10.0, 'f', 1)));
displayTunableElementsControlSettings();
blockApplySettings(false); blockApplySettings(false);
} }
void SoapySDROutputGui::displayTunableElementsControlSettings()
{
for (const auto &it : m_tunableElementsGUIs)
{
QMap<QString, double>::const_iterator elIt = m_settings.m_tunableElements.find(it->getName());
if (elIt != m_settings.m_tunableElements.end()) {
it->setValue(*elIt);
}
}
}
void SoapySDROutputGui::sendSettings() void SoapySDROutputGui::sendSettings()
{ {
if (!m_updateTimer.isActive()) { if (!m_updateTimer.isActive()) {

View File

@ -30,6 +30,7 @@ class DeviceSampleSink;
class DeviceUISet; class DeviceUISet;
class ItemSettingGUI; class ItemSettingGUI;
class StringRangeGUI; class StringRangeGUI;
class DynamicItemSettingGUI;
namespace Ui { namespace Ui {
class SoapySDROutputGui; class SoapySDROutputGui;
@ -61,6 +62,7 @@ private:
const QString& text, const QString& text,
const QString& unit); const QString& unit);
void createAntennasControl(const std::vector<std::string>& antennaList); void createAntennasControl(const std::vector<std::string>& antennaList);
void createTunableElementsControl(const std::vector<DeviceSoapySDRParams::FrequencySetting>& tunableElementsList);
Ui::SoapySDROutputGui* ui; Ui::SoapySDROutputGui* ui;
@ -79,9 +81,11 @@ private:
StringRangeGUI *m_antennas; StringRangeGUI *m_antennas;
ItemSettingGUI *m_sampleRateGUI; ItemSettingGUI *m_sampleRateGUI;
ItemSettingGUI *m_bandwidthGUI; ItemSettingGUI *m_bandwidthGUI;
std::vector<DynamicItemSettingGUI*> m_tunableElementsGUIs;
void blockApplySettings(bool block) { m_doApplySettings = !block; } void blockApplySettings(bool block) { m_doApplySettings = !block; }
void displaySettings(); void displaySettings();
void displayTunableElementsControlSettings();
void sendSettings(); void sendSettings();
void updateSampleRateAndFrequency(); void updateSampleRateAndFrequency();
void updateFrequencyLimits(); void updateFrequencyLimits();
@ -89,9 +93,10 @@ private:
private slots: private slots:
void handleInputMessages(); void handleInputMessages();
void sampleRateChanged(double sampleRate);
void antennasChanged(); void antennasChanged();
void sampleRateChanged(double sampleRate);
void bandwidthChanged(double bandwidth); void bandwidthChanged(double bandwidth);
void tunableElementChanged(QString name, double value);
void on_centerFrequency_changed(quint64 value); void on_centerFrequency_changed(quint64 value);
void on_LOppm_valueChanged(int value); void on_LOppm_valueChanged(int value);
void on_interp_currentIndexChanged(int index); void on_interp_currentIndexChanged(int index);

View File

@ -15,6 +15,8 @@
/////////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////////
#include <QtGlobal> #include <QtGlobal>
#include <QDataStream>
#include "util/simpleserializer.h" #include "util/simpleserializer.h"
#include "soapysdroutputsettings.h" #include "soapysdroutputsettings.h"
@ -47,6 +49,7 @@ QByteArray SoapySDROutputSettings::serialize() const
s.writeS64(5, m_transverterDeltaFrequency); s.writeS64(5, m_transverterDeltaFrequency);
s.writeString(6, m_antenna); s.writeString(6, m_antenna);
s.writeU32(7, m_bandwidth); s.writeU32(7, m_bandwidth);
s.writeBlob(8, serializeNamedElementMap(m_tunableElements));
return s.final(); return s.final();
} }
@ -63,6 +66,8 @@ bool SoapySDROutputSettings::deserialize(const QByteArray& data)
if (d.getVersion() == 1) if (d.getVersion() == 1)
{ {
QByteArray blob;
d.readS32(1, &m_devSampleRate); d.readS32(1, &m_devSampleRate);
d.readS32(2, &m_LOppmTenths); d.readS32(2, &m_LOppmTenths);
d.readU32(3, &m_log2Interp); d.readU32(3, &m_log2Interp);
@ -70,6 +75,8 @@ bool SoapySDROutputSettings::deserialize(const QByteArray& data)
d.readS64(5, &m_transverterDeltaFrequency, 0); d.readS64(5, &m_transverterDeltaFrequency, 0);
d.readString(6, &m_antenna, "NONE"); d.readString(6, &m_antenna, "NONE");
d.readU32(7, &m_bandwidth, 1000000); d.readU32(7, &m_bandwidth, 1000000);
d.readBlob(8, &blob);
deserializeNamedElementMap(blob, m_tunableElements);
return true; return true;
} }
@ -79,3 +86,20 @@ bool SoapySDROutputSettings::deserialize(const QByteArray& data)
return false; return false;
} }
} }
QByteArray SoapySDROutputSettings::serializeNamedElementMap(const QMap<QString, double>& map) const
{
QByteArray data;
QDataStream *stream = new QDataStream(&data, QIODevice::WriteOnly);
(*stream) << map;
delete stream;
return data;
}
void SoapySDROutputSettings::deserializeNamedElementMap(const QByteArray& data, QMap<QString, double>& map)
{
QDataStream *stream = new QDataStream(data);
(*stream) >> map;
delete stream;
}

View File

@ -18,6 +18,7 @@
#define PLUGINS_SAMPLESINK_SOAPYSDROUTPUT_SOAPYSDROUTPUTSETTINGS_H_ #define PLUGINS_SAMPLESINK_SOAPYSDROUTPUT_SOAPYSDROUTPUTSETTINGS_H_
#include <QtGlobal> #include <QtGlobal>
#include <QMap>
struct SoapySDROutputSettings { struct SoapySDROutputSettings {
quint64 m_centerFrequency; quint64 m_centerFrequency;
@ -28,11 +29,16 @@ struct SoapySDROutputSettings {
qint64 m_transverterDeltaFrequency; qint64 m_transverterDeltaFrequency;
QString m_antenna; QString m_antenna;
quint32 m_bandwidth; quint32 m_bandwidth;
QMap<QString, double> m_tunableElements;
SoapySDROutputSettings(); SoapySDROutputSettings();
void resetToDefaults(); void resetToDefaults();
QByteArray serialize() const; QByteArray serialize() const;
bool deserialize(const QByteArray& data); bool deserialize(const QByteArray& data);
private:
QByteArray serializeNamedElementMap(const QMap<QString, double>& map) const;
void deserializeNamedElementMap(const QByteArray& data, QMap<QString, double>& map);
}; };
#endif /* PLUGINS_SAMPLESINK_SOAPYSDROUTPUT_SOAPYSDROUTPUTSETTINGS_H_ */ #endif /* PLUGINS_SAMPLESINK_SOAPYSDROUTPUT_SOAPYSDROUTPUTSETTINGS_H_ */

View File

@ -306,7 +306,6 @@ void SoapySDRInputGui::bandwidthChanged(double bandwidth)
void SoapySDRInputGui::tunableElementChanged(QString name, double value) void SoapySDRInputGui::tunableElementChanged(QString name, double value)
{ {
qDebug("SoapySDRInputGui::tunableElementChanged: name: %s value: %lf", name.toStdString().c_str(), value);
m_settings.m_tunableElements[name] = value; m_settings.m_tunableElements[name] = value;
sendSettings(); sendSettings();
} }

View File

@ -92,10 +92,10 @@ private:
private slots: private slots:
void handleInputMessages(); void handleInputMessages();
void sampleRateChanged(double sampleRate);
void antennasChanged(); void antennasChanged();
void tunableElementChanged(QString name, double value); void sampleRateChanged(double sampleRate);
void bandwidthChanged(double bandwidth); void bandwidthChanged(double bandwidth);
void tunableElementChanged(QString name, double value);
void on_centerFrequency_changed(quint64 value); void on_centerFrequency_changed(quint64 value);
void on_LOppm_valueChanged(int value); void on_LOppm_valueChanged(int value);
void on_dcOffset_toggled(bool checked); void on_dcOffset_toggled(bool checked);