| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Copyright (C) 2016 Edouard Griffiths, F4EXB                                   //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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                  //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef PLUGINS_CHANNELTX_MODSSB_SSBMOD_H_
 | 
					
						
							|  |  |  | #define PLUGINS_CHANNELTX_MODSSB_SSBMOD_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QMutex>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | #include <iostream>
 | 
					
						
							|  |  |  | #include <fstream>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "dsp/basebandsamplesource.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-14 00:14:52 +01:00
										 |  |  | #include "dsp/basebandsamplesink.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-19 08:28:50 +01:00
										 |  |  | #include "dsp/ncof.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | #include "dsp/interpolator.h"
 | 
					
						
							|  |  |  | #include "dsp/movingaverage.h"
 | 
					
						
							|  |  |  | #include "dsp/agc.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | #include "dsp/fftfilt.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | #include "dsp/cwkeyer.h"
 | 
					
						
							|  |  |  | #include "audio/audiofifo.h"
 | 
					
						
							|  |  |  | #include "util/message.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class SSBMod : public BasebandSampleSource { | 
					
						
							|  |  |  |     Q_OBJECT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     typedef enum | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SSBModInputNone, | 
					
						
							|  |  |  |         SSBModInputTone, | 
					
						
							|  |  |  |         SSBModInputFile, | 
					
						
							|  |  |  |         SSBModInputAudio, | 
					
						
							|  |  |  |         SSBModInputCWTone | 
					
						
							|  |  |  |     } SSBModInputAF; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgConfigureFileSourceName : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         const QString& getFileName() const { return m_fileName; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgConfigureFileSourceName* create(const QString& fileName) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgConfigureFileSourceName(fileName); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         QString m_fileName; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureFileSourceName(const QString& fileName) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_fileName(fileName) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgConfigureFileSourceSeek : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         int getPercentage() const { return m_seekPercentage; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgConfigureFileSourceSeek* create(int seekPercentage) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgConfigureFileSourceSeek(seekPercentage); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected: | 
					
						
							|  |  |  |         int m_seekPercentage; //!< percentage of seek position from the beginning 0..100
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureFileSourceSeek(int seekPercentage) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_seekPercentage(seekPercentage) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgConfigureFileSourceStreamTiming : public Message { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgConfigureFileSourceStreamTiming* create() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgConfigureFileSourceStreamTiming(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureFileSourceStreamTiming() : | 
					
						
							|  |  |  |             Message() | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgConfigureAFInput : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         SSBModInputAF getAFInput() const { return m_afInput; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgConfigureAFInput* create(SSBModInputAF afInput) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgConfigureAFInput(afInput); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							|  |  |  |         SSBModInputAF m_afInput; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgConfigureAFInput(SSBModInputAF afInput) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_afInput(afInput) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgReportFileSourceStreamTiming : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         std::size_t getSamplesCount() const { return m_samplesCount; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgReportFileSourceStreamTiming* create(std::size_t samplesCount) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgReportFileSourceStreamTiming(samplesCount); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected: | 
					
						
							|  |  |  |         std::size_t m_samplesCount; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgReportFileSourceStreamTiming(std::size_t samplesCount) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_samplesCount(samplesCount) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MsgReportFileSourceStreamData : public Message { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         int getSampleRate() const { return m_sampleRate; } | 
					
						
							|  |  |  |         quint32 getRecordLength() const { return m_recordLength; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static MsgReportFileSourceStreamData* create(int sampleRate, | 
					
						
							|  |  |  |                 quint32 recordLength) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             return new MsgReportFileSourceStreamData(sampleRate, recordLength); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected: | 
					
						
							|  |  |  |         int m_sampleRate; | 
					
						
							|  |  |  |         quint32 m_recordLength; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MsgReportFileSourceStreamData(int sampleRate, | 
					
						
							|  |  |  |                 quint32 recordLength) : | 
					
						
							|  |  |  |             Message(), | 
					
						
							|  |  |  |             m_sampleRate(sampleRate), | 
					
						
							|  |  |  |             m_recordLength(recordLength) | 
					
						
							|  |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //=================================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 00:14:52 +01:00
										 |  |  |     SSBMod(BasebandSampleSink* sampleSink); | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |     ~SSBMod(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void configure(MessageQueue* messageQueue, | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |             Real bandwidth, | 
					
						
							|  |  |  | 			Real lowCutoff, | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |             float toneFrequency, | 
					
						
							|  |  |  | 			float volumeFactor, | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | 			int spanLog2, | 
					
						
							|  |  |  | 			bool audioBinaural, | 
					
						
							|  |  |  | 			bool audioFlipChannels, | 
					
						
							|  |  |  | 			bool dsb, | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  | 			bool audioMute, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |             bool playLoop, | 
					
						
							|  |  |  |             bool agc, | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  |             float agcOrder, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |             int agcTime, | 
					
						
							|  |  |  |             int agcThreshold, | 
					
						
							|  |  |  |             int agcThresholdGate, | 
					
						
							|  |  |  |             int agcThresholdDelay); | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     virtual void pull(Sample& sample); | 
					
						
							| 
									
										
										
										
											2016-12-26 01:39:34 +01:00
										 |  |  |     virtual void pullAudio(int nbSamples); | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |     virtual void start(); | 
					
						
							|  |  |  |     virtual void stop(); | 
					
						
							|  |  |  |     virtual bool handleMessage(const Message& cmd); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 23:39:49 +02:00
										 |  |  |     double getMagSq() const { return m_magsq; } | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     CWKeyer *getCWKeyer() { return &m_cwKeyer; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | signals: | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Level changed | 
					
						
							|  |  |  | 	 * \param rmsLevel RMS level in range 0.0 - 1.0 | 
					
						
							|  |  |  | 	 * \param peakLevel Peak level in range 0.0 - 1.0 | 
					
						
							|  |  |  | 	 * \param numSamples Number of audio samples analyzed | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	void levelChanged(qreal rmsLevel, qreal peakLevel, int numSamples); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     class MsgConfigureSSBMod : public Message | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MESSAGE_CLASS_DECLARATION | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public: | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         Real getBandwidth() const { return m_bandwidth; } | 
					
						
							|  |  |  |         Real getLowCutoff() const { return m_lowCutoff; } | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         float getToneFrequency() const { return m_toneFrequency; } | 
					
						
							|  |  |  |         float getVolumeFactor() const { return m_volumeFactor; } | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         int getSpanLog2() const { return m_spanLog2; } | 
					
						
							|  |  |  |         bool getAudioBinaural() const { return m_audioBinaural; } | 
					
						
							|  |  |  |         bool getAudioFlipChannels() const { return m_audioFlipChannels; } | 
					
						
							|  |  |  |         bool getDSB() const { return m_dsb; } | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         bool getAudioMute() const { return m_audioMute; } | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  |         bool getPlayLoop() const { return m_playLoop; } | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         bool getAGC() const { return m_agc; } | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  |         float getAGCOrder() const { return m_agcOrder; } | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         int getAGCTime() const { return m_agcTime; } | 
					
						
							|  |  |  |         int getAGCThreshold() const { return m_agcThreshold; } | 
					
						
							|  |  |  |         int getAGCThresholdGate() const { return m_agcThresholdGate; } | 
					
						
							|  |  |  |         int getAGCThresholdDelay() const { return m_agcThresholdDelay; } | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         static MsgConfigureSSBMod* create(Real bandwidth, | 
					
						
							|  |  |  |         		Real lowCutoff, | 
					
						
							|  |  |  |         		float toneFrequency, | 
					
						
							|  |  |  | 				float volumeFactor, | 
					
						
							|  |  |  | 				int spanLog2, | 
					
						
							|  |  |  | 				bool audioBinaural, | 
					
						
							|  |  |  | 				bool audioFlipChannels, | 
					
						
							|  |  |  | 				bool dsb, | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  | 				bool audioMute, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 				bool playLoop, | 
					
						
							|  |  |  | 				bool agc, | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  | 				float agcOrder, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 				int agcTime, | 
					
						
							|  |  |  |                 int agcThreshold, | 
					
						
							|  |  |  |                 int agcThresholdGate, | 
					
						
							|  |  |  |                 int agcThresholdDelay) | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |             return new MsgConfigureSSBMod(bandwidth, | 
					
						
							|  |  |  |             		lowCutoff, | 
					
						
							|  |  |  | 					toneFrequency, | 
					
						
							|  |  |  | 					volumeFactor, | 
					
						
							|  |  |  | 					spanLog2, | 
					
						
							|  |  |  | 					audioBinaural, | 
					
						
							|  |  |  | 					audioFlipChannels, | 
					
						
							|  |  |  | 					dsb, | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  | 					audioMute, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 					playLoop, | 
					
						
							|  |  |  | 					agc, | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  | 					agcOrder, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 					agcTime, | 
					
						
							|  |  |  | 					agcThreshold, | 
					
						
							|  |  |  | 					agcThresholdGate, | 
					
						
							|  |  |  | 					agcThresholdDelay); | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         Real m_bandwidth; | 
					
						
							|  |  |  |         Real m_lowCutoff; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         float m_toneFrequency; | 
					
						
							|  |  |  |         float m_volumeFactor; | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | 		int  m_spanLog2; | 
					
						
							|  |  |  | 		bool m_audioBinaural; | 
					
						
							|  |  |  | 		bool m_audioFlipChannels; | 
					
						
							|  |  |  | 		bool m_dsb; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         bool m_audioMute; | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  |         bool m_playLoop; | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         bool m_agc; | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  |         float m_agcOrder; | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         int m_agcTime; | 
					
						
							|  |  |  |         int m_agcThreshold; | 
					
						
							|  |  |  |         int m_agcThresholdGate; | 
					
						
							|  |  |  |         int m_agcThresholdDelay; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         MsgConfigureSSBMod(Real bandwidth, | 
					
						
							|  |  |  |         		Real lowCutoff, | 
					
						
							|  |  |  |         		float toneFrequency, | 
					
						
							|  |  |  | 				float volumeFactor, | 
					
						
							|  |  |  | 				int spanLog2, | 
					
						
							|  |  |  | 				bool audioBinaural, | 
					
						
							|  |  |  | 				bool audioFlipChannels, | 
					
						
							|  |  |  | 				bool dsb, | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  | 				bool audioMute, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 				bool playLoop, | 
					
						
							|  |  |  | 				bool agc, | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  | 				float agcOrder, | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 				int agcTime, | 
					
						
							|  |  |  | 				int agcThreshold, | 
					
						
							|  |  |  | 				int agcThresholdGate, | 
					
						
							|  |  |  | 				int agcThresholdDelay) : | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |             Message(), | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |             m_bandwidth(bandwidth), | 
					
						
							|  |  |  | 			m_lowCutoff(lowCutoff), | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |             m_toneFrequency(toneFrequency), | 
					
						
							|  |  |  |             m_volumeFactor(volumeFactor), | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | 			m_spanLog2(spanLog2), | 
					
						
							|  |  |  | 			m_audioBinaural(audioBinaural), | 
					
						
							|  |  |  | 			m_audioFlipChannels(audioFlipChannels), | 
					
						
							|  |  |  | 			m_dsb(dsb), | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  |             m_audioMute(audioMute), | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 			m_playLoop(playLoop), | 
					
						
							|  |  |  | 			m_agc(agc), | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  | 			m_agcOrder(agcOrder), | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 			m_agcTime(agcTime), | 
					
						
							|  |  |  | 			m_agcThreshold(agcThreshold), | 
					
						
							|  |  |  | 			m_agcThresholdGate(agcThresholdGate), | 
					
						
							|  |  |  | 			m_agcThresholdDelay(agcThresholdDelay) | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //=================================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     enum RateState { | 
					
						
							|  |  |  |         RSInitialFill, | 
					
						
							|  |  |  |         RSRunning | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct Config { | 
					
						
							| 
									
										
										
										
											2017-08-06 17:10:29 +02:00
										 |  |  |         int m_basebandSampleRate; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         int m_outputSampleRate; | 
					
						
							|  |  |  |         qint64 m_inputFrequencyOffset; | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |         Real m_bandwidth; | 
					
						
							|  |  |  |         Real m_lowCutoff; | 
					
						
							|  |  |  |         bool m_usb; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         float m_toneFrequency; | 
					
						
							|  |  |  |         float m_volumeFactor; | 
					
						
							|  |  |  |         quint32 m_audioSampleRate; | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | 		int  m_spanLog2; | 
					
						
							|  |  |  | 		bool m_audioBinaural; | 
					
						
							|  |  |  | 		bool m_audioFlipChannels; | 
					
						
							|  |  |  | 		bool m_dsb; | 
					
						
							|  |  |  | 		bool m_audioMute; | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  |         bool m_playLoop; | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         bool m_agc; | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  |         float m_agcOrder; | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |         int m_agcTime; | 
					
						
							|  |  |  |         bool m_agcThresholdEnable; | 
					
						
							|  |  |  |         double m_agcThreshold; | 
					
						
							|  |  |  |         int m_agcThresholdGate; | 
					
						
							|  |  |  |         int m_agcThresholdDelay; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         Config() : | 
					
						
							| 
									
										
										
										
											2017-08-06 17:10:29 +02:00
										 |  |  |             m_basebandSampleRate(0), | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |             m_outputSampleRate(0), | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |             m_inputFrequencyOffset(0), | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  |             m_bandwidth(3000.0f), | 
					
						
							|  |  |  | 			m_lowCutoff(300.0f), | 
					
						
							|  |  |  | 			m_usb(true), | 
					
						
							|  |  |  |             m_toneFrequency(1000.0f), | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |             m_volumeFactor(1.0f), | 
					
						
							|  |  |  |             m_audioSampleRate(0), | 
					
						
							| 
									
										
										
										
											2016-12-12 22:02:24 +01:00
										 |  |  | 			m_spanLog2(3), | 
					
						
							|  |  |  | 			m_audioBinaural(false), | 
					
						
							|  |  |  | 			m_audioFlipChannels(false), | 
					
						
							|  |  |  | 			m_dsb(false), | 
					
						
							| 
									
										
										
										
											2016-12-14 02:57:47 +01:00
										 |  |  |             m_audioMute(false), | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 			m_playLoop(false), | 
					
						
							|  |  |  | 			m_agc(false), | 
					
						
							| 
									
										
										
										
											2017-08-05 23:11:05 +02:00
										 |  |  | 			m_agcOrder(0.2), | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  | 			m_agcTime(9600), | 
					
						
							|  |  |  | 			m_agcThresholdEnable(true), | 
					
						
							|  |  |  | 			m_agcThreshold(1e-4), | 
					
						
							|  |  |  | 			m_agcThresholdGate(192), | 
					
						
							|  |  |  | 			m_agcThresholdDelay(2400) | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |         { } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //=================================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Config m_config; | 
					
						
							|  |  |  |     Config m_running; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-19 08:28:50 +01:00
										 |  |  |     NCOF m_carrierNco; | 
					
						
							|  |  |  |     NCOF m_toneNco; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |     Complex m_modSample; | 
					
						
							|  |  |  |     Interpolator m_interpolator; | 
					
						
							|  |  |  |     Real m_interpolatorDistance; | 
					
						
							|  |  |  |     Real m_interpolatorDistanceRemain; | 
					
						
							|  |  |  |     bool m_interpolatorConsumed; | 
					
						
							| 
									
										
										
										
											2016-12-13 00:43:59 +01:00
										 |  |  | 	fftfilt* m_SSBFilter; | 
					
						
							|  |  |  | 	fftfilt* m_DSBFilter; | 
					
						
							| 
									
										
										
										
											2016-12-13 19:57:07 +01:00
										 |  |  | 	Complex* m_SSBFilterBuffer; | 
					
						
							|  |  |  | 	Complex* m_DSBFilterBuffer; | 
					
						
							|  |  |  | 	int m_SSBFilterBufferIndex; | 
					
						
							|  |  |  | 	int m_DSBFilterBufferIndex; | 
					
						
							| 
									
										
										
										
											2016-12-13 00:43:59 +01:00
										 |  |  | 	static const int m_ssbFftLen; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 00:14:52 +01:00
										 |  |  | 	BasebandSampleSink* m_sampleSink; | 
					
						
							|  |  |  | 	SampleVector m_sampleBuffer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //    Real m_magsqSpectrum;
 | 
					
						
							|  |  |  | //    Real m_magsqSum;
 | 
					
						
							|  |  |  | //    Real m_magsqPeak;
 | 
					
						
							|  |  |  | //    int  m_magsqCount;
 | 
					
						
							|  |  |  |     fftfilt::cmplx m_sum; | 
					
						
							|  |  |  |     int m_undersampleCount; | 
					
						
							|  |  |  |     int m_sumCount; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 23:39:49 +02:00
										 |  |  |     double m_magsq; | 
					
						
							| 
									
										
										
										
											2017-05-12 00:03:56 +02:00
										 |  |  |     MovingAverage<double> m_movingAverage; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-26 01:39:34 +01:00
										 |  |  |     AudioVector m_audioBuffer; | 
					
						
							|  |  |  |     uint m_audioBufferFill; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     AudioFifo m_audioFifo; | 
					
						
							|  |  |  |     QMutex m_settingsMutex; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::ifstream m_ifstream; | 
					
						
							|  |  |  |     QString m_fileName; | 
					
						
							|  |  |  |     quint64 m_fileSize;     //!< raw file size (bytes)
 | 
					
						
							|  |  |  |     quint32 m_recordLength; //!< record length in seconds computed from file size
 | 
					
						
							|  |  |  |     int m_sampleRate; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     SSBModInputAF m_afInput; | 
					
						
							|  |  |  |     quint32 m_levelCalcCount; | 
					
						
							|  |  |  |     Real m_peakLevel; | 
					
						
							|  |  |  |     Real m_levelSum; | 
					
						
							|  |  |  |     CWKeyer m_cwKeyer; | 
					
						
							| 
									
										
										
										
											2016-12-14 22:48:39 +01:00
										 |  |  |     CWSmoother m_cwSmoother; | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-05 19:08:33 +02:00
										 |  |  |     MagAGC m_inAGC; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |     static const int m_levelNbSamples; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void apply(); | 
					
						
							| 
									
										
										
										
											2016-12-13 00:43:59 +01:00
										 |  |  |     void pullAF(Complex& sample); | 
					
						
							|  |  |  |     void calculateLevel(Complex& sample); | 
					
						
							| 
									
										
										
										
											2016-12-12 00:48:27 +01:00
										 |  |  |     void modulateSample(); | 
					
						
							|  |  |  |     void openFileStream(); | 
					
						
							|  |  |  |     void seekFileStream(int seekPercentage); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* PLUGINS_CHANNELTX_MODSSB_SSBMOD_H_ */
 |