| 
									
										
										
										
											2016-10-02 23:21:53 +02:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2017-09-16 23:44:00 +02:00
										 |  |  | // Copyright (C) 2015-2017 F4EXB                                                 //
 | 
					
						
							|  |  |  | // written by Edouard Griffiths                                                  //
 | 
					
						
							| 
									
										
										
										
											2016-10-02 23:21:53 +02:00
										 |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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                  //
 | 
					
						
							| 
									
										
										
										
											2019-04-11 14:32:15 +02:00
										 |  |  | // (at your option) any later version.                                           //
 | 
					
						
							| 
									
										
										
										
											2016-10-02 23:21:53 +02:00
										 |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-10 11:47:13 +02:00
										 |  |  | #include <QDebug>
 | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "dsp/devicesamplestatic.h"
 | 
					
						
							|  |  |  | #include "dsp/devicesamplesource.h"
 | 
					
						
							| 
									
										
										
										
											2016-10-02 23:21:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-16 23:44:00 +02:00
										 |  |  | DeviceSampleSource::DeviceSampleSource() : | 
					
						
							|  |  |  |     m_guiMessageQueue(0) | 
					
						
							| 
									
										
										
										
											2016-10-02 23:21:53 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	connect(&m_inputMessageQueue, SIGNAL(messageEnqueued()), this, SLOT(handleInputMessages())); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DeviceSampleSource::~DeviceSampleSource() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void DeviceSampleSource::handleInputMessages() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Message* message; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while ((message = m_inputMessageQueue.pop()) != 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (handleMessage(*message)) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			delete message; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-05-10 11:47:13 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | qint64 DeviceSampleSource::calculateDeviceCenterFrequency( | 
					
						
							|  |  |  |             quint64 centerFrequency, | 
					
						
							|  |  |  |             qint64 transverterDeltaFrequency, | 
					
						
							|  |  |  |             int log2Decim, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							|  |  |  |             quint32 devSampleRate, | 
					
						
							| 
									
										
										
										
											2019-04-02 01:10:03 +02:00
										 |  |  |             FrequencyShiftScheme frequencyShiftScheme, | 
					
						
							| 
									
										
										
										
											2018-05-10 11:47:13 +02:00
										 |  |  |             bool transverterMode) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSourceDeviceCenterFrequency( | 
					
						
							|  |  |  |         centerFrequency, | 
					
						
							|  |  |  |         transverterDeltaFrequency, | 
					
						
							|  |  |  |         log2Decim, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate, | 
					
						
							|  |  |  |         (DeviceSampleStatic::FrequencyShiftScheme) frequencyShiftScheme, | 
					
						
							|  |  |  |         transverterMode | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2018-05-10 11:47:13 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-05-10 22:17:39 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-30 20:44:55 +01:00
										 |  |  | qint64 DeviceSampleSource::calculateCenterFrequency( | 
					
						
							|  |  |  |             quint64 deviceCenterFrequency, | 
					
						
							|  |  |  |             qint64 transverterDeltaFrequency, | 
					
						
							|  |  |  |             int log2Decim, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							|  |  |  |             quint32 devSampleRate, | 
					
						
							| 
									
										
										
										
											2019-04-02 01:10:03 +02:00
										 |  |  |             FrequencyShiftScheme frequencyShiftScheme, | 
					
						
							| 
									
										
										
										
											2019-03-30 20:44:55 +01:00
										 |  |  |             bool transverterMode) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSourceCenterFrequency( | 
					
						
							|  |  |  |         deviceCenterFrequency, | 
					
						
							|  |  |  |         transverterDeltaFrequency, | 
					
						
							|  |  |  |         log2Decim, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate, | 
					
						
							|  |  |  |         (DeviceSampleStatic::FrequencyShiftScheme) frequencyShiftScheme, | 
					
						
							|  |  |  |         transverterMode | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2019-03-30 20:44:55 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-10 22:17:39 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * log2Decim = 0:  no shift | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * n = log2Decim <= 2: fc = +/- 1/2^(n-1) | 
					
						
							|  |  |  |  *      center | 
					
						
							|  |  |  |  *  |     ^     | | 
					
						
							|  |  |  |  *  | inf | sup | | 
					
						
							|  |  |  |  *     ^     ^ | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * n = log2Decim > 2: fc = +/- 1/2^n | 
					
						
							|  |  |  |  *         center | 
					
						
							|  |  |  |  *  |         ^         | | 
					
						
							|  |  |  |  *  |  |inf|  |  |sup|  | | 
					
						
							|  |  |  |  *       ^         ^ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | qint32 DeviceSampleSource::calculateFrequencyShift( | 
					
						
							|  |  |  |             int log2Decim, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							| 
									
										
										
										
											2019-04-02 01:10:03 +02:00
										 |  |  |             quint32 devSampleRate, | 
					
						
							|  |  |  |             FrequencyShiftScheme frequencyShiftScheme) | 
					
						
							| 
									
										
										
										
											2018-05-10 22:17:39 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSourceFrequencyShift( | 
					
						
							|  |  |  |         log2Decim, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate, | 
					
						
							|  |  |  |         (DeviceSampleStatic::FrequencyShiftScheme) frequencyShiftScheme | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2018-05-10 22:17:39 +02:00
										 |  |  | } |