ngscopeclient 0.1-dev+51fbda87c
Session.h
Go to the documentation of this file.
1/***********************************************************************************************************************
2* *
3* ngscopeclient *
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
35#ifndef Session_h
36#define Session_h
37
38class MainWindow;
39class WaveformArea;
41
42#include "../xptools/HzClock.h"
43#include "HistoryManager.h"
44#include "PacketManager.h"
45#include "PreferenceManager.h"
46#include "Marker.h"
47#include "TriggerGroup.h"
48
49extern std::atomic<int64_t> g_lastWaveformRenderTime;
50
51class Session;
52
54{
55public:
57 {
58 m_shuttingDown = false;
59 args.shuttingDown = &m_shuttingDown;
60 m_thread = std::make_unique<std::thread>(InstrumentThread, args);
62 }
63
65 { Close(); }
66
67 void Close()
68 {
69 if(m_thread)
70 {
71 //Terminate the thread
72 m_shuttingDown = true;
73 m_thread->join();
74 }
75 m_thread = nullptr;
76 }
77
79 std::atomic<bool> m_shuttingDown;
80
82 std::unique_ptr<std::thread> m_thread;
83
86};
87
95{
96public:
97 Session(MainWindow* wnd);
98 virtual ~Session();
99
100 bool OnMemoryPressure(MemoryPressureLevel level, MemoryPressureType type, size_t requestedSize);
101
102 void ArmTrigger(TriggerGroup::TriggerType type, bool all=false);
103 void StopTrigger(bool all=false);
104 bool HasOnlineScopes();
105 void DownloadWaveforms();
106 bool CheckForWaveforms(vk::raii::CommandBuffer& cmdbuf);
107 void RefreshAllFilters();
110 bool RefreshDirtyFilters();
111 void FlushConfigCache();
112
114
115 void RenderWaveformTextures(
116 vk::raii::CommandBuffer& cmdbuf,
117 std::vector<std::shared_ptr<DisplayedChannel> >& channels);
118
119 void Clear();
121
122 bool PreLoadFromYaml(const YAML::Node& node, const std::string& dataDir, bool online);
123 bool LoadFromYaml(const YAML::Node& node, const std::string& dataDir, bool online);
125 YAML::Node SerializeMetadata();
126 YAML::Node SerializeTriggerGroups();
127 bool LoadTriggerGroups(const YAML::Node& node);
128 YAML::Node SerializeFilterConfiguration();
129 YAML::Node SerializeMarkers();
130 bool SerializeWaveforms(const std::string& dataDir);
131 bool SerializeSparseWaveform(SparseWaveformBase* wfm, const std::string& path);
132 bool SerializeUniformWaveform(UniformWaveformBase* wfm, const std::string& path);
133
134 void AddMultimeterDialog(std::shared_ptr<SCPIMultimeter> meter);
135 std::shared_ptr<PacketManager> AddPacketFilter(PacketDecoder* filter);
136
137 void AddInstrument(std::shared_ptr<Instrument> inst, bool createDialogs = true);
138 void RemoveInstrument(std::shared_ptr<Instrument> inst);
139 std::shared_ptr<InstrumentConnectionState> GetInstrumentConnectionState(std::shared_ptr<Instrument> inst) { return m_instrumentStates[inst]; }
140
141 bool IsMultiScope()
142 { return m_multiScope; }
143
144 MainWindow* GetMainWindow()
145 { return m_mainWindow; }
146
150 std::shared_ptr<BERTState> GetBERTState(std::shared_ptr<BERT> bert)
151 {
152 std::lock_guard<std::mutex> lock(m_scopeMutex);
153 return m_berts[bert];
154 }
155
159 std::shared_ptr<PowerSupplyState> GetPSUState(std::shared_ptr<SCPIPowerSupply> psu)
160 {
161 std::lock_guard<std::mutex> lock(m_scopeMutex);
162 return m_psus[psu];
163 }
164
168 std::shared_ptr<FunctionGeneratorState> GetFunctionGeneratorState(std::shared_ptr<FunctionGenerator> awg)
169 {
170 std::lock_guard<std::mutex> lock(m_scopeMutex);
171 return m_awgs[awg];
172 }
173
177 std::shared_ptr<PacketManager> GetPacketManager(PacketDecoder* filter)
178 {
179 std::lock_guard<std::mutex> lock(m_packetMgrMutex);
180 return m_packetmgrs[filter];
181 }
182
183 void ApplyPreferences(std::shared_ptr<Oscilloscope> scope);
184
185 size_t GetFilterCount();
186
187 bool IsChannelBeingDragged();
188
189 int64_t GetToneMapTime();
190
195 { return m_lastFilterGraphExecTime.load(); }
196
201 { return g_lastWaveformRenderTime.load(); }
202
207 {
208 std::lock_guard<std::mutex> lock(m_perfClockMutex);
209 return m_waveformDownloadRate.GetAverageHz();
210 }
211
215 const std::vector<std::shared_ptr<Oscilloscope>> GetScopes()
216 {
217 std::lock_guard<std::mutex> lock(m_scopeMutex);
218 return m_oscilloscopes;
219 }
220
224 const std::vector<std::shared_ptr<BERT> > GetBERTs()
225 {
226 std::lock_guard<std::mutex> lock(m_scopeMutex);
227 std::vector<std::shared_ptr<BERT> > berts;
228 for(auto& it : m_berts)
229 berts.push_back(it.first);
230 return berts;
231 }
232
236 std::set<std::shared_ptr<SCPIInstrument>> GetSCPIInstruments();
237
241 std::set<std::shared_ptr<Instrument>> GetInstruments();
242
247 { return GetInstruments().size(); }
248
253
257 std::shared_mutex& GetWaveformDataMutex()
258 { return m_waveformDataMutex; }
259
264 { return m_history; }
265
269 void AddMarker(Marker m);
270
272
273 void ClearSweeps();
274
279 { return m_rasterizedWaveformMutex; }
280
285
289 std::string m_generalNotes;
290
294 std::string m_setupNotes;
295
296 std::vector<std::shared_ptr<TriggerGroup> > GetTriggerGroups()
297 {
298 std::lock_guard<std::recursive_mutex> lock(m_triggerGroupMutex);
299 return m_triggerGroups;
300 }
301
303
304 void MakeNewTriggerGroup(std::shared_ptr<Oscilloscope> scope);
305 void MakeNewTriggerGroup(PausableFilter* filter);
306
307 int64_t GetDeskew(std::shared_ptr<Oscilloscope> scope)
308 { return m_scopeDeskewCal[scope]; }
309
310 void SetDeskew(std::shared_ptr<Oscilloscope> scope, int64_t skew)
311 { m_scopeDeskewCal[scope] = skew; }
312
313 bool IsPrimaryOfMultiScopeGroup(std::shared_ptr<Oscilloscope> scope);
314 bool IsSecondaryOfMultiScopeGroup(std::shared_ptr<Oscilloscope> scope);
315
316 std::shared_ptr<TriggerGroup> GetTriggerGroupForScope(std::shared_ptr<Oscilloscope> scope);
317 std::shared_ptr<TriggerGroup> GetTriggerGroupForFilter(PausableFilter* filter);
318
319 const ConfigWarningList& GetWarnings()
320 { return m_warnings; }
321
323 std::shared_ptr<LoadState> GetLoadState(std::shared_ptr<Load> load)
324 {
325 auto it = m_loads.find(load);
326 if(it != m_loads.end())
327 return it->second;
328 else
329 return nullptr;
330 }
331
332 std::shared_ptr<TriggerGroup> GetTrendFilterGroup();
333
334 void OnMarkerChanged();
335
337 std::map<FlowGraphNode*, int64_t> GetFilterGraphRuntime()
338 {
339 std::lock_guard<std::mutex> lock(m_lastFilterGraphRuntimeMutex);
341 }
342
343protected:
344 void UpdatePacketManagers(const std::set<FlowGraphNode*>& nodes);
345
346 std::string GetRegisteredTypeOfDriver(const std::string& drivername);
347
348 bool LoadInstruments(int version, const YAML::Node& node, bool online);
349 bool PreLoadInstruments(int version, const YAML::Node& node, bool online);
350 SCPITransport* CreateTransportForNode(const YAML::Node& node);
351 bool VerifyInstrument(const YAML::Node& node, std::shared_ptr<Instrument> inst);
352 bool PreLoadVNA(int version, const YAML::Node& node, bool online);
353 bool PreLoadOscilloscope(int version, const YAML::Node& node, bool online);
354 bool PreLoadPowerSupply(int version, const YAML::Node& node, bool online);
355 bool PreLoadRFSignalGenerator(int version, const YAML::Node& node, bool online);
356 bool PreLoadFunctionGenerator(int version, const YAML::Node& node, bool online);
357 bool PreLoadMultimeter(int version, const YAML::Node& node, bool online);
358 bool PreLoadSpectrometer(int version, const YAML::Node& node, bool online);
359 bool PreLoadSDR(int version, const YAML::Node& node, bool online);
360 bool PreLoadBERT(int version, const YAML::Node& node, bool online);
361 bool PreLoadLoad(int version, const YAML::Node& node, bool online);
362 bool PreLoadMisc(int version, const YAML::Node& node, bool online);
363 bool LoadFilters(int version, const YAML::Node& node);
364 bool LoadInstrumentInputs(int version, const YAML::Node& node);
365 bool LoadWaveformData(int version, const std::string& dataDir);
367 int version,
368 const YAML::Node& node,
369 std::shared_ptr<Oscilloscope> scope,
370 const std::string& dataDir);
372 int version,
373 const YAML::Node& node,
374 const std::string& dataDir);
375 void DoLoadWaveformDataForStream(
377 int stream,
378 std::string format,
379 std::string fname);
380
383
386
388 std::map<std::shared_ptr<Oscilloscope>, int64_t> m_scopeDeskewCal;
389
391 std::mutex m_scopeMutex;
392
394 std::shared_mutex m_waveformDataMutex;
395
398
401
403 std::atomic<bool> m_shuttingDown;
404
407
409 std::vector<std::shared_ptr<Oscilloscope>> m_oscilloscopes;
410
412 std::map<std::shared_ptr<PowerSupply>, std::shared_ptr<PowerSupplyState> > m_psus;
413
415 std::map<std::shared_ptr<Multimeter>, std::shared_ptr<MultimeterState> > m_meters;
416
418 std::map<std::shared_ptr<Load>, std::shared_ptr<LoadState> > m_loads;
419
421 std::map<std::shared_ptr<BERT>, std::shared_ptr<BERTState> > m_berts;
422
424 std::map<std::shared_ptr<FunctionGenerator>, std::shared_ptr<FunctionGeneratorState> > m_awgs;
425
427 std::vector<std::shared_ptr<TriggerGroup> > m_triggerGroups;
428
430 std::shared_ptr<TriggerGroup> m_trendTriggerGroup;
431
433 std::recursive_mutex m_triggerGroupMutex;
434
436 std::map<std::shared_ptr<Instrument>, std::shared_ptr<InstrumentConnectionState> > m_instrumentStates;
437
439 std::unique_ptr<std::thread> m_waveformThread;
440
442 std::set<std::shared_ptr<Oscilloscope> > m_recentlyTriggeredScopes;
443
445 std::set<std::shared_ptr<TriggerGroup>> m_recentlyTriggeredGroups;
446
449
451 double m_tArm;
452
455
458
461
464
466 std::atomic<int64_t> m_lastFilterGraphExecTime;
467
470
472 std::map<FlowGraphNode*, int64_t> m_lastFilterGraphRuntimeStats;
473
476
479
482
485
487 std::map<PacketDecoder*, std::shared_ptr<PacketManager> > m_packetmgrs;
488
491
494
496 // Markers
497
499 std::map<TimePoint, std::vector<Marker> > m_markers;
500
503
505 // Partial graph refreshes
506
508 std::set<FlowGraphNode*> m_dirtyChannels;
509
512
513public:
514
518 std::string GetNextMarkerName()
519 { return std::string("M") + std::to_string(m_nextMarkerNum ++); }
520
524 std::vector<Marker>& GetMarkers(TimePoint t)
525 { return m_markers[t]; }
526
530 std::vector<TimePoint> GetMarkerTimes();
531
536 { m_markers.erase(t); }
537
538 void RemovePackets(TimePoint t);
539
540 std::set<FlowGraphNode*> GetAllGraphNodes();
541
543 std::optional<TimePoint> GetHoveredPacketTimestamp()
544 { return m_hoverTime; }
545
546 void SetHoveredPacketTimestamp(std::optional<TimePoint> t)
547 { m_hoverTime = t; }
548
549protected:
550 std::optional<TimePoint> m_hoverTime;
551
553 // End user preferences (persistent across sessions)
554
555 //Preferences state
556 PreferenceManager m_preferences;
557
558public:
559 PreferenceManager& GetPreferences()
560 { return m_preferences; }
561
563 // Reference filters (used to query legal inputs to filters etc)
564
565public:
566
570 Filter* GetReferenceFilter(const std::string& name)
571 { return m_referenceFilters[name]; }
572
573 const std::map<std::string, Filter*>& GetReferenceFilters()
574 { return m_referenceFilters; }
575
577 const std::vector<std::string>& GetDriverNamesForType(const std::string& type)
578 { return m_driverNamesByType[type]; }
579
581 const std::string& driver,
582 SCPITransport* transport,
583 const std::string& nickname);
584
585protected:
588
589 std::map<std::string, Filter*> m_referenceFilters;
590
592 std::map<std::string, std::vector<std::string> > m_driverNamesByType;
593};
594
595#endif
MemoryPressureLevel
Levels of memory pressure.
Definition: AcceleratorBuffer.h:67
MemoryPressureType
Types of memory pressure.
Definition: AcceleratorBuffer.h:84
Declaration of HistoryManager.
Declaration of Marker.
Declaration of PacketManager.
Stores and manages preference values.
std::atomic< int64_t > g_lastWaveformRenderTime
Time spent on the last cycle of waveform rendering shaders.
Definition: WaveformThread.cpp:53
Declaration of TriggerGroup.
All warnings generated by a configuration we're in the process of loading.
Definition: ConfigWarningList.h:90
Context data for a single channel being displayed within a WaveformArea.
Definition: WaveformArea.h:190
Execution manager / scheduler for the filter graph.
Definition: FilterGraphExecutor.h:48
Abstract base class for all filter graph blocks which are not physical instrument channels.
Definition: Filter.h:95
Keeps track of recently acquired waveforms.
Definition: HistoryManager.h:73
Clock that measures rate at which it is called; windowed average.
Definition: HzClock.h:52
Bidirectional table mapping integer IDs in scopesession files to object pointers.
Definition: IDTable.h:49
A single channel of an instrument.
Definition: InstrumentChannel.h:63
Definition: Session.h:54
std::unique_ptr< std::thread > m_thread
Thread for polling the instrument.
Definition: Session.h:82
Oscilloscope::TriggerMode m_lastTriggerState
Cached trigger state, to reflect in the UI.
Definition: Session.h:85
std::atomic< bool > m_shuttingDown
Termination flag for shutting down the polling thread.
Definition: Session.h:79
Definition: ngscopeclient.h:59
Top level application window.
Definition: MainWindow.h:115
Data for a marker.
Definition: Marker.h:84
A single channel on an oscilloscope.
Definition: OscilloscopeChannel.h:49
TriggerMode
Definition: Oscilloscope.h:411
@ TRIGGER_MODE_WAIT
WAIT - not yet fully armed.
Definition: Oscilloscope.h:422
Definition: PacketDecoder.h:85
A filter which may be started and stopped.
Definition: PausableFilter.h:46
Definition: PreferenceManager.h:45
Abstraction of a transport layer for moving SCPI data between endpoints.
Definition: SCPITransport.h:47
A Session stores all of the instrument configuration and other state the user has open.
Definition: Session.h:95
std::map< std::shared_ptr< BERT >, std::shared_ptr< BERTState > > m_berts
BERTs we are currently connected to.
Definition: Session.h:421
bool PreLoadFromYaml(const YAML::Node &node, const std::string &dataDir, bool online)
Perform partial loading and check for potentially dangerous configurations.
Definition: Session.cpp:316
int64_t GetToneMapTime()
Gets the last execution time of the tone mapping shaders.
Definition: Session.cpp:3478
std::shared_ptr< LoadState > GetLoadState(std::shared_ptr< Load > load)
Get the state for a load.
Definition: Session.h:323
const std::vector< std::string > & GetDriverNamesForType(const std::string &type)
Get all of the drivers of a given type.
Definition: Session.h:577
void RemoveMarkers(TimePoint t)
Deletes markers for a waveform timestamp.
Definition: Session.h:535
void CreateAndAddInstrument(const std::string &driver, SCPITransport *transport, const std::string &nickname)
Creates a new instrument and adds it to the session.
Definition: Session.cpp:2783
std::map< PacketDecoder *, std::shared_ptr< PacketManager > > m_packetmgrs
Historical packet data from filters.
Definition: Session.h:487
double m_tArm
Time we last armed the global trigger.
Definition: Session.h:451
std::unique_ptr< std::thread > m_waveformThread
Processing thread for waveform data.
Definition: Session.h:439
std::string GetNextMarkerName()
Generate an automatic name for a newly created marker.
Definition: Session.h:518
std::mutex m_recentlyTriggeredScopeMutex
Mutex to synchronize access to m_recentlyTriggeredScopes.
Definition: Session.h:448
std::vector< std::shared_ptr< TriggerGroup > > m_triggerGroups
Trigger groups for syncing oscilloscopes.
Definition: Session.h:427
std::map< std::shared_ptr< FunctionGenerator >, std::shared_ptr< FunctionGeneratorState > > m_awgs
Function generator we are currently connected to.
Definition: Session.h:424
bool HasOnlineScopes()
Returns true if we have at least one scope that isn't offline.
Definition: Session.cpp:3134
int64_t GetFilterGraphExecTime()
Gets the last execution time of the filter graph.
Definition: Session.h:194
std::shared_ptr< FunctionGeneratorState > GetFunctionGeneratorState(std::shared_ptr< FunctionGenerator > awg)
Returns a pointer to the state for a function generator.
Definition: Session.h:168
bool SerializeSparseWaveform(SparseWaveformBase *wfm, const std::string &path)
Saves waveform sample data in the "sparsev1" file format.
Definition: Session.cpp:2422
bool LoadFromYaml(const YAML::Node &node, const std::string &dataDir, bool online)
Deserialize a YAML::Node (and associated data directory) to the current session.
Definition: Session.cpp:349
HistoryManager & GetHistory()
Get our history manager.
Definition: Session.h:263
ConfigWarningList m_warnings
Warnings generated by loading the current file.
Definition: Session.h:385
void StartWaveformThreadIfNeeded()
Starts the WaveformThread if we don't already have one.
Definition: Session.cpp:2774
HzClock m_waveformDownloadRate
Frequency at which we are pulling waveforms off of scopes.
Definition: Session.h:478
void RefreshAllFiltersNonblocking()
Queues a request to refresh all filters the next time we poll stuff.
Definition: Session.cpp:3275
std::shared_ptr< PacketManager > AddPacketFilter(PacketDecoder *filter)
Called when a new packet filter is created.
Definition: Session.cpp:3453
std::recursive_mutex m_triggerGroupMutex
Mutex controlling access to m_triggerGroups.
Definition: Session.h:433
void Clear()
Clears all session state and returns the object to an empty state.
Definition: Session.cpp:171
void RefreshDirtyFiltersNonblocking()
Queues a request to refresh dirty filters the next time we poll stuff.
Definition: Session.cpp:3285
std::shared_ptr< PowerSupplyState > GetPSUState(std::shared_ptr< SCPIPowerSupply > psu)
Returns a pointer to the state for a power supply.
Definition: Session.h:159
std::optional< TimePoint > GetHoveredPacketTimestamp()
Returns the timestamp of the protocol analyzer event that the mouse is over, if any.
Definition: Session.h:543
void AddInstrument(std::shared_ptr< Instrument > inst, bool createDialogs=true)
Adds a new instrument to the session.
Definition: Session.cpp:2855
bool LoadWaveformDataForFilters(int version, const YAML::Node &node, const std::string &dataDir)
Loads waveform data for filters that need to be preserved.
Definition: Session.cpp:443
std::shared_ptr< PacketManager > GetPacketManager(PacketDecoder *filter)
Returns a pointer to the existing packet manager for a protocol decode filter.
Definition: Session.h:177
std::vector< std::shared_ptr< Oscilloscope > > m_oscilloscopes
Oscilloscopes we are currently connected to.
Definition: Session.h:409
std::mutex m_lastFilterGraphRuntimeMutex
Mutex for controlling access to m_lastFilterGraphRuntimeStats.
Definition: Session.h:469
void AddMarker(Marker m)
Adds a marker.
Definition: Session.cpp:267
std::set< std::shared_ptr< Instrument > > GetInstruments()
Gets the set of all instruments we're connect to (regardless of type)
Definition: Session.cpp:3040
std::mutex m_dirtyChannelsMutex
Mutex controlling access to m_dirtyChannels.
Definition: Session.h:511
bool m_multiScope
True if we have >1 oscilloscope.
Definition: Session.h:493
FilterGraphExecutor m_graphExecutor
Context for filter graph evaluation.
Definition: Session.h:463
bool SerializeUniformWaveform(UniformWaveformBase *wfm, const std::string &path)
Saves waveform sample data in the "densev1" file format.
Definition: Session.cpp:2560
std::map< FlowGraphNode *, int64_t > GetFilterGraphRuntime()
Return the last filter graph runtime stats.
Definition: Session.h:337
bool CheckForPendingWaveforms()
Check if we have data available from all of our scopes.
Definition: Session.cpp:3144
void StopTrigger(bool all=false)
Stop the trigger for the session.
Definition: Session.cpp:3118
std::atomic< int64_t > m_lastFilterGraphExecTime
Time spent on the last filter graph execution.
Definition: Session.h:466
YAML::Node SerializeInstrumentConfiguration()
Serialize the configuration for all oscilloscopes.
Definition: Session.cpp:2067
std::shared_mutex & GetWaveformDataMutex()
Get the mutex controlling access to waveform data.
Definition: Session.h:257
void GarbageCollectTriggerGroups()
Remove trigger groups with no instruments in them.
Definition: Session.cpp:2620
std::vector< TimePoint > GetMarkerTimes()
Get a list of timestamps for markers.
Definition: Session.cpp:258
std::set< std::shared_ptr< SCPIInstrument > > GetSCPIInstruments()
Gets the set of all SCPI instruments we're connect to (regardless of type)
Definition: Session.cpp:2990
YAML::Node SerializeFilterConfiguration()
Serialize the configuration for all protocol decoders.
Definition: Session.cpp:2090
bool m_triggerArmed
Indicates trigger is armed (incoming waveforms are ignored if not armed)
Definition: Session.h:457
std::atomic< bool > m_shuttingDown
Flag for shutting down all scope threads when we exit.
Definition: Session.h:403
void ClearBackgroundThreads()
Terminate all background threads for instruments.
Definition: Session.cpp:126
MainWindow * m_mainWindow
Top level UI window.
Definition: Session.h:400
std::set< FlowGraphNode * > m_dirtyChannels
Set of dirty channels.
Definition: Session.h:508
std::vector< Marker > & GetMarkers(TimePoint t)
Get the markers for a given waveform timestamp.
Definition: Session.h:524
void RemoveInstrument(std::shared_ptr< Instrument > inst)
Removes an instrument from the session.
Definition: Session.cpp:2951
void OnMarkerChanged()
Called when a marker is added, removed, or modified.
Definition: Session.cpp:291
std::map< std::shared_ptr< Oscilloscope >, int64_t > m_scopeDeskewCal
Deskew correction coefficients for multi-scope.
Definition: Session.h:388
std::string m_setupNotes
Session notes about the experimental setup.
Definition: Session.h:294
void RemovePackets(TimePoint t)
Deletes packets from our packet managers for a waveform timestamp.
Definition: Session.cpp:3466
bool OnMemoryPressure(MemoryPressureLevel level, MemoryPressureType type, size_t requestedSize)
Handler for low memory conditions.
Definition: Session.cpp:3527
void DownloadWaveforms()
Pull the waveform data out of the queue and make it current.
Definition: Session.cpp:3167
Filter * GetReferenceFilter(const std::string &name)
Gets the reference instance of a given filter.
Definition: Session.h:570
bool m_triggerOneShot
If true, trigger is currently armed in single-shot mode.
Definition: Session.h:460
std::map< std::shared_ptr< Multimeter >, std::shared_ptr< MultimeterState > > m_meters
Multimeters we are currently connected to.
Definition: Session.h:415
YAML::Node SerializeMetadata()
Serializes metadata about the session / software stack.
Definition: Session.cpp:2109
std::set< std::shared_ptr< Oscilloscope > > m_recentlyTriggeredScopes
Scopes whose data is currently being processed for history.
Definition: Session.h:442
double GetWaveformDownloadRate()
Gets the average rate at which we are pulling waveforms off the scope, in Hz.
Definition: Session.h:206
std::map< std::shared_ptr< Load >, std::shared_ptr< LoadState > > m_loads
Loads we are currently connected to.
Definition: Session.h:418
std::string m_generalNotes
Session notes.
Definition: Session.h:289
bool LoadWaveformDataForScope(int version, const YAML::Node &node, std::shared_ptr< Oscilloscope > scope, const std::string &dataDir)
Loads waveform data for a single scope.
Definition: Session.cpp:527
std::mutex m_filterUpdatingMutex
Mutex for controlling access to filter graph.
Definition: Session.h:397
std::mutex & GetRasterizedWaveformMutex()
Get the mutex controlling access to rasterized waveforms.
Definition: Session.h:278
std::mutex m_packetMgrMutex
Mutex for controlling access to m_packetmgrs.
Definition: Session.h:484
std::shared_ptr< TriggerGroup > GetTriggerGroupForFilter(PausableFilter *filter)
Gets the trigger group that contains a specified filter.
Definition: Session.cpp:2714
std::map< std::string, std::vector< std::string > > m_driverNamesByType
Map of "type" to drivername[].
Definition: Session.h:592
std::mutex m_rasterizedWaveformMutex
Mutex for controlling access to rasterized waveforms.
Definition: Session.h:490
size_t GetInstrumentCount()
Get the number of instruments we're connected to (regardless of type)
Definition: Session.h:246
std::set< FlowGraphNode * > GetAllGraphNodes()
Gets all of our graph nodes (filters plus instrument channels)
Definition: Session.cpp:3299
int m_fileLoadVersion
Version of the file being loaded.
Definition: Session.h:382
std::shared_ptr< TriggerGroup > m_trendTriggerGroup
Trigger group dedicated to trend filters.
Definition: Session.h:430
void MarkChannelDirty(InstrumentChannel *chan)
Flags a single channel as dirty (updated outside of a global trigger event)
Definition: Session.cpp:3403
std::shared_ptr< TriggerGroup > GetTriggerGroupForScope(std::shared_ptr< Oscilloscope > scope)
Gets the trigger group that contains a specified scope.
Definition: Session.cpp:2691
void AddMultimeterDialog(std::shared_ptr< SCPIMultimeter > meter)
Adds a multimeter dialog to the session.
Definition: Session.cpp:2980
std::map< FlowGraphNode *, int64_t > m_lastFilterGraphRuntimeStats
Performance stats from last graph execution.
Definition: Session.h:472
std::map< std::shared_ptr< PowerSupply >, std::shared_ptr< PowerSupplyState > > m_psus
Power supplies we are currently connected to.
Definition: Session.h:412
const std::vector< std::shared_ptr< Oscilloscope > > GetScopes()
Get the set of scopes we're currently connected to.
Definition: Session.h:215
void UpdatePacketManagers(const std::set< FlowGraphNode * > &nodes)
Update all of the packet managers when new data arrives.
Definition: Session.cpp:3429
int m_nextMarkerNum
Number for next autogenerated waveform name.
Definition: Session.h:502
int64_t GetLastWaveformRenderTime()
Gets the last run time of the waveform rendering shaders.
Definition: Session.h:200
IDTable m_idtable
ID mapping used for serialization.
Definition: Session.h:284
bool CheckForWaveforms(vk::raii::CommandBuffer &cmdbuf)
Check if new waveform data has arrived.
Definition: Session.cpp:3210
std::map< TimePoint, std::vector< Marker > > m_markers
Map of waveform timestamps to markers.
Definition: Session.h:499
const std::vector< std::shared_ptr< BERT > > GetBERTs()
Get the set of BERTs we're currently connected to.
Definition: Session.h:224
void ArmTrigger(TriggerGroup::TriggerType type, bool all=false)
Arms the trigger for all trigger groups.
Definition: Session.cpp:3071
std::set< std::shared_ptr< TriggerGroup > > m_recentlyTriggeredGroups
Groups whose data is currently being processed.
Definition: Session.h:445
HistoryManager m_history
Historical waveform data.
Definition: Session.h:481
std::mutex m_scopeMutex
Mutex for controlling access to scope vectors.
Definition: Session.h:391
bool IsSecondaryOfMultiScopeGroup(std::shared_ptr< Oscilloscope > scope)
Check if a scope is a secondary within a multiscope group.
Definition: Session.cpp:2670
std::map< std::shared_ptr< Instrument >, std::shared_ptr< InstrumentConnectionState > > m_instrumentStates
Worker threads and other bookkeeping metadata for instruments.
Definition: Session.h:436
std::shared_ptr< BERTState > GetBERTState(std::shared_ptr< BERT > bert)
Returns a pointer to the state for a BERT.
Definition: Session.h:150
void DestroyReferenceFilters()
Destroys the reference filters.
Definition: Session.cpp:3517
bool m_modifiedSinceLastSave
True if the session has been modified since last time it was saved.
Definition: Session.h:406
std::string GetRegisteredTypeOfDriver(const std::string &drivername)
Performs an exhaustive search of the driver list to see which type this instrument is.
Definition: Session.cpp:891
void ClearSweeps()
Clear state on all of our filters.
Definition: Session.cpp:3412
std::shared_mutex m_waveformDataMutex
Mutex for controlling access to waveform data.
Definition: Session.h:394
bool IsPrimaryOfMultiScopeGroup(std::shared_ptr< Oscilloscope > scope)
Check if a scope is the primary of a group containing at least one other scope.
Definition: Session.cpp:2656
std::mutex m_perfClockMutex
Mutex for controlling access to performance counters.
Definition: Session.h:475
double m_tPrimaryTrigger
Time that the primary scope triggered (in multi-scope setups)
Definition: Session.h:454
void CreateReferenceFilters()
Creates one filter of each known type to use as a reference for what inputs are legal to use to a new...
Definition: Session.cpp:3494
bool RefreshDirtyFilters()
Refresh dirty filters (and anything in their downstream influence cone)
Definition: Session.cpp:3347
Base class for waveforms with nonuniform sample rate.
Definition: Waveform.h:266
A timestamp, measured in seconds + femtoseconds.
Definition: Marker.h:42
Base class for waveforms with data sampled at uniform intervals.
Definition: Waveform.h:337
A WaveformArea is a plot that displays one or more OscilloscopeChannel's worth of data.
Definition: WaveformArea.h:446