285 virtual void Degauss(
size_t i);
378 virtual void Invert(
size_t i,
bool invert);
479 if(old_trig != trigger)
496 if(sync || (m_trigger == NULL) )
593 virtual std::set< InterleaveConflict > GetInterleaveConflicts() =0;
697 typedef std::vector<OscilloscopeChannel*> AnalogBank;
734 virtual void SetADCMode(
size_t channel,
size_t mode);
739 typedef std::vector<OscilloscopeChannel*> DigitalBank;
795 virtual void SetSpan(int64_t span);
870 static void Convert8BitSamples(
float* pout,
const int8_t* pin,
float gain,
float offset,
size_t count);
873 static void Convert8BitSamplesAVX2(
float* pout,
const int8_t* pin,
float gain,
float offset,
size_t count);
879 static void ConvertUnsigned8BitSamplesAVX2(
float* pout,
const uint8_t* pin,
float gain,
float offset,
size_t count);
882 static void Convert16BitSamples(
float* pout,
const int16_t* pin,
float gain,
float offset,
size_t count);
885 static void Convert16BitSamplesAVX2(
float* pout,
const int16_t* pin,
float gain,
float offset,
size_t count);
886 static void Convert16BitSamplesFMA(
float* pout,
const int16_t* pin,
float gain,
float offset,
size_t count);
887 static void Convert16BitSamplesAVX512F(
float* pout,
const int16_t* pin,
float gain,
float offset,
size_t count);
894 bool HasPendingWaveforms();
896 size_t GetPendingWaveformCount();
901 typedef std::map<StreamDescriptor, WaveformBase*> SequenceSet;
902 std::list<SequenceSet> m_pendingWaveforms;
903 std::mutex m_pendingWaveformsMutex;
904 std::recursive_mutex m_mutex;
909 std::deque<std::string> m_diagnosticLogMessages;
910 std::map<std::string, FilterParameter*> m_diagnosticValues;
913 void AddDiagnosticLog(std::string message)
915 m_diagnosticLogMessages.push_back(message);
919 bool HasPendingDiagnosticLogMessages()
921 return !m_diagnosticLogMessages.empty();
924 std::string PopPendingDiagnosticLogMessage()
926 std::string message = m_diagnosticLogMessages.front();
927 m_diagnosticLogMessages.pop_front();
931 std::map<std::string, FilterParameter*>& GetDiagnosticsValues()
934 return m_diagnosticValues;
949 auto p = m_analogWaveformPool.
Get();
967 auto p = m_digitalWaveformPool.
Get();
991 {
return m_analogWaveformPool.
clear() || m_digitalWaveformPool.
clear(); }
994 { m_analogWaveformPool.
Add(w); }
997 { m_digitalWaveformPool.
Add(w); }
1000 typedef std::shared_ptr<Oscilloscope> (*CreateProcType)(
SCPITransport*);
1001 static void DoAddDriverClass(std::string name, CreateProcType proc);
1003 static void EnumDrivers(std::vector<std::string>& names);
1004 static std::shared_ptr<Oscilloscope> CreateOscilloscope(std::string driver,
SCPITransport* transport);
1008 typedef std::map< std::string, CreateProcType > CreateMapType;
1009 static CreateMapType m_createprocs;
1017#define STRINGIFY(T) #T
1020#define OSCILLOSCOPE_INITPROC(T) \
1021 static std::shared_ptr<Oscilloscope> CreateInstance(SCPITransport* transport) \
1022 { return std::make_shared<T>(transport); } \
1023 virtual std::string GetDriverName() const override \
1024 { return GetDriverNameInternal(); }
1026#define AddDriverClass(T) Oscilloscope::DoAddDriverClass(T::GetDriverNameInternal(), T::CreateInstance)
Declaration of SCPITransport.
All warnings generated by a configuration we're in the process of loading.
Definition: ConfigWarningList.h:90
Bidirectional table mapping integer IDs in scopesession files to object pointers.
Definition: IDTable.h:49
DownloadState
Enum values to be mapped to GetDownloadState() int result value for specific channel download states.
Definition: InstrumentChannel.h:246
Instrument * m_instrument
The instrument we're part of (may be null in the case of filters etc)
Definition: InstrumentChannel.h:274
An arbitrary lab instrument. Oscilloscope, LA, PSU, DMM, etc.
Definition: Instrument.h:58
InstrumentChannel * GetChannelByHwName(const std::string &name)
Gets a channel given the hardware name.
Definition: Instrument.cpp:64
InstrumentChannel * GetChannel(size_t i) const
Gets a given channel on the instrument.
Definition: Instrument.h:158
A single channel on an oscilloscope.
Definition: OscilloscopeChannel.h:49
Generic representation of an oscilloscope, logic analyzer, or spectrum analyzer.
Definition: Oscilloscope.h:50
virtual int64_t GetCenterFrequency(size_t channel)
Gets the center frequency for a frequency-domain channel.
Definition: Oscilloscope.cpp:926
virtual bool IsChannelEnabled(size_t i)=0
Checks if a channel is enabled in hardware.
virtual std::vector< uint64_t > GetSampleRatesInterleaved()=0
Get the legal sampling rates (in Hz) for this scope in combined-channels mode.
virtual bool IsInverted(size_t i)
Checks if hardware polarity inversion is enabled for a channel.
Definition: Oscilloscope.cpp:854
virtual bool HasInputMux(size_t i)
Checks if a channel has an input multiplexer.
Definition: Oscilloscope.cpp:779
void DoLoadConfiguration(int version, const YAML::Node &node, IDTable &idmap)
Load instrument and channel configuration from a save file.
Definition: Oscilloscope.cpp:386
virtual float GetChannelOffset(size_t i, size_t stream)=0
Gets the offset, in volts, for a given channel.
virtual bool HasFrequencyControls()
Returns true if the instrument has at least one frequency-domain channel.
Definition: Oscilloscope.cpp:940
virtual void SetChannelAttenuation(size_t i, double atten)=0
Sets the probe attenuation used for an input channel.
virtual int64_t GetResolutionBandwidth()
Gets the resolution bandwidth for frequency-domain channels.
Definition: Oscilloscope.cpp:935
std::pair< OscilloscopeChannel *, OscilloscopeChannel * > InterleaveConflict
Get the set of conflicting channels.
Definition: Oscilloscope.h:592
virtual void SetDigitalThreshold(size_t channel, float level)
Gets the threshold for a digital input.
Definition: Oscilloscope.cpp:747
virtual unsigned int GetChannelBandwidthLimit(size_t i)=0
Gets the bandwidth limit for an input channel.
virtual bool IsSamplingModeAvailable(SamplingMode mode)
Returns true if the requested sampling mode is available with the current instrument configuration.
Definition: Oscilloscope.cpp:656
virtual void SetDigitalHysteresis(size_t channel, float level)
Sets the hysteresis for a digital input.
Definition: Oscilloscope.cpp:743
virtual bool IsADCModeConfigurable()
Returns true if the ADC is configurable, false if it can only run in one mode.
Definition: Oscilloscope.cpp:823
bool FreeWaveformPools()
Free all waveforms in our pool to reclaim memory.
Definition: Oscilloscope.h:990
virtual int64_t GetDeskewForChannel(size_t channel)
Gets the deskew setting for a channel.
Definition: Oscilloscope.cpp:683
virtual bool PopPendingWaveform()
Pops the queue of pending waveforms and updates each channel with a new waveform.
Definition: Oscilloscope.cpp:182
virtual std::vector< uint64_t > GetSampleDepthsNonInterleaved()=0
Get the legal memory depths for this scope in all-channels mode.
static void ConvertUnsigned8BitSamplesGeneric(float *pout, const uint8_t *pin, float gain, float offset, size_t count)
Generic backend for ConvertUnsigned8BitSamples()
Definition: Oscilloscope.cpp:1153
virtual bool ShouldDegauss(size_t i)
Determines if a channel requires a degauss cycle (if supported)
Definition: Oscilloscope.cpp:765
virtual uint64_t GetSampleDepth()=0
Gets the current sample depth of this scope.
virtual void SetADCMode(size_t channel, size_t mode)
Sets the ADC mode for a channel.
Definition: Oscilloscope.cpp:840
virtual bool HasResolutionBandwidth()
Returns true if the instrument has a resolution bandwidth setting.
Definition: Oscilloscope.cpp:945
static void Convert8BitSamples(float *pout, const int8_t *pin, float gain, float offset, size_t count)
Converts 8-bit ADC samples to floating point.
Definition: Oscilloscope.cpp:962
virtual void SetDeskewForChannel(size_t channel, int64_t skew)
Sets the deskew setting for a channel.
Definition: Oscilloscope.cpp:678
virtual bool IsDigitalThresholdConfigurable()
Checks if digital input threshold is configurable or fixed.
Definition: Oscilloscope.cpp:728
virtual std::vector< uint64_t > GetSampleRatesNonInterleaved()=0
Get the legal sampling rates (in Hz) for this scope in all-channels mode.
virtual double GetChannelAttenuation(size_t i)=0
Gets the probe attenuation for an input channel.
virtual float GetChannelVoltageRange(size_t i, size_t stream)=0
Gets the range of the current channel configuration.
virtual size_t GetNumAverages(size_t i)
Returns the number of averages the channel is configured for.
Definition: Oscilloscope.cpp:212
virtual bool CanEnableChannel(size_t i)
Determines if a channel can be enabled.
Definition: Oscilloscope.cpp:117
int GetEnabledChannelCount()
Returns the number of enabled channels for this oscilloscope.
Definition: Oscilloscope.cpp:122
virtual void SetChannelBandwidthLimit(size_t i, unsigned int limit_mhz)=0
Sets the bandwidth limit for an input channel.
virtual std::string IDPing()=0
Returns the instrument's identification string.
void ChannelsDownloadStatusUpdate(size_t ch, InstrumentChannel::DownloadState state, float progress)
Helper method called by drivers to set one channel's download status and update its download progress...
Definition: Oscilloscope.cpp:873
virtual void StartSingleTrigger()=0
Arms the trigger for a single acquistion.
virtual void DisableChannel(size_t i)=0
Turn a channel off, given the index.
void DoPreLoadConfiguration(int version, const YAML::Node &node, IDTable &idmap, ConfigWarningList &list)
Validate instrument and channel configuration from a save file.
Definition: Oscilloscope.cpp:591
virtual void Start()=0
Starts the instrument in continuous trigger mode.
virtual void SetSampleDepth(uint64_t depth)=0
Sets the sample depth of the scope.
virtual void SetSampleRate(uint64_t rate)=0
Sets the sample rate of the scope, in Hz.
void ChannelsDownloadFinished()
Helper method called by drivers when waveform download is finished to reset all channels to "no downl...
Definition: Oscilloscope.cpp:883
virtual void FlushConfigCache()
Instruments are allowed to cache configuration settings to reduce round trip queries to the device.
Definition: Oscilloscope.cpp:107
virtual bool PeekTriggerArmed()
Checks if the trigger is armed directly on the instrument, without altering internal state or touchin...
Definition: Oscilloscope.cpp:905
virtual std::vector< AnalogBank > GetAnalogBanks()
Gets the analog banks for this instrument.
Definition: Oscilloscope.cpp:802
virtual bool CanDegauss(size_t i)
Determines if a channel has a probe connected which supports the "degauss" feature.
Definition: Oscilloscope.cpp:760
virtual void SetChannelOffset(size_t i, size_t stream, float offset)=0
Sets the offset for a given channel.
static void Convert8BitSamplesGeneric(float *pout, const int8_t *pin, float gain, float offset, size_t count)
Generic backend for Convert8BitSamples()
Definition: Oscilloscope.cpp:1021
virtual void SetChannelVoltageRange(size_t i, size_t stream, float range)=0
Sets the range of the current channel configuration.
virtual void SetSpan(int64_t span)
Sets the span for frequency-domain channels.
Definition: Oscilloscope.cpp:913
virtual void SetInputMux(size_t i, size_t select)
Sets the input mux for a channel.
Definition: Oscilloscope.cpp:795
virtual bool IsInterleaving()=0
Checks if the scope is currently combining channels.
virtual bool IsTriggerArmed()=0
Checks if the trigger is currently armed.
virtual bool CanAutoZero(size_t i)
Determines if a channel has a probe connected which supports the "auto zero" feature.
Definition: Oscilloscope.cpp:751
virtual std::vector< std::string > GetInputMuxNames(size_t i)
Gets names for the input mux ports of a channel.
Definition: Oscilloscope.cpp:789
void ClearPendingWaveforms()
Discard any pending waveforms that haven't yet been processed.
Definition: Oscilloscope.cpp:167
virtual size_t GetInputMuxSetting(size_t i)
Gets the setting for a channel's input mux (if it has one)
Definition: Oscilloscope.cpp:784
OscilloscopeChannel * GetOscilloscopeChannelByHwName(const std::string &name)
Gets a channel given the hardware name.
Definition: Oscilloscope.h:145
virtual size_t GetADCMode(size_t channel)
Gets the ADC mode for a channel.
Definition: Oscilloscope.cpp:835
virtual std::vector< std::string > GetADCModeNames(size_t channel)
Gets the names of the ADC modes for the bank a given channel is located in.
Definition: Oscilloscope.cpp:828
OscilloscopeChannel * GetOscilloscopeChannel(size_t i)
Gets a channel by index.
Definition: Oscilloscope.h:97
void SetTrigger(Trigger *trigger)
Sets a new trigger on the instrument and pushes changes.
Definition: Oscilloscope.h:468
virtual std::string GetProbeName(size_t i)
Returns the name of the probe connected to the scope, if possible.
Definition: Oscilloscope.cpp:774
virtual void Invert(size_t i, bool invert)
Enables hardware polarity inversion for a channel, if supported.
Definition: Oscilloscope.cpp:850
virtual std::vector< unsigned int > GetChannelBandwidthLimiters(size_t i)
Gets the set of available bandwidth limiters for an input channel.
Definition: Oscilloscope.cpp:702
virtual bool CanInvert(size_t i)
Checks if a channel is capable of hardware polarity inversion.
Definition: Oscilloscope.cpp:845
virtual void SetChannelCoupling(size_t i, OscilloscopeChannel::CouplingType type)=0
Sets the coupling used for an input channel.
virtual bool IsAppendingToWaveform()
Checks if we are appending to the existing waveform or creating a new one.
Definition: Oscilloscope.cpp:199
bool WaitForTrigger(int timeout)
Block until a trigger happens or a timeout elapses.
Definition: Oscilloscope.cpp:137
virtual void Stop()=0
Stops triggering.
virtual OscilloscopeChannel::CouplingType GetChannelCoupling(size_t i)=0
Gets the coupling used for an input channel.
virtual float GetDigitalHysteresis(size_t channel)
Gets the hysteresis for a digital input.
Definition: Oscilloscope.cpp:733
virtual std::vector< uint64_t > GetSampleDepthsInterleaved()=0
Get the legal memory depths for this scope in combined-channels mode.
virtual bool CanInterleave()
Returns true if we have no interleave conflicts, false if we have conflicts.
Definition: Oscilloscope.cpp:689
virtual void SetResolutionBandwidth(int64_t rbw)
Gets the resolution bandwidth for frequency-domain channels.
Definition: Oscilloscope.cpp:931
virtual void SetSamplingMode(SamplingMode mode)
Sets the current sampling mode of the instrument.
Definition: Oscilloscope.cpp:666
virtual DigitalBank GetDigitalBank(size_t channel)
Gets the bank containing a given channel.
Definition: Oscilloscope.cpp:718
static void Convert16BitSamples(float *pout, const int16_t *pin, float gain, float offset, size_t count)
Converts 16-bit ADC samples to floating point.
Definition: Oscilloscope.cpp:1229
Trigger * GetTrigger(bool sync=false)
Gets the current trigger.
Definition: Oscilloscope.h:494
virtual bool SetInterleaving(bool combine)=0
Configures the scope to combine channels.
virtual void ForceTrigger()=0
Forces a single acquisition as soon as possible.
virtual SamplingMode GetSamplingMode()
Gets the current sampling mode of the instrument.
Definition: Oscilloscope.cpp:661
virtual void PushTrigger()=0
Pushes changes made to m_trigger to the instrument.
virtual int64_t GetTriggerOffset()=0
Gets the trigger offset.
virtual void PullTrigger()=0
Updates m_trigger with any changes made from the instrument side.
void ChannelsDownloadStarted()
Helper method called by drivers to reset all channels to "waiting to download" state.
Definition: Oscilloscope.cpp:859
virtual bool IsDigitalHysteresisConfigurable()
Checks if digital input hysteresis is configurable or fixed.
Definition: Oscilloscope.cpp:723
virtual float GetDigitalThreshold(size_t channel)
Gets the threshold for a digital input.
Definition: Oscilloscope.cpp:738
virtual int64_t GetSpan()
Gets the span for frequency-domain channels.
Definition: Oscilloscope.cpp:917
virtual void AutoZero(size_t i)
Performs an "auto zero" cycle on the attached active probe, if supported by the hardware.
Definition: Oscilloscope.cpp:756
virtual void EnableChannel(size_t i)=0
Turn a channel on, given the index.
virtual void SetUseExternalRefclk(bool external)
Configures the instrument's clock source.
Definition: Oscilloscope.cpp:671
virtual void EnableTriggerOutput()
Enables the trigger output, configuring a shared auxiliary port for this purpose if needed.
Definition: Oscilloscope.cpp:651
static void ConvertUnsigned8BitSamples(float *pout, const uint8_t *pin, float gain, float offset, size_t count)
Converts Unsigned 8-bit ADC samples to floating point.
Definition: Oscilloscope.cpp:1094
TriggerMode
Definition: Oscilloscope.h:411
@ TRIGGER_MODE_AUTO
Auto trigger - waiting for auto-trigger.
Definition: Oscilloscope.h:425
@ TRIGGER_MODE_COUNT
Placeholder.
Definition: Oscilloscope.h:428
@ TRIGGER_MODE_WAIT
WAIT - not yet fully armed.
Definition: Oscilloscope.h:422
@ TRIGGER_MODE_TRIGGERED
Just got triggered, data is ready to read.
Definition: Oscilloscope.h:419
@ TRIGGER_MODE_RUN
Active, waiting for a trigger event.
Definition: Oscilloscope.h:413
@ TRIGGER_MODE_STOP
Triggered once, but not recently.
Definition: Oscilloscope.h:416
virtual std::vector< DigitalBank > GetDigitalBanks()
Gets the digital channel banks for this instrument.
Definition: Oscilloscope.cpp:712
virtual void SetCenterFrequency(size_t channel, int64_t freq)
Sets the center frequency for frequency-domain channels.
Definition: Oscilloscope.cpp:922
virtual void SetNumAverages(size_t i, size_t navg)
Sets the number of hardware averages to use.
Definition: Oscilloscope.cpp:217
virtual bool IsOffline()
Checks if the instrument is currently online.
Definition: Oscilloscope.cpp:112
virtual OscilloscopeChannel * GetExternalTrigger()=0
Returns the external trigger input channel, if we have one.
virtual bool HasTimebaseControls()
Returns true if the instrument has at least one time-domain channel.
Definition: Oscilloscope.cpp:951
virtual Oscilloscope::TriggerMode PollTrigger()=0
Checks the curent trigger status.
virtual std::vector< OscilloscopeChannel::CouplingType > GetAvailableCouplings(size_t i)=0
Gets the set of legal coupling values for an input channel.
virtual void Degauss(size_t i)
Performs an "degauss" cycle on the attached active probe, if supported by the hardware.
Definition: Oscilloscope.cpp:770
virtual std::vector< std::string > GetTriggerTypes()
Gets a list of triggers this instrument supports.
Definition: Oscilloscope.cpp:898
virtual AnalogBank GetAnalogBank(size_t channel)
Gets the bank containing a given channel.
Definition: Oscilloscope.cpp:809
static void Convert16BitSamplesGeneric(float *pout, const int16_t *pin, float gain, float offset, size_t count)
Converts raw ADC samples to floating point.
Definition: Oscilloscope.cpp:1314
virtual void SetTriggerOffset(int64_t offset)=0
Sets the trigger offset.
void DoSerializeConfiguration(YAML::Node &node, IDTable &table)
Serializes this oscilloscope's configuration to a YAML node.
Definition: Oscilloscope.cpp:226
virtual bool CanAverage(size_t i)
Determines if the channel supports hardware averaging.
Definition: Oscilloscope.cpp:207
virtual uint64_t GetSampleRate()=0
Gets the current sampling rate (in Hz) of this scope.
Abstraction of a transport layer for moving SCPI data between endpoints.
Definition: SCPITransport.h:47
Abstract base class for oscilloscope / logic analyzer trigger inputs.
Definition: Trigger.h:46