1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2024-11-08 17:46:03 -05:00
sdrangel/sdrgui/dsp/scopevis.h

171 lines
6.1 KiB
C
Raw Normal View History

#ifndef INCLUDE_SCOPEVIS_H
#define INCLUDE_SCOPEVIS_H
2015-07-20 16:51:49 -04:00
#include <boost/circular_buffer.hpp>
#include <dsp/basebandsamplesink.h>
#include "util/export.h"
2015-07-13 04:46:51 -04:00
#include "util/message.h"
class GLScope;
class MessageQueue;
class SDRANGEL_API ScopeVis : public BasebandSampleSink {
public:
enum TriggerChannel {
TriggerFreeRun,
TriggerChannelI,
2015-07-13 04:46:51 -04:00
TriggerChannelQ,
TriggerMagLin,
TriggerMagDb,
TriggerPhase,
TriggerDPhase
};
2015-07-21 15:38:36 -04:00
static const uint m_traceChunkSize;
static const uint m_nbTriggers = 10;
2015-07-21 15:38:36 -04:00
ScopeVis(GLScope* glScope = NULL);
2015-08-13 23:00:28 -04:00
virtual ~ScopeVis();
void configure(MessageQueue* msgQueue,
uint triggerIndex,
2015-07-22 22:58:27 -04:00
TriggerChannel triggerChannel,
Real triggerLevel,
bool triggerPositiveEdge,
2015-07-23 00:52:12 -04:00
bool triggerBothEdges,
2015-07-22 22:58:27 -04:00
uint triggerPre,
2015-11-04 18:07:51 -05:00
uint triggerDelay,
uint triggerCounts,
2015-07-22 22:58:27 -04:00
uint traceSize);
2015-07-13 20:18:55 -04:00
void setOneShot(bool oneShot);
void blockTrigger(bool blecked);
virtual void feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool positiveOnly);
2015-08-13 23:00:28 -04:00
virtual void start();
virtual void stop();
virtual bool handleMessage(const Message& message);
2015-07-06 19:17:16 -04:00
void setSampleRate(int sampleRate);
int getSampleRate() const { return m_sampleRate; }
SampleVector::const_iterator getTriggerPoint() const { return m_triggerPoint; }
2015-07-06 19:17:16 -04:00
private:
2015-07-13 04:46:51 -04:00
class MsgConfigureScopeVis : public Message {
MESSAGE_CLASS_DECLARATION
public:
uint getTriggerIndex() const { return m_triggerIndex; }
2015-07-13 04:46:51 -04:00
int getTriggerChannel() const { return m_triggerChannel; }
Real getTriggerLevel() const { return m_triggerLevel; }
Real getTriggerPositiveEdge() const { return m_triggerPositiveEdge; }
2015-07-23 00:52:12 -04:00
Real getTriggerBothEdges() const { return m_triggerBothEdges; }
uint getTriggerPre() const { return m_triggerPre; }
2015-07-22 22:58:27 -04:00
uint getTriggerDelay() const { return m_triggerDelay; }
2015-11-04 18:07:51 -05:00
uint getTriggerCounts() const { return m_triggerCounts; }
2015-07-21 15:38:36 -04:00
uint getTraceSize() const { return m_traceSize; }
2015-07-13 04:46:51 -04:00
static MsgConfigureScopeVis* create(uint triggerIndex,
int triggerChannel,
2015-07-22 22:58:27 -04:00
Real triggerLevel,
bool triggerPositiveEdge,
2015-07-23 00:52:12 -04:00
bool triggerBothEdges,
2015-07-22 22:58:27 -04:00
uint triggerPre,
2015-11-04 18:07:51 -05:00
uint triggerDelay,
uint triggerCounts,
2015-07-22 22:58:27 -04:00
uint traceSize)
2015-07-13 04:46:51 -04:00
{
return new MsgConfigureScopeVis(triggerIndex,
triggerChannel,
2015-07-23 00:52:12 -04:00
triggerLevel,
triggerPositiveEdge,
triggerBothEdges,
triggerPre,
triggerDelay,
2015-11-04 18:07:51 -05:00
triggerCounts,
2015-07-23 00:52:12 -04:00
traceSize);
2015-07-13 04:46:51 -04:00
}
private:
uint m_triggerIndex;
2015-07-13 04:46:51 -04:00
int m_triggerChannel;
Real m_triggerLevel;
bool m_triggerPositiveEdge;
2015-07-23 00:52:12 -04:00
bool m_triggerBothEdges;
uint m_triggerPre;
2015-07-22 22:58:27 -04:00
uint m_triggerDelay;
2015-11-04 18:07:51 -05:00
uint m_triggerCounts;
2015-07-21 15:38:36 -04:00
uint m_traceSize;
2015-07-13 04:46:51 -04:00
MsgConfigureScopeVis(uint triggerIndex,
int triggerChannel,
2015-07-22 22:58:27 -04:00
Real triggerLevel,
bool triggerPositiveEdge,
2015-07-23 00:52:12 -04:00
bool triggerBothEdges,
2015-07-22 22:58:27 -04:00
uint triggerPre,
uint triggerDelay,
2015-11-04 18:07:51 -05:00
uint triggerCounts,
2015-07-22 22:58:27 -04:00
uint traceSize) :
2015-07-13 04:46:51 -04:00
Message(),
m_triggerIndex(triggerIndex),
2015-07-13 04:46:51 -04:00
m_triggerChannel(triggerChannel),
m_triggerLevel(triggerLevel),
2015-07-20 16:51:49 -04:00
m_triggerPositiveEdge(triggerPositiveEdge),
2015-07-23 00:52:12 -04:00
m_triggerBothEdges(triggerBothEdges),
m_triggerPre(triggerPre),
2015-07-22 22:58:27 -04:00
m_triggerDelay(triggerDelay),
2015-11-04 18:07:51 -05:00
m_triggerCounts(triggerCounts),
2015-07-21 15:38:36 -04:00
m_traceSize(traceSize)
2015-07-13 04:46:51 -04:00
{ }
};
2015-07-22 22:58:27 -04:00
/**
* TriggerState: (repeat at each successive non freerun trigger)
2015-07-22 22:58:27 -04:00
*
* send a Trigger condition +--------------------+
* dummy trace - Immediate m_triggerOneShot | |
* Config -------------> Untriggered ----------------------------------> Triggered ----------------> WaitForReset |
* ^ ^ | ^ | | ^ |
* | | | - Delayed Delay expired | | | | setOneShot(true)|
* | | +---------------------> Delay ----------------+ | | +-----------------+
* | | !m_triggerOneShot | |
* | +--------------------------------------------------+ setOneShot(false) |
* +-------------------------------------------------------------------------------+
*/
enum TriggerState {
2015-07-22 22:58:27 -04:00
Untriggered, //!< Search for trigger
Config, //!< New configuration has just been received
Triggered, //!< Trigger was kicked off
WaitForReset, //!< Wait for release from GUI
Delay //!< Trigger delay engaged
};
GLScope* m_glScope;
2015-07-20 16:51:49 -04:00
std::vector<Complex> m_trace; //!< Raw trace to be used by GLScope
2015-07-21 15:38:36 -04:00
boost::circular_buffer<Complex> m_traceback; //!< FIFO for samples prior to triggering point to support pre-trigger (when in triggered mode)
uint m_tracebackCount; //!< Count of samples stored into trace memory since triggering is active up to trace memory size
uint m_fill;
TriggerState m_triggerState;
uint m_triggerIndex; //!< current active trigger index
TriggerChannel m_triggerChannel[m_nbTriggers];
Real m_triggerLevel[m_nbTriggers];
bool m_triggerPositiveEdge[m_nbTriggers];
bool m_triggerBothEdges[m_nbTriggers];
2015-07-23 00:52:12 -04:00
bool m_prevTrigger;
2015-07-22 22:58:27 -04:00
uint m_triggerPre; //!< Pre-trigger delay in number of samples
2015-07-13 20:18:55 -04:00
bool m_triggerOneShot;
2015-07-13 18:04:34 -04:00
bool m_armed;
uint m_triggerDelay[m_nbTriggers]; //!< Trigger delay in number of trace sizes
2015-07-22 22:58:27 -04:00
uint m_triggerDelayCount; //!< trace sizes delay counter
2015-11-04 18:07:51 -05:00
uint m_triggerCounts[m_nbTriggers]; //!< Number of trigger events before the actual trigger is kicked off
uint m_triggerCount;
int m_sampleRate;
SampleVector::const_iterator m_triggerPoint;
Real m_prevArg;
bool m_firstArg;
2015-07-13 17:38:10 -04:00
bool triggerCondition(SampleVector::const_iterator& it);
bool nextTrigger(); //!< move to next trigger. Returns true if next trigger is active.
};
#endif // INCLUDE_SCOPEVIS_H