| 
									
										
										
										
											2020-04-28 18:44:03 +02:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Copyright (C) 2015-2020 Edouard Griffiths, F4EXB                              //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // Symbol synchronizer or symbol clock recovery mostly encapsulating             //
 | 
					
						
							|  |  |  | // liquid-dsp's symsync "object"                                                 //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is free software; you can redistribute it and/or modify          //
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by          //
 | 
					
						
							|  |  |  | // the Free Software Foundation as version 3 of the License, or                  //
 | 
					
						
							|  |  |  | // (at your option) any later version.                                           //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,               //
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of                //
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the                  //
 | 
					
						
							|  |  |  | // GNU General Public License V3 for more details.                               //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License             //
 | 
					
						
							|  |  |  | // along with this program. If not, see <http://www.gnu.org/licenses/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | #ifndef INCLUDE_SPECTRUMVIS_H
 | 
					
						
							|  |  |  | #define INCLUDE_SPECTRUMVIS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-22 02:27:56 +02:00
										 |  |  | #include <QMutex>
 | 
					
						
							| 
									
										
										
										
											2020-04-29 17:41:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "dsp/basebandsamplesink.h"
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | #include "dsp/fftengine.h"
 | 
					
						
							| 
									
										
										
										
											2017-10-22 19:12:43 +02:00
										 |  |  | #include "dsp/fftwindow.h"
 | 
					
						
							| 
									
										
										
										
											2020-05-01 02:12:30 +02:00
										 |  |  | #include "dsp/glspectrumsettings.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-20 13:49:21 +01:00
										 |  |  | #include "export.h"
 | 
					
						
							| 
									
										
										
										
											2015-08-18 02:47:14 +02:00
										 |  |  | #include "util/message.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-28 23:47:15 +02:00
										 |  |  | #include "util/movingaverage2d.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-01 02:16:59 +02:00
										 |  |  | #include "util/fixedaverage2d.h"
 | 
					
						
							| 
									
										
										
										
											2018-10-12 08:47:14 +02:00
										 |  |  | #include "util/max2d.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-29 17:41:17 +02:00
										 |  |  | #include "websockets/wsspectrum.h"
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-28 18:44:03 +02:00
										 |  |  | class GLSpectrumInterface; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | class MessageQueue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  | namespace SWGSDRangel { | 
					
						
							|  |  |  |     class SWGGLSpectrum; | 
					
						
							|  |  |  |     class SWGSpectrumServer; | 
					
						
							| 
									
										
										
										
											2020-05-06 01:38:23 +02:00
										 |  |  |     class SWGSuccessResponse; | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 19:34:28 +01:00
										 |  |  | class SDRBASE_API SpectrumVis : public BasebandSampleSink { | 
					
						
							| 
									
										
										
										
											2015-08-18 02:47:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-05-14 22:14:11 +02:00
										 |  |  |     class SDRBASE_API MsgConfigureSpectrumVis : public Message { | 
					
						
							| 
									
										
										
										
											2020-05-01 02:12:30 +02:00
										 |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         const GLSpectrumSettings& getSettings() const { return m_settings; } | 
					
						
							|  |  |  |         bool getForce() const { return m_force; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-02 00:35:47 +02:00
										 |  |  |         static MsgConfigureSpectrumVis* create(const GLSpectrumSettings& settings, bool force) { | 
					
						
							| 
									
										
										
										
											2020-05-01 02:12:30 +02:00
										 |  |  |             return new MsgConfigureSpectrumVis(settings, force); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         GLSpectrumSettings m_settings; | 
					
						
							|  |  |  |         bool m_force; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureSpectrumVis(const GLSpectrumSettings& settings, bool force) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_settings(settings), | 
					
						
							|  |  |  |             m_force(force) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-05 11:04:20 +02:00
										 |  |  |     class SDRBASE_API MsgStartStop : public Message { | 
					
						
							| 
									
										
										
										
											2020-07-05 10:03:41 +02:00
										 |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         bool getStartStop() const { return m_startStop; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgStartStop* create(bool startStop) { | 
					
						
							|  |  |  |             return new MsgStartStop(startStop); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected: | 
					
						
							|  |  |  |         bool m_startStop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgStartStop(bool startStop) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_startStop(startStop) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 19:34:28 +01:00
										 |  |  |     class SDRBASE_API MsgConfigureWSpectrumOpenClose : public Message | 
					
						
							| 
									
										
										
										
											2020-05-02 00:35:47 +02:00
										 |  |  |     { | 
					
						
							|  |  |  | 		MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  |         Real getOpenClose() const { return m_openClose; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgConfigureWSpectrumOpenClose* create(bool openClose) { | 
					
						
							|  |  |  |             return new MsgConfigureWSpectrumOpenClose(openClose); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         bool m_openClose; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureWSpectrumOpenClose(bool openClose) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_openClose(openClose) | 
					
						
							|  |  |  |         {} | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 10:15:34 +01:00
										 |  |  |     class SDRBASE_API MsgFrequencyZooming : public Message { | 
					
						
							| 
									
										
										
										
											2021-02-15 13:49:51 +01:00
										 |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         float getFrequencyZoomFactor() const { return m_frequencyZoomFactor; } | 
					
						
							|  |  |  |         float getFrequencyZoomPos() const { return m_frequencyZoomPos; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgFrequencyZooming* create(float frequencyZoomFactor, float frequencyZoomPos) { | 
					
						
							|  |  |  |             return new MsgFrequencyZooming(frequencyZoomFactor, frequencyZoomPos); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         float m_frequencyZoomFactor; | 
					
						
							|  |  |  |         float m_frequencyZoomPos; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgFrequencyZooming(float frequencyZoomFactor, float frequencyZoomPos) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_frequencyZoomFactor(frequencyZoomFactor), | 
					
						
							|  |  |  |             m_frequencyZoomPos(frequencyZoomPos) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-12 08:47:14 +02:00
										 |  |  |     enum AvgMode | 
					
						
							| 
									
										
										
										
											2018-07-01 02:16:59 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-01 22:36:36 +02:00
										 |  |  |         AvgModeNone, | 
					
						
							| 
									
										
										
										
											2018-10-12 08:47:14 +02:00
										 |  |  |         AvgModeMovingAvg, | 
					
						
							|  |  |  |         AvgModeFixedAvg, | 
					
						
							|  |  |  |         AvgModeMax | 
					
						
							| 
									
										
										
										
											2018-07-01 02:16:59 +02:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-30 09:57:05 +02:00
										 |  |  | 	SpectrumVis(Real scalef); | 
					
						
							|  |  |  | 	virtual ~SpectrumVis(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void setGLSpectrum(GLSpectrumInterface* glSpectrum) { m_glSpectrum = glSpectrum; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void setScalef(Real scalef); | 
					
						
							|  |  |  |     void configureWSSpectrum(const QString& address, uint16_t port); | 
					
						
							| 
									
										
										
										
											2020-07-16 16:58:45 +02:00
										 |  |  |     const GLSpectrumSettings& getSettings() const { return m_settings; } | 
					
						
							|  |  |  |     Real getSpecMax() const { return m_specMax / m_powFFTDiv; } | 
					
						
							| 
									
										
										
										
											2021-02-10 08:34:42 +01:00
										 |  |  |     void getPowerSpectrumCopy(std::vector<Real>& copy) { copy.assign(m_powerSpectrum.begin(), m_powerSpectrum.end()); } | 
					
						
							| 
									
										
										
										
											2021-02-18 06:23:12 +01:00
										 |  |  |     void getPSDCopy(std::vector<Real>& copy) const { copy.assign(m_psd.begin(), m_psd.begin() + m_settings.m_fftSize); } | 
					
						
							|  |  |  |     void getZoomedPSDCopy(std::vector<Real>& copy) const; | 
					
						
							| 
									
										
										
										
											2020-04-30 09:57:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	virtual void feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool positiveOnly); | 
					
						
							|  |  |  |     virtual void feed(const Complex *begin, unsigned int length); //!< direct FFT feed
 | 
					
						
							|  |  |  | 	void feedTriggered(const SampleVector::const_iterator& triggerPoint, const SampleVector::const_iterator& end, bool positiveOnly); | 
					
						
							|  |  |  | 	virtual void start(); | 
					
						
							|  |  |  | 	virtual void stop(); | 
					
						
							|  |  |  | 	virtual bool handleMessage(const Message& message); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-08 21:52:47 +01:00
										 |  |  |     void setMessageQueueToGUI(MessageQueue *queue) { m_guiMessageQueue = queue; } | 
					
						
							|  |  |  |     MessageQueue *getMessageQueueToGUI() { return m_guiMessageQueue; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  |     int webapiSpectrumSettingsGet(SWGSDRangel::SWGGLSpectrum& response, QString& errorMessage) const; | 
					
						
							| 
									
										
										
										
											2020-05-06 01:38:23 +02:00
										 |  |  |     int webapiSpectrumSettingsPutPatch( | 
					
						
							|  |  |  |             bool force, | 
					
						
							|  |  |  |             const QStringList& spectrumSettingsKeys, | 
					
						
							|  |  |  |             SWGSDRangel::SWGGLSpectrum& response, // query + response
 | 
					
						
							|  |  |  |             QString& errorMessage); | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  |     int webapiSpectrumServerGet(SWGSDRangel::SWGSpectrumServer& response, QString& errorMessage) const; | 
					
						
							| 
									
										
										
										
											2020-05-06 01:38:23 +02:00
										 |  |  |     int webapiSpectrumServerPost(SWGSDRangel::SWGSuccessResponse& response, QString& errorMessage); | 
					
						
							|  |  |  |     int webapiSpectrumServerDelete(SWGSDRangel::SWGSuccessResponse& response, QString& errorMessage); | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-30 09:57:05 +02:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2019-10-26 22:30:53 +02:00
										 |  |  |     class MsgConfigureScalingFactor : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 		MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  |         MsgConfigureScalingFactor(Real scalef) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_scalef(scalef) | 
					
						
							|  |  |  |         {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Real getScalef() const { return m_scalef; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         Real m_scalef; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-30 09:57:05 +02:00
										 |  |  |     class MsgConfigureWSpectrum : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 		MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  |         MsgConfigureWSpectrum(const QString& address, uint16_t port) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_address(address), | 
					
						
							|  |  |  |             m_port(port) | 
					
						
							|  |  |  |         {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const QString& getAddress() const { return m_address; } | 
					
						
							|  |  |  |         uint16_t getPort() const { return m_port; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         QString m_address; | 
					
						
							|  |  |  |         uint16_t m_port; | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-05 10:03:41 +02:00
										 |  |  |     bool m_running; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 	FFTEngine* m_fft; | 
					
						
							|  |  |  | 	FFTWindow m_window; | 
					
						
							| 
									
										
										
										
											2020-03-12 06:27:38 +01:00
										 |  |  |     unsigned int m_fftEngineSequence; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	std::vector<Complex> m_fftBuffer; | 
					
						
							| 
									
										
										
										
											2021-02-10 08:34:42 +01:00
										 |  |  | 	std::vector<Real> m_powerSpectrum; //!< displayable power spectrum
 | 
					
						
							|  |  |  |     std::vector<Real> m_psd; //!< real PSD
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-01 02:12:30 +02:00
										 |  |  |     GLSpectrumSettings m_settings; | 
					
						
							| 
									
										
										
										
											2021-02-08 23:40:28 +01:00
										 |  |  | 	int m_overlapSize; | 
					
						
							|  |  |  | 	int m_refillSize; | 
					
						
							|  |  |  | 	int m_fftBufferFill; | 
					
						
							| 
									
										
										
										
											2015-07-15 01:19:39 +02:00
										 |  |  | 	bool m_needMoreSamples; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-15 13:49:51 +01:00
										 |  |  |     float m_frequencyZoomFactor; | 
					
						
							|  |  |  |     float m_frequencyZoomPos; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-22 14:07:24 +01:00
										 |  |  | 	Real m_scalef; | 
					
						
							| 
									
										
										
										
											2020-04-28 18:44:03 +02:00
										 |  |  | 	GLSpectrumInterface* m_glSpectrum; | 
					
						
							| 
									
										
										
										
											2020-04-29 17:41:17 +02:00
										 |  |  |     WSSpectrum m_wsSpectrum; | 
					
						
							| 
									
										
										
										
											2018-07-01 02:16:59 +02:00
										 |  |  | 	MovingAverage2D<double> m_movingAverage; | 
					
						
							|  |  |  | 	FixedAverage2D<double> m_fixedAverage; | 
					
						
							| 
									
										
										
										
											2018-10-12 08:47:14 +02:00
										 |  |  | 	Max2D<double> m_max; | 
					
						
							| 
									
										
										
										
											2020-07-16 16:58:45 +02:00
										 |  |  |     Real m_specMax; | 
					
						
							| 
									
										
										
										
											2018-06-28 23:47:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-29 17:41:17 +02:00
										 |  |  |     uint64_t m_centerFrequency; | 
					
						
							|  |  |  |     int m_sampleRate; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 23:47:15 +02:00
										 |  |  | 	Real m_ofs; | 
					
						
							| 
									
										
										
										
											2018-07-06 01:34:05 +02:00
										 |  |  | 	Real m_powFFTDiv; | 
					
						
							| 
									
										
										
										
											2018-06-28 23:47:15 +02:00
										 |  |  | 	static const Real m_mult; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-08 21:52:47 +01:00
										 |  |  |     MessageQueue *m_guiMessageQueue;  //!< Input message queue to the GUI
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-22 02:27:56 +02:00
										 |  |  | 	QMutex m_mutex; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-10 00:08:42 +02:00
										 |  |  |     void setRunning(bool running) { m_running = running; } | 
					
						
							| 
									
										
										
										
											2020-05-01 02:12:30 +02:00
										 |  |  |     void applySettings(const GLSpectrumSettings& settings, bool force = false); | 
					
						
							| 
									
										
										
										
											2020-05-01 02:16:20 +02:00
										 |  |  |     void handleConfigureDSP(uint64_t centerFrequency, int sampleRate); | 
					
						
							| 
									
										
										
										
											2019-10-26 22:30:53 +02:00
										 |  |  |     void handleScalef(Real scalef); | 
					
						
							| 
									
										
										
										
											2020-05-01 02:16:20 +02:00
										 |  |  |     void handleWSOpenClose(bool openClose); | 
					
						
							| 
									
										
										
										
											2020-04-30 09:57:05 +02:00
										 |  |  |     void handleConfigureWSSpectrum(const QString& address, uint16_t port); | 
					
						
							| 
									
										
										
										
											2020-05-05 18:58:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static void webapiFormatSpectrumSettings(SWGSDRangel::SWGGLSpectrum& response, const GLSpectrumSettings& settings); | 
					
						
							| 
									
										
										
										
											2020-05-06 01:38:23 +02:00
										 |  |  |     static void webapiUpdateSpectrumSettings( | 
					
						
							|  |  |  |             GLSpectrumSettings& settings, | 
					
						
							|  |  |  |             const QStringList& spectrumSettingsKeys, | 
					
						
							|  |  |  |             SWGSDRangel::SWGGLSpectrum& response); | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // INCLUDE_SPECTRUMVIS_H
 |