| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | // Copyright (C) 2016-2019 F4EXB                                                 //
 | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | // written by Edouard Griffiths                                                  //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // 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.                                           //
 | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +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/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | #include <QDebug>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  | #include "dsp/devicesamplestatic.h"
 | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | #include "dsp/devicesamplesink.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DeviceSampleSink::DeviceSampleSink() : | 
					
						
							| 
									
										
										
										
											2017-12-20 01:01:53 +01:00
										 |  |  |     m_sampleSourceFifo(1<<19), | 
					
						
							|  |  |  |     m_guiMessageQueue(0) | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	connect(&m_inputMessageQueue, SIGNAL(messageEnqueued()), this, SLOT(handleInputMessages())); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DeviceSampleSink::~DeviceSampleSink() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void DeviceSampleSink::handleInputMessages() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Message* message; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while ((message = m_inputMessageQueue.pop()) != 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (handleMessage(*message)) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			delete message; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | qint64 DeviceSampleSink::calculateDeviceCenterFrequency( | 
					
						
							|  |  |  |             quint64 centerFrequency, | 
					
						
							|  |  |  |             qint64 transverterDeltaFrequency, | 
					
						
							|  |  |  |             int log2Interp, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							|  |  |  |             quint32 devSampleRate, | 
					
						
							|  |  |  |             bool transverterMode) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSinkDeviceCenterFrequency( | 
					
						
							|  |  |  |         centerFrequency, | 
					
						
							|  |  |  |         transverterDeltaFrequency, | 
					
						
							|  |  |  |         log2Interp, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate, | 
					
						
							|  |  |  |         transverterMode | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | qint64 DeviceSampleSink::calculateCenterFrequency( | 
					
						
							|  |  |  |             quint64 deviceCenterFrequency, | 
					
						
							|  |  |  |             qint64 transverterDeltaFrequency, | 
					
						
							|  |  |  |             int log2Interp, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							|  |  |  |             quint32 devSampleRate, | 
					
						
							|  |  |  |             bool transverterMode) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSinkCenterFrequency( | 
					
						
							|  |  |  |         deviceCenterFrequency, | 
					
						
							|  |  |  |         transverterDeltaFrequency, | 
					
						
							|  |  |  |         log2Interp, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate, | 
					
						
							|  |  |  |         transverterMode | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * log2Interp = 0:  no shift | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-04-01 14:40:01 +02:00
										 |  |  |  * log2Interp = 1:  middle of side band (inf or sup: 1/2) | 
					
						
							|  |  |  |  *        ^     |     ^ | 
					
						
							|  |  |  |  *  | inf | inf | sup | sup | | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * log2Interp = 2:  middle of far side half side band (inf, inf or sup, sup: 1/2 + 1/4) | 
					
						
							|  |  |  |  *     ^        |        ^ | 
					
						
							|  |  |  |  *  | inf | inf | sup | sup | | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * log2Interp = 3:  inf, inf, sup or sup, sup, inf: 1/2 + 1/4 - 1/8 = 5/8 | 
					
						
							|  |  |  |  * log2Interp = 4:  inf, inf, sup, inf or sup, sup, inf, sup: 1/2 + 1/4 - 1/8 + 1/16 = 11/16 | 
					
						
							|  |  |  |  * log2Interp = 5:  inf, inf, sup, inf, sup or sup, sup, inf, sup, inf: 1/2 + 1/4 - 1/8 + 1/16 - 1/32 = 21/32 | 
					
						
							|  |  |  |  * log2Interp = 6:  inf, sup, inf, sup, inf, sup or sup, inf, sup, inf, sup, inf: 1/2 - 1/4 + 1/8 -1/16 + 1/32 - 1/64 = 21/64 | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | qint32 DeviceSampleSink::calculateFrequencyShift( | 
					
						
							|  |  |  |             int log2Interp, | 
					
						
							|  |  |  |             fcPos_t fcPos, | 
					
						
							|  |  |  |             quint32 devSampleRate) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-18 00:15:04 +02:00
										 |  |  |     return DeviceSampleStatic::calculateSinkFrequencyShift( | 
					
						
							|  |  |  |         log2Interp, | 
					
						
							|  |  |  |         (DeviceSampleStatic::fcPos_t) fcPos, | 
					
						
							|  |  |  |         devSampleRate | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2019-03-31 00:40:42 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-09-28 14:07:41 +02:00
										 |  |  | 
 |