| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | #include "dsp/scopevis.h"
 | 
					
						
							|  |  |  | #include "gui/glscope.h"
 | 
					
						
							|  |  |  | #include "dsp/dspcommands.h"
 | 
					
						
							|  |  |  | #include "util/messagequeue.h"
 | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  | #include <algorithm>
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-09 10:33:04 +02:00
										 |  |  | #include <QDebug>
 | 
					
						
							| 
									
										
										
										
											2015-07-06 09:17:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 15:10:22 +01:00
										 |  |  | #ifndef LINUX
 | 
					
						
							|  |  |  | inline double log2f(double n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return log(n) / log(2.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | MESSAGE_CLASS_DEFINITION(ScopeVis::MsgConfigureScopeVis, Message) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-21 21:38:36 +02:00
										 |  |  | const uint ScopeVis::m_traceChunkSize = 4800; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | ScopeVis::ScopeVis(GLScope* glScope) : | 
					
						
							|  |  |  | 	m_glScope(glScope), | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |     m_tracebackCount(0), | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 	m_fill(0), | 
					
						
							|  |  |  | 	m_triggerState(Untriggered), | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 	m_triggerIndex(0), | 
					
						
							|  |  |  | 	m_prevTrigger(false), | 
					
						
							| 
									
										
										
										
											2015-07-21 22:18:17 +02:00
										 |  |  | 	m_triggerPre(0), | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 	m_triggerOneShot(false), | 
					
						
							| 
									
										
										
										
											2015-07-14 00:04:34 +02:00
										 |  |  | 	m_armed(false), | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  |     m_triggerDelayCount(0), | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 	m_triggerCount(0), | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	m_sampleRate(0), | 
					
						
							|  |  |  | 	m_prevArg(0.0), | 
					
						
							|  |  |  | 	m_firstArg(true) | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-12 09:03:02 +02:00
										 |  |  | 	setObjectName("ScopeVis"); | 
					
						
							| 
									
										
										
										
											2015-07-21 21:38:36 +02:00
										 |  |  | 	m_trace.reserve(100*m_traceChunkSize); | 
					
						
							|  |  |  | 	m_trace.resize(20*m_traceChunkSize); | 
					
						
							|  |  |  | 	m_traceback.resize(20*m_traceChunkSize); | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  | 	for (unsigned int i = 0; i < m_nbTriggers; i++) | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		m_triggerChannel[i] = TriggerFreeRun; | 
					
						
							|  |  |  | 		m_triggerLevel[i] = 0.0; | 
					
						
							|  |  |  | 		m_triggerPositiveEdge[i] = true; | 
					
						
							|  |  |  | 		m_triggerBothEdges[i] = false; | 
					
						
							|  |  |  | 		m_triggerDelay[i] = 0; | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 		m_triggerCounts[i] = 0; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | ScopeVis::~ScopeVis() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | void ScopeVis::configure(MessageQueue* msgQueue, | 
					
						
							|  |  |  | 	uint triggerIndex, | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  |     TriggerChannel triggerChannel, | 
					
						
							|  |  |  |     Real triggerLevel, | 
					
						
							|  |  |  |     bool triggerPositiveEdge, | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |     bool triggerBothEdges, | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |     uint triggerPre, | 
					
						
							|  |  |  |     uint triggerDelay, | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 	uint triggerCounts, | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |     uint traceSize) | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 	Message* cmd = MsgConfigureScopeVis::create(triggerIndex, | 
					
						
							|  |  |  | 			triggerChannel, | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  | 			triggerLevel, | 
					
						
							|  |  |  | 			triggerPositiveEdge, | 
					
						
							|  |  |  | 			triggerBothEdges, | 
					
						
							|  |  |  | 			triggerPre, | 
					
						
							|  |  |  | 			triggerDelay, | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 			triggerCounts, | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  | 			traceSize); | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | 	msgQueue->push(cmd); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  | void ScopeVis::feed(const SampleVector::const_iterator& cbegin, const SampleVector::const_iterator& end, bool positiveOnly __attribute__((unused))) | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-25 08:24:23 +02:00
										 |  |  | 	SampleVector::const_iterator begin(cbegin); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 	if (m_triggerChannel[m_triggerIndex] == TriggerFreeRun) { | 
					
						
							| 
									
										
										
										
											2015-07-15 01:19:39 +02:00
										 |  |  | 		m_triggerPoint = begin; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (m_triggerState == Triggered) { | 
					
						
							|  |  |  | 		m_triggerPoint = begin; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (m_triggerState == Untriggered) { | 
					
						
							|  |  |  | 		m_triggerPoint = end; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (m_triggerState == WaitForReset) { | 
					
						
							|  |  |  | 		m_triggerPoint = end; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		m_triggerPoint = begin; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 	while(begin < end) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		if (m_triggerChannel[m_triggerIndex] == TriggerFreeRun) | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			int count = end - begin; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 			if(count > (int)(m_trace.size() - m_fill)) | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 				count = m_trace.size() - m_fill; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 			std::vector<Complex>::iterator it = m_trace.begin() + m_fill; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			for(int i = 0; i < count; ++i) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2015-10-09 03:59:28 +02:00
										 |  |  | 				*it++ = Complex(begin->real() / 32768.0f, begin->imag() / 32768.0f); | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 				++begin; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 			m_fill += count; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if(m_fill >= m_trace.size()) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 				m_glScope->newTrace(m_trace, m_sampleRate); | 
					
						
							|  |  |  | 				m_fill = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 			if(m_triggerState == WaitForReset) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2015-07-14 02:56:54 +02:00
										 |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  | 			if(m_triggerState == Config) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  |                 m_glScope->newTrace(m_trace, m_sampleRate); // send a dummy trace
 | 
					
						
							|  |  |  | 				m_triggerState = Untriggered; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | 				m_triggerIndex = 0; | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  | 			} | 
					
						
							|  |  |  |             if(m_triggerState == Delay) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 int count = end - begin; | 
					
						
							|  |  |  | 				if (count > (int)(m_trace.size() - m_fill)) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  | 					count = m_trace.size() - m_fill; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 begin += count; | 
					
						
							|  |  |  |                 m_fill += count; | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  | 				if(m_fill >= m_trace.size()) | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |                 { | 
					
						
							|  |  |  |                     m_fill = 0; | 
					
						
							|  |  |  |                     m_triggerDelayCount--; | 
					
						
							|  |  |  |                     if (m_triggerDelayCount == 0) | 
					
						
							|  |  |  |                     { | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  |                     	if (nextTrigger()) | 
					
						
							|  |  |  |                     	{ | 
					
						
							|  |  |  |                     		m_triggerState = Untriggered; | 
					
						
							|  |  |  |                     	} | 
					
						
							|  |  |  |                     	else | 
					
						
							|  |  |  |                     	{ | 
					
						
							|  |  |  |                     		m_triggerState = Triggered; | 
					
						
							|  |  |  |                     	} | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-14 00:04:34 +02:00
										 |  |  | 			if(m_triggerState == Untriggered) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2015-11-10 03:03:56 +01:00
										 |  |  | 				m_firstArg = true; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-14 00:04:34 +02:00
										 |  |  | 				while(begin < end) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |                     bool triggerCdt = triggerCondition(begin); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-22 01:45:57 +02:00
										 |  |  |                     if (m_tracebackCount > m_triggerPre) | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |                     { | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |                         bool trigger; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  |                         if (m_triggerBothEdges[m_triggerIndex]) { | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |                         	trigger = m_prevTrigger ^ triggerCdt; | 
					
						
							|  |  |  |                         } else { | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  |                         	trigger = triggerCdt ^ !m_triggerPositiveEdge[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |                         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         if (trigger) | 
					
						
							| 
									
										
										
										
											2015-07-22 01:45:57 +02:00
										 |  |  | 						{ | 
					
						
							|  |  |  | 							if (m_armed) | 
					
						
							|  |  |  | 							{ | 
					
						
							|  |  |  | 								m_armed = false; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  |                                 if (m_triggerDelay[m_triggerIndex] > 0) | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |                                 { | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  |                                     m_triggerDelayCount = m_triggerDelay[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |                                     m_fill = 0; | 
					
						
							|  |  |  |                                     m_triggerState = Delay; | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                                 else | 
					
						
							|  |  |  |                                 { | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  |                                 	if (nextTrigger()) | 
					
						
							|  |  |  |                                 	{ | 
					
						
							|  |  |  |                                 		m_triggerState = Untriggered; | 
					
						
							|  |  |  |                                 	} | 
					
						
							|  |  |  |                                 	else | 
					
						
							|  |  |  |                                 	{ | 
					
						
							|  |  |  | 										m_triggerState = Triggered; | 
					
						
							|  |  |  | 										m_triggerPoint = begin; | 
					
						
							|  |  |  | 										// fill beginning of m_trace with delayed samples from the trace memory FIFO. Increment m_fill accordingly.
 | 
					
						
							|  |  |  | 										if (m_triggerPre) { // do this process only if there is a pre-trigger delay
 | 
					
						
							|  |  |  | 											std::copy(m_traceback.end() - m_triggerPre - 1, m_traceback.end() - 1, m_trace.begin()); | 
					
						
							|  |  |  | 											m_fill = m_triggerPre; // Increment m_fill accordingly (from 0).
 | 
					
						
							|  |  |  | 										} | 
					
						
							|  |  |  |                                 	} | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  |                                 } | 
					
						
							| 
									
										
										
										
											2015-07-22 01:45:57 +02:00
										 |  |  | 								break; | 
					
						
							|  |  |  | 							} | 
					
						
							| 
									
										
										
										
											2015-07-14 00:04:34 +02:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2015-07-22 01:45:57 +02:00
										 |  |  | 						else | 
					
						
							|  |  |  | 						{ | 
					
						
							|  |  |  | 							m_armed = true; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2015-07-23 06:52:12 +02:00
										 |  |  |                     m_prevTrigger = triggerCdt; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 					++begin; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-14 00:04:34 +02:00
										 |  |  | 			if(m_triggerState == Triggered) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 				int count = end - begin; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 				if(count > (int)(m_trace.size() - m_fill)) | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 					count = m_trace.size() - m_fill; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 				std::vector<Complex>::iterator it = m_trace.begin() + m_fill; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				for(int i = 0; i < count; ++i) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2015-10-09 08:45:29 +02:00
										 |  |  | 					*it++ = Complex(begin->real() / 32768.0f, begin->imag() / 32768.0f); | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 					++begin; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 				m_fill += count; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(m_fill >= m_trace.size()) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 					m_glScope->newTrace(m_trace, m_sampleRate); | 
					
						
							|  |  |  | 					m_fill = 0; | 
					
						
							| 
									
										
										
										
											2015-09-28 02:39:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 					if (m_triggerOneShot) { | 
					
						
							|  |  |  | 						m_triggerState = WaitForReset; | 
					
						
							|  |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |                         m_tracebackCount = 0; | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 						m_triggerState = Untriggered; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | 						m_triggerIndex = 0; | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ScopeVis::start() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ScopeVis::stop() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | bool ScopeVis::handleMessage(const Message& message) | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 	qDebug() << "ScopeVis::handleMessage"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (DSPSignalNotification::match(message)) | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 		DSPSignalNotification& notif = (DSPSignalNotification&) message; | 
					
						
							|  |  |  | 		m_sampleRate = notif.getSampleRate(); | 
					
						
							|  |  |  | 		qDebug() << "  - DSPSignalNotification: m_sampleRate: " << m_sampleRate; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (MsgConfigureScopeVis::match(message)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		MsgConfigureScopeVis& conf = (MsgConfigureScopeVis&) message; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		m_tracebackCount = 0; | 
					
						
							| 
									
										
										
										
											2015-07-23 04:58:27 +02:00
										 |  |  | 		m_triggerState = Config; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		uint index = conf.getTriggerIndex(); | 
					
						
							|  |  |  | 		m_triggerChannel[index] = (TriggerChannel) conf.getTriggerChannel(); | 
					
						
							|  |  |  | 		m_triggerLevel[index] = conf.getTriggerLevel(); | 
					
						
							|  |  |  | 		m_triggerPositiveEdge[index] = conf.getTriggerPositiveEdge(); | 
					
						
							|  |  |  | 		m_triggerBothEdges[index] = conf.getTriggerBothEdges(); | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 		m_triggerPre = conf.getTriggerPre(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 		if (m_triggerChannel[index] == TriggerDPhase) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_firstArg = true; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  |         if (m_triggerPre >= m_traceback.size()) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2015-07-21 22:18:17 +02:00
										 |  |  |         	m_triggerPre = m_traceback.size() - 1; // top sample in FIFO is always the triggering one (pre-trigger delay = 0)
 | 
					
						
							| 
									
										
										
										
											2015-07-21 21:38:36 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  |         m_triggerDelay[index] = conf.getTriggerDelay(); | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  |         m_triggerCounts[index] = conf.getTriggerCounts(); | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  |         uint newSize = conf.getTraceSize(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (newSize != m_trace.size()) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2015-07-21 21:38:36 +02:00
										 |  |  |             m_trace.resize(newSize); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (newSize > m_traceback.size()) // fitting the exact required space is not a requirement for the back trace
 | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2015-07-21 21:38:36 +02:00
										 |  |  |             m_traceback.resize(newSize); | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		qDebug() << "  - MsgConfigureScopeVis:" | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 				<< " triggerIndex: " << index | 
					
						
							|  |  |  | 				<< " m_triggerChannel: " << m_triggerChannel[index] | 
					
						
							|  |  |  | 				<< " m_triggerLevel: " << m_triggerLevel[index] | 
					
						
							|  |  |  | 				<< " m_triggerPositiveEdge: " << (m_triggerPositiveEdge[index] ? "edge+" : "edge-") | 
					
						
							|  |  |  | 				<< " m_triggerBothEdges: " << (m_triggerBothEdges[index] ? "yes" : "no") | 
					
						
							| 
									
										
										
										
											2015-07-21 22:18:17 +02:00
										 |  |  | 				<< " m_preTrigger: " << m_triggerPre | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 				<< " m_triggerDelay: " << m_triggerDelay[index] | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 				<< " m_triggerCounts: " << m_triggerCounts[index] | 
					
						
							| 
									
										
										
										
											2015-08-09 10:33:04 +02:00
										 |  |  | 				<< " m_traceSize: " << m_trace.size(); | 
					
						
							| 
									
										
										
										
											2015-08-17 08:29:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-13 10:46:51 +02:00
										 |  |  | 		return true; | 
					
						
							| 
									
										
										
										
											2014-05-18 16:52:39 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2015-06-23 20:05:28 +02:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-08-14 05:00:28 +02:00
										 |  |  | 		return false; | 
					
						
							| 
									
										
										
										
											2015-06-23 20:05:28 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-07 01:17:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | void ScopeVis::setSampleRate(int sampleRate) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_sampleRate = sampleRate; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | bool ScopeVis::triggerCondition(SampleVector::const_iterator& it) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-10-09 08:45:29 +02:00
										 |  |  | 	Complex c(it->real()/32768.0f, it->imag()/32768.0f); | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |     m_traceback.push_back(c); // store into trace memory FIFO
 | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  |     if (m_tracebackCount < m_traceback.size()) | 
					
						
							|  |  |  |     { // increment count up to trace memory size
 | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |         m_tracebackCount++; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-05-25 20:13:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	if (m_triggerChannel[m_triggerIndex] == TriggerChannelI) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		return c.real() > m_triggerLevel[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	else if (m_triggerChannel[m_triggerIndex] == TriggerChannelQ) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		return c.imag() > m_triggerLevel[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	else if (m_triggerChannel[m_triggerIndex] == TriggerMagLin) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		return abs(c) > m_triggerLevel[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	else if (m_triggerChannel[m_triggerIndex] == TriggerMagDb) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 		Real mult = (10.0f / log2f(10.0f)); | 
					
						
							|  |  |  | 		Real v = c.real() * c.real() + c.imag() * c.imag(); | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		return mult * log2f(v) > m_triggerLevel[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	else if (m_triggerChannel[m_triggerIndex] == TriggerPhase) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-04 03:10:05 +01:00
										 |  |  | 		return arg(c) / M_PI > m_triggerLevel[m_triggerIndex]; | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-11-04 04:29:26 +01:00
										 |  |  | 	else if (m_triggerChannel[m_triggerIndex] == TriggerDPhase) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		Real curArg = arg(c) - m_prevArg; | 
					
						
							|  |  |  | 		m_prevArg = arg(c); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (curArg < -M_PI) { | 
					
						
							|  |  |  | 			curArg += 2.0 * M_PI; | 
					
						
							|  |  |  | 		} else if (curArg > M_PI) { | 
					
						
							|  |  |  | 			curArg -= 2.0 * M_PI; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (m_firstArg) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_firstArg = false; | 
					
						
							|  |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			return curArg / M_PI > m_triggerLevel[m_triggerIndex]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-07-13 23:38:10 +02:00
										 |  |  | 		return false; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | void ScopeVis::setOneShot(bool oneShot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_triggerOneShot = oneShot; | 
					
						
							| 
									
										
										
										
											2015-07-14 02:56:54 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if ((m_triggerState == WaitForReset) && !oneShot) { | 
					
						
							| 
									
										
										
										
											2015-07-20 22:51:49 +02:00
										 |  |  |         m_tracebackCount = 0; | 
					
						
							| 
									
										
										
										
											2015-07-14 02:56:54 +02:00
										 |  |  | 		m_triggerState = Untriggered; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | 		m_triggerIndex = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-01 04:42:47 +02:00
										 |  |  | void ScopeVis::blockTrigger(bool blocked) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (blocked) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_triggerState = WaitForReset; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (!m_triggerOneShot) { | 
					
						
							|  |  |  | 	        m_tracebackCount = 0; | 
					
						
							|  |  |  | 			m_triggerState = Untriggered; | 
					
						
							|  |  |  | 			m_triggerIndex = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | bool ScopeVis::nextTrigger() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 	if (m_triggerCount < m_triggerCounts[m_triggerIndex]) | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 		m_triggerCount++; | 
					
						
							|  |  |  | 		return true; | 
					
						
							| 
									
										
										
										
											2015-11-04 03:25:41 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-11-05 00:07:51 +01:00
										 |  |  | 		m_triggerIndex++; | 
					
						
							|  |  |  | 		m_prevTrigger = false; | 
					
						
							|  |  |  | 		m_triggerDelayCount = 0; | 
					
						
							|  |  |  | 		m_triggerCount = 0; | 
					
						
							|  |  |  | 		m_armed = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (m_triggerIndex == m_nbTriggers) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_triggerIndex = 0; | 
					
						
							|  |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (m_triggerChannel[m_triggerIndex] == TriggerFreeRun) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_triggerIndex = 0; | 
					
						
							|  |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			return true; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-07-14 02:56:54 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-07-14 02:18:55 +02:00
										 |  |  | } |