ngscopeclient 0.1-dev+51fbda87c
Oscilloscope.h
Go to the documentation of this file.
1/***********************************************************************************************************************
2* *
3* libscopehal *
4* *
5* Copyright (c) 2012-2024 Andrew D. Zonenberg and contributors *
6* All rights reserved. *
7* *
8* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the *
9* following conditions are met: *
10* *
11* * Redistributions of source code must retain the above copyright notice, this list of conditions, and the *
12* following disclaimer. *
13* *
14* * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the *
15* following disclaimer in the documentation and/or other materials provided with the distribution. *
16* *
17* * Neither the name of the author nor the names of any contributors may be used to endorse or promote products *
18* derived from this software without specific prior written permission. *
19* *
20* THIS SOFTWARE IS PROVIDED BY THE AUTHORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
21* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL *
22* THE AUTHORS BE HELD LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES *
23* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR *
24* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT *
25* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE *
26* POSSIBILITY OF SUCH DAMAGE. *
27* *
28***********************************************************************************************************************/
29
36#ifndef Oscilloscope_h
37#define Oscilloscope_h
38
39class Instrument;
40
41#include "SCPITransport.h"
42#include "WaveformPool.h"
43
49class Oscilloscope : public virtual Instrument
50{
51public:
53 // Construction / destruction
54
56 virtual ~Oscilloscope();
57
64 virtual std::string IDPing() =0;
65
79 virtual void FlushConfigCache();
80
87 virtual bool IsOffline();
88
90 // Channel information
91
98 { return dynamic_cast<OscilloscopeChannel*>(GetChannel(i)); }
99
103 virtual bool IsChannelEnabled(size_t i) =0;
104
110 virtual void EnableChannel(size_t i) =0;
111
124 virtual bool CanEnableChannel(size_t i);
125
133 virtual void DisableChannel(size_t i) =0;
134
141
146 { return dynamic_cast<OscilloscopeChannel*>(GetChannelByHwName(name)); }
147
153 virtual OscilloscopeChannel::CouplingType GetChannelCoupling(size_t i) =0;
154
160 virtual void SetChannelCoupling(size_t i, OscilloscopeChannel::CouplingType type) =0;
161
167 virtual std::vector<OscilloscopeChannel::CouplingType> GetAvailableCouplings(size_t i) =0;
168
177 virtual double GetChannelAttenuation(size_t i) =0;
178
185 virtual void SetChannelAttenuation(size_t i, double atten) =0;
186
192 virtual std::vector<unsigned int> GetChannelBandwidthLimiters(size_t i);
193
201 virtual unsigned int GetChannelBandwidthLimit(size_t i) =0;
202
209 virtual void SetChannelBandwidthLimit(size_t i, unsigned int limit_mhz) =0;
210
218
231 virtual float GetChannelVoltageRange(size_t i, size_t stream) =0;
232
246 virtual void SetChannelVoltageRange(size_t i, size_t stream, float range) =0;
247
255 virtual bool CanAutoZero(size_t i);
256
262 virtual void AutoZero(size_t i);
263
271 virtual bool CanDegauss(size_t i);
272
278 virtual bool ShouldDegauss(size_t i);
279
285 virtual void Degauss(size_t i);
286
292 virtual bool CanAverage(size_t i);
293
299 virtual size_t GetNumAverages(size_t i);
300
307 virtual void SetNumAverages(size_t i, size_t navg);
308
317 virtual std::string GetProbeName(size_t i);
318
324 virtual bool HasInputMux(size_t i);
325
331 virtual size_t GetInputMuxSetting(size_t i);
332
338 virtual std::vector<std::string> GetInputMuxNames(size_t i);
339
346 virtual void SetInputMux(size_t i, size_t select);
347
354 virtual float GetChannelOffset(size_t i, size_t stream) =0;
355
363 virtual void SetChannelOffset(size_t i, size_t stream, float offset) =0;
364
370 virtual bool CanInvert(size_t i);
371
378 virtual void Invert(size_t i, bool invert);
379
385 virtual bool IsInverted(size_t i);
386
387protected:
388
391
403 void ChannelsDownloadStatusUpdate(size_t ch, InstrumentChannel::DownloadState state, float progress);
404
407
408public:
409 //Triggering
411 {
414
417
420
423
426
429 };
430
435
447 virtual bool PeekTriggerArmed();
448
459 bool WaitForTrigger(int timeout);
460
468 void SetTrigger(Trigger* trigger)
469 {
470 Trigger* old_trig = m_trigger;
471
472 //Set the new trigger and sync to hardware
473 m_trigger = trigger;
474 PushTrigger();
475
476 //Delete old trigger *after* pushing the new one.
477 //This prevents possible race conditions where we disable the current trigger channel before the new
478 //trigger is set.
479 if(old_trig != trigger)
480 delete old_trig;
481 }
482
486 virtual void PushTrigger() =0;
487
494 Trigger* GetTrigger(bool sync = false)
495 {
496 if(sync || (m_trigger == NULL) )
497 PullTrigger();
498 return m_trigger;
499 }
500
504 virtual std::vector<std::string> GetTriggerTypes();
505
509 virtual void PullTrigger() =0;
510
517 virtual void Start() =0;
518
522 virtual void StartSingleTrigger() =0;
523
527 virtual void Stop() =0;
528
534 virtual void ForceTrigger() =0;
535
539 virtual bool IsTriggerArmed() =0;
540
547 virtual void EnableTriggerOutput();
548
549public:
551 // Memory depth / sample rate control.
552
556 virtual std::vector<uint64_t> GetSampleRatesNonInterleaved() =0;
557
561 virtual std::vector<uint64_t> GetSampleRatesInterleaved() =0;
562
566 virtual uint64_t GetSampleRate() =0;
567
571 virtual bool IsInterleaving() =0;
572
580 virtual bool SetInterleaving(bool combine) =0;
581
585 virtual bool CanInterleave();
586
592 typedef std::pair<OscilloscopeChannel*, OscilloscopeChannel* > InterleaveConflict;
593 virtual std::set< InterleaveConflict > GetInterleaveConflicts() =0;
594
598 virtual std::vector<uint64_t> GetSampleDepthsNonInterleaved() =0;
599
603 virtual std::vector<uint64_t> GetSampleDepthsInterleaved() =0;
604
608 virtual uint64_t GetSampleDepth() =0;
609
613 virtual void SetSampleDepth(uint64_t depth) =0;
614
618 virtual void SetSampleRate(uint64_t rate) =0;
619
620 enum SamplingMode
621 {
622 REAL_TIME,
623 EQUIVALENT_TIME
624 };
625
631 virtual bool IsSamplingModeAvailable(SamplingMode mode);
632
638 virtual SamplingMode GetSamplingMode();
639
645 virtual void SetSamplingMode(SamplingMode mode);
646
656 virtual void SetUseExternalRefclk(bool external);
657
665 virtual void SetTriggerOffset(int64_t offset) =0;
666
670 virtual int64_t GetTriggerOffset() =0;
671
682 virtual void SetDeskewForChannel(size_t channel, int64_t skew);
683
689 virtual int64_t GetDeskewForChannel(size_t channel);
690
692 // Sequenced triggering
693
695 // ADC bit depth configuration
696
697 typedef std::vector<OscilloscopeChannel*> AnalogBank;
698
704 virtual std::vector<AnalogBank> GetAnalogBanks();
705
709 virtual AnalogBank GetAnalogBank(size_t channel);
710
714 virtual bool IsADCModeConfigurable();
715
724 virtual std::vector<std::string> GetADCModeNames(size_t channel);
725
729 virtual size_t GetADCMode(size_t channel);
730
734 virtual void SetADCMode(size_t channel, size_t mode);
735
737 // Logic analyzer configuration
738
739 typedef std::vector<OscilloscopeChannel*> DigitalBank;
740
746 virtual std::vector<DigitalBank> GetDigitalBanks();
747
751 virtual DigitalBank GetDigitalBank(size_t channel);
752
758 virtual bool IsDigitalHysteresisConfigurable();
759
765 virtual bool IsDigitalThresholdConfigurable();
766
770 virtual float GetDigitalHysteresis(size_t channel);
771
775 virtual float GetDigitalThreshold(size_t channel);
776
780 virtual void SetDigitalHysteresis(size_t channel, float level);
781
785 virtual void SetDigitalThreshold(size_t channel, float level);
786
788 // Frequency domain channel configuration
789
795 virtual void SetSpan(int64_t span);
796
800 virtual int64_t GetSpan();
801
808 virtual void SetCenterFrequency(size_t channel, int64_t freq);
809
815 virtual int64_t GetCenterFrequency(size_t channel);
816
820 virtual void SetResolutionBandwidth(int64_t rbw);
821
825 virtual int64_t GetResolutionBandwidth();
826
830 virtual bool HasFrequencyControls();
831
839 virtual bool HasResolutionBandwidth();
840
844 virtual bool HasTimebaseControls();
845
846 //TODO: window controls
847
849 // Configuration storage
850
851protected:
855 void DoSerializeConfiguration(YAML::Node& node, IDTable& table);
856
860 void DoLoadConfiguration(int version, const YAML::Node& node, IDTable& idmap);
861
865 void DoPreLoadConfiguration(int version, const YAML::Node& node, IDTable& idmap, ConfigWarningList& list);
866
868 // Sample format conversion
869public:
870 static void Convert8BitSamples(float* pout, const int8_t* pin, float gain, float offset, size_t count);
871 static void Convert8BitSamplesGeneric(float* pout, const int8_t* pin, float gain, float offset, size_t count);
872#ifdef __x86_64__
873 static void Convert8BitSamplesAVX2(float* pout, const int8_t* pin, float gain, float offset, size_t count);
874#endif
875
876 static void ConvertUnsigned8BitSamples(float* pout, const uint8_t* pin, float gain, float offset, size_t count);
877 static void ConvertUnsigned8BitSamplesGeneric(float* pout, const uint8_t* pin, float gain, float offset, size_t count);
878#ifdef __x86_64__
879 static void ConvertUnsigned8BitSamplesAVX2(float* pout, const uint8_t* pin, float gain, float offset, size_t count);
880#endif
881
882 static void Convert16BitSamples(float* pout, const int16_t* pin, float gain, float offset, size_t count);
883 static void Convert16BitSamplesGeneric(float* pout, const int16_t* pin, float gain, float offset, size_t count);
884#ifdef __x86_64__
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);
888#endif
889
890public:
892 // Waveform Access
893
894 bool HasPendingWaveforms();
896 size_t GetPendingWaveformCount();
897 virtual bool PopPendingWaveform();
898 virtual bool IsAppendingToWaveform();
899
900protected:
901 typedef std::map<StreamDescriptor, WaveformBase*> SequenceSet;
902 std::list<SequenceSet> m_pendingWaveforms;
903 std::mutex m_pendingWaveformsMutex;
904 std::recursive_mutex m_mutex;
905
907 // Diagnostics Access
908protected:
909 std::deque<std::string> m_diagnosticLogMessages;
910 std::map<std::string, FilterParameter*> m_diagnosticValues;
911 // Pointers are expected to be to members of this class; not dynamically allocated
912
913 void AddDiagnosticLog(std::string message)
914 {
915 m_diagnosticLogMessages.push_back(message);
916 }
917
918public:
919 bool HasPendingDiagnosticLogMessages()
920 {
921 return !m_diagnosticLogMessages.empty();
922 }
923
924 std::string PopPendingDiagnosticLogMessage()
925 {
926 std::string message = m_diagnosticLogMessages.front();
927 m_diagnosticLogMessages.pop_front();
928 return message;
929 }
930
931 std::map<std::string, FilterParameter*>& GetDiagnosticsValues()
932 {
933 // TODO: Should really be readonly, but need to mutate to add change listeners...
934 return m_diagnosticValues;
935 }
936
937protected:
938
939 //The trigger
940 Trigger* m_trigger;
941
942 //Pool for reusing memory allocations
943 WaveformPool m_analogWaveformPool;
944
945 WaveformPool m_digitalWaveformPool;
946
947 UniformAnalogWaveform* AllocateAnalogWaveform(const std::string& name)
948 {
949 auto p = m_analogWaveformPool.Get();
950 auto ret = dynamic_cast<UniformAnalogWaveform*>(p);
951 if(ret)
952 {
953 ret->Rename(name);
954 return ret;
955 }
956
957 //Delete garbage if somebody pushed the wrong type of waveform
958 if(p)
959 delete p;
960
961 //Pool was empty, allocate a new waveform
962 return new UniformAnalogWaveform(name);
963 }
964
965 SparseDigitalWaveform* AllocateDigitalWaveform(const std::string& name)
966 {
967 auto p = m_digitalWaveformPool.Get();
968 auto ret = dynamic_cast<SparseDigitalWaveform*>(p);
969 if(ret)
970 {
971 ret->Rename(name);
972 return ret;
973 }
974
975 //Delete garbage if somebody pushed the wrong type of waveform
976 if(p)
977 delete p;
978
979 //Pool was empty, allocate a new waveform
980 return new SparseDigitalWaveform(name);
981 }
982
983public:
984
991 { return m_analogWaveformPool.clear() || m_digitalWaveformPool.clear(); }
992
993 void AddWaveformToAnalogPool(WaveformBase* w)
994 { m_analogWaveformPool.Add(w); }
995
996 void AddWaveformToDigitalPool(WaveformBase* w)
997 { m_digitalWaveformPool.Add(w); }
998
999public:
1000 typedef std::shared_ptr<Oscilloscope> (*CreateProcType)(SCPITransport*);
1001 static void DoAddDriverClass(std::string name, CreateProcType proc);
1002
1003 static void EnumDrivers(std::vector<std::string>& names);
1004 static std::shared_ptr<Oscilloscope> CreateOscilloscope(std::string driver, SCPITransport* transport);
1005
1006protected:
1007 //Class enumeration
1008 typedef std::map< std::string, CreateProcType > CreateMapType;
1009 static CreateMapType m_createprocs;
1010};
1011
1012//must be declared here after Oscilloscope is defined
1013inline Oscilloscope* OscilloscopeChannel::GetScope()
1014{ return dynamic_cast<Oscilloscope*>(m_instrument); }
1015
1016#ifndef STRINGIFY
1017#define STRINGIFY(T) #T
1018#endif
1019
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(); }
1025
1026#define AddDriverClass(T) Oscilloscope::DoAddDriverClass(T::GetDriverNameInternal(), T::CreateInstance)
1027
1028#endif
Declaration of SCPITransport.
Declaration of WaveformPool.
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
A waveform sampled at irregular intervals.
Definition: Waveform.h:460
virtual void Rename(const std::string &name="") override
Assings a human readable name to the waveform for debug purposes.
Definition: Waveform.h:478
Abstract base class for oscilloscope / logic analyzer trigger inputs.
Definition: Trigger.h:46
A waveform sampled at uniform intervals.
Definition: Waveform.h:365
virtual void Rename(const std::string &name="") override
Assings a human readable name to the waveform for debug purposes.
Definition: Waveform.h:383
Base class for all Waveform specializations.
Definition: Waveform.h:59
Thread safe memory pool for reusing Waveform objects.
Definition: WaveformPool.h:47
bool clear()
Free all waveforms in the pool to reclaim memory.
Definition: WaveformPool.h:109
WaveformBase * Get()
Attempts to get a waveform from the pool.
Definition: WaveformPool.h:89
void Add(WaveformBase *w)
Adds a new waveform to the pool if there's sufficient free slots in the pool.
Definition: WaveformPool.h:73