mirror of
https://github.com/gwm17/Daqromancy.git
synced 2025-10-23 14:25:51 -04:00
Compare commits
No commits in common. "275c19a8b1c8e1d8087c03aab7894f51b34ea3b4" and "53c6ec5833043b645e9691872b9787bbf50e5158" have entirely different histories.
275c19a8b1
...
53c6ec5833
|
@ -31,7 +31,7 @@ namespace YAML {
|
|||
|
||||
args.type = (CAEN_DGTZ_ConnectionType) node["ConnectionType"].as<int>();
|
||||
args.linkNumber = node["LinkNumber"].as<int>();
|
||||
args.conetNode = node["CONETNode"].as<int>();
|
||||
args.conetNode = node["ConetNode"].as<int>();
|
||||
args.vmeAddress = node["VMEAddress"].as<uint32_t>();
|
||||
args.handle = node["Handle"].as<int>();
|
||||
args.model = (CAEN_DGTZ_BoardModel_t) node["Model"].as<int>();
|
||||
|
|
|
@ -79,13 +79,13 @@ namespace Daqromancy {
|
|||
|
||||
//For iterator loops, need begin()/end() idiom
|
||||
|
||||
typename std::deque<T>::iterator begin()
|
||||
std::deque<T>::iterator begin()
|
||||
{
|
||||
std::scoped_lock<std::mutex> guard(m_queueMutex);
|
||||
return m_queue.begin();
|
||||
}
|
||||
|
||||
typename std::deque<T>::iterator end()
|
||||
std::deque<T>::iterator end()
|
||||
{
|
||||
std::scoped_lock<std::mutex> guard(m_queueMutex);
|
||||
return m_queue.end();
|
||||
|
|
|
@ -63,13 +63,14 @@ namespace Daqromancy {
|
|||
m_args.model = CAEN_DGTZ_BoardModel_t::CAEN_DGTZ_V1740;
|
||||
else
|
||||
m_args.model = CAEN_DGTZ_BoardModel_t::CAEN_DGTZ_DT5720;
|
||||
m_args.name = info.ModelName + std::string("_") + std::to_string(info.SerialNumber);
|
||||
m_args.name = info.ModelName + std::to_string(info.SerialNumber);
|
||||
m_args.firmware = CAEN_DGTZ_DPPFirmware_PHA;
|
||||
m_args.channels = info.Channels;
|
||||
|
||||
m_channelParams.resize(info.Channels);
|
||||
m_eventCountsPerChannel = new uint32_t[info.Channels];
|
||||
m_eventData = new CAEN_DGTZ_DPP_PHA_Event_t*[info.Channels];
|
||||
m_waveData = new CAEN_DGTZ_DPP_PHA_Waveforms_t*[info.Channels];
|
||||
|
||||
for (int i = 0; i < info.Channels; i++)
|
||||
{
|
||||
|
@ -276,14 +277,16 @@ namespace Daqromancy {
|
|||
m_args.status |= CAEN_DGTZ_MallocReadoutBuffer(m_args.handle, &m_lowBuffer, &m_lowBufferSize);
|
||||
//void casts are soooo bad .... but required by CAEN API
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPEvents(m_args.handle, (void**)(m_eventData), &m_eventBufferSize);
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPWaveforms(m_args.handle, (void**)(&m_waveData), &m_waveBufferSize);
|
||||
for(int channel=0; channel<m_internalData.Channels; channel++)
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPWaveforms(m_args.handle, (void**)(&m_waveData[channel]), &m_waveBufferSize);
|
||||
}
|
||||
|
||||
void DigitizerPHA::DeallocateMemory()
|
||||
{
|
||||
m_args.status |= CAEN_DGTZ_FreeReadoutBuffer(&m_lowBuffer);
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPEvents(m_args.handle, (void**)(m_eventData));
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPWaveforms(m_args.handle, (void*)(m_waveData));
|
||||
for(int i=0; i<m_internalData.Channels; i++)
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPWaveforms(m_args.handle, (void*)(m_waveData[i]));
|
||||
}
|
||||
|
||||
void DigitizerPHA::ReadData(std::vector<DYData>& buffer)
|
||||
|
@ -297,7 +300,7 @@ namespace Daqromancy {
|
|||
return;
|
||||
}
|
||||
|
||||
m_args.status |= CAEN_DGTZ_GetDPPEvents(m_args.handle, m_lowBuffer, m_lowBufferSize, (void**)(m_eventData), m_eventCountsPerChannel);
|
||||
m_args.status |= CAEN_DGTZ_GetDPPEvents(m_args.handle, m_lowBuffer, m_lowBufferSize, (void**)(&m_eventData), m_eventCountsPerChannel);
|
||||
size_t waveSize;
|
||||
DYData tempData;
|
||||
tempData.board = m_args.handle;
|
||||
|
@ -315,15 +318,15 @@ namespace Daqromancy {
|
|||
if(m_digitizerParams.dppAcqMode != CAEN_DGTZ_DPP_ACQ_MODE_List)
|
||||
{
|
||||
CAEN_DGTZ_DecodeDPPWaveforms(m_args.handle, (void*)&(m_eventData[i][j]), m_waveData);
|
||||
tempData.waveSize = m_waveData->Ns;
|
||||
waveSize = m_waveData->Ns;
|
||||
tempData.waveSize = m_waveData[i]->Ns;
|
||||
waveSize = m_waveData[i]->Ns;
|
||||
if(waveSize != 0)
|
||||
{
|
||||
//Copy the data to our vectors PHA supports 2 analog traces and 2 digital traces
|
||||
tempData.trace1Samples.assign(m_waveData->Trace1, m_waveData->Trace1 + waveSize);
|
||||
tempData.trace2Samples.assign(m_waveData->Trace2, m_waveData->Trace2 + waveSize); //This is all zero if in single analog trace mode
|
||||
tempData.digitalTrace1Samples.assign(m_waveData->DTrace1, m_waveData->DTrace1 + waveSize);
|
||||
tempData.digitalTrace2Samples.assign(m_waveData->DTrace2, m_waveData->DTrace2 + waveSize);
|
||||
tempData.trace1Samples.assign(m_waveData[i]->Trace1, m_waveData[i]->Trace1 + waveSize);
|
||||
tempData.trace2Samples.assign(m_waveData[i]->Trace2, m_waveData[i]->Trace2 + waveSize); //This is all zero if in single analog trace mode
|
||||
tempData.digitalTrace1Samples.assign(m_waveData[i]->DTrace1, m_waveData[i]->DTrace1 + waveSize);
|
||||
tempData.digitalTrace2Samples.assign(m_waveData[i]->DTrace2, m_waveData[i]->DTrace2 + waveSize);
|
||||
}
|
||||
}
|
||||
buffer.push_back(tempData);
|
||||
|
@ -355,13 +358,14 @@ namespace Daqromancy {
|
|||
m_args.model = CAEN_DGTZ_BoardModel_t::CAEN_DGTZ_V1740;
|
||||
else
|
||||
m_args.model = CAEN_DGTZ_BoardModel_t::CAEN_DGTZ_DT5720;
|
||||
m_args.name = info.ModelName + std::string(" ") + std::to_string(info.SerialNumber);
|
||||
m_args.name = info.ModelName + std::to_string(info.SerialNumber);
|
||||
m_args.firmware = CAEN_DGTZ_DPPFirmware_PSD;
|
||||
m_args.channels = info.Channels;
|
||||
|
||||
m_channelParams.resize(info.Channels);
|
||||
m_eventCountsPerChannel = new uint32_t[info.Channels];
|
||||
m_eventData = new CAEN_DGTZ_DPP_PSD_Event_t*[info.Channels];
|
||||
m_waveData = new CAEN_DGTZ_DPP_PSD_Waveforms_t*[info.Channels];
|
||||
LoadDigitizerParameters();
|
||||
LoadChannelParameters();
|
||||
//Must load default parameters here to generate a buffer
|
||||
|
@ -556,14 +560,16 @@ namespace Daqromancy {
|
|||
m_args.status |= CAEN_DGTZ_MallocReadoutBuffer(m_args.handle, &m_lowBuffer, &m_lowBufferSize);
|
||||
//void casts are soooo bad .... but required by CAEN API
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPEvents(m_args.handle, (void**)(m_eventData), &m_eventBufferSize);
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPWaveforms(m_args.handle, (void**)(&m_waveData), &m_waveBufferSize);
|
||||
for(int channel=0; channel<m_internalData.Channels; channel++)
|
||||
m_args.status |= CAEN_DGTZ_MallocDPPWaveforms(m_args.handle, (void**)(&m_waveData[channel]), &m_waveBufferSize);
|
||||
}
|
||||
|
||||
void DigitizerPSD::DeallocateMemory()
|
||||
{
|
||||
m_args.status |= CAEN_DGTZ_FreeReadoutBuffer(&m_lowBuffer);
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPEvents(m_args.handle, (void**)(m_eventData));
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPWaveforms(m_args.handle, (void*)(m_waveData));
|
||||
for(int i=0; i<m_internalData.Channels; i++)
|
||||
m_args.status |= CAEN_DGTZ_FreeDPPWaveforms(m_args.handle, (void*)(m_waveData[i]));
|
||||
}
|
||||
|
||||
void DigitizerPSD::ReadData(std::vector<DYData>& buffer)
|
||||
|
@ -577,7 +583,7 @@ namespace Daqromancy {
|
|||
return;
|
||||
}
|
||||
|
||||
m_args.status |= CAEN_DGTZ_GetDPPEvents(m_args.handle, m_lowBuffer, m_lowBufferSize, (void**)(m_eventData), m_eventCountsPerChannel);
|
||||
m_args.status |= CAEN_DGTZ_GetDPPEvents(m_args.handle, m_lowBuffer, m_lowBufferSize, (void**)(&m_eventData), m_eventCountsPerChannel);
|
||||
size_t waveSize;
|
||||
DYData tempData;
|
||||
tempData.board = m_args.handle;
|
||||
|
@ -596,15 +602,15 @@ namespace Daqromancy {
|
|||
if(m_digitizerParams.dppAcqMode != CAEN_DGTZ_DPP_ACQ_MODE_List)
|
||||
{
|
||||
CAEN_DGTZ_DecodeDPPWaveforms(m_args.handle, (void*)&(m_eventData[i][j]), m_waveData);
|
||||
tempData.waveSize = m_waveData->Ns;
|
||||
waveSize = m_waveData->Ns;
|
||||
tempData.waveSize = m_waveData[i]->Ns;
|
||||
waveSize = m_waveData[i]->Ns;
|
||||
if(tempData.waveSize != 0)
|
||||
{
|
||||
//Copy the data to our vectors PHA supports 2 analog traces and 2 digital traces
|
||||
tempData.trace1Samples.assign(m_waveData->Trace1, m_waveData->Trace1 + waveSize);
|
||||
tempData.trace2Samples.assign(m_waveData->Trace2, m_waveData->Trace2 + waveSize); //This is all zero if in single analog trace mode
|
||||
tempData.digitalTrace1Samples.assign(m_waveData->DTrace1, m_waveData->DTrace1 + waveSize);
|
||||
tempData.digitalTrace2Samples.assign(m_waveData->DTrace2, m_waveData->DTrace2 + waveSize);
|
||||
tempData.trace1Samples.assign(m_waveData[i]->Trace1, m_waveData[i]->Trace1 + waveSize);
|
||||
tempData.trace2Samples.assign(m_waveData[i]->Trace2, m_waveData[i]->Trace2 + waveSize); //This is all zero if in single analog trace mode
|
||||
tempData.digitalTrace1Samples.assign(m_waveData[i]->DTrace1, m_waveData[i]->DTrace1 + waveSize);
|
||||
tempData.digitalTrace2Samples.assign(m_waveData[i]->DTrace2, m_waveData[i]->DTrace2 + waveSize);
|
||||
}
|
||||
}
|
||||
buffer.push_back(tempData);
|
||||
|
|
|
@ -179,7 +179,7 @@ namespace Daqromancy {
|
|||
|
||||
//CAEN required data storage, does not interface to other parts of the program
|
||||
CAEN_DGTZ_DPP_PHA_Event_t** m_eventData;
|
||||
CAEN_DGTZ_DPP_PHA_Waveforms_t* m_waveData;
|
||||
CAEN_DGTZ_DPP_PHA_Waveforms_t** m_waveData;
|
||||
CAEN_DGTZ_DPP_PHA_Params_t m_caenParams;
|
||||
|
||||
std::vector<PHAParameters> m_channelParams;
|
||||
|
@ -218,7 +218,7 @@ namespace Daqromancy {
|
|||
|
||||
//CAEN required data storage, does not interface to other parts of the program
|
||||
CAEN_DGTZ_DPP_PSD_Event_t** m_eventData;
|
||||
CAEN_DGTZ_DPP_PSD_Waveforms_t* m_waveData;
|
||||
CAEN_DGTZ_DPP_PSD_Waveforms_t** m_waveData;
|
||||
CAEN_DGTZ_DPP_PSD_Params_t m_caenParams;
|
||||
|
||||
std::vector<PSDParameters> m_channelParams;
|
||||
|
|
|
@ -64,7 +64,7 @@ namespace Daqromancy {
|
|||
switch (mode)
|
||||
{
|
||||
case DPPAcqMode::List: modeIn = CAEN_DGTZ_DPP_ACQ_MODE_List; break;
|
||||
case DPPAcqMode::Waves: modeIn = CAEN_DGTZ_DPP_ACQ_MODE_Mixed; break;
|
||||
case DPPAcqMode::Waves: modeIn = CAEN_DGTZ_DPP_ACQ_MODE_Oscilloscope; break;
|
||||
case DPPAcqMode::None: DY_WARN("Attempted to set DPPAcqMode::None!"); return;
|
||||
}
|
||||
|
||||
|
|
|
@ -242,17 +242,17 @@ namespace Daqromancy {
|
|||
//Option of dual analog, which types (digital probe 2 is always trigger for PHA)
|
||||
struct PHAWaveParameters
|
||||
{
|
||||
CAEN_DGTZ_DPP_VirtualProbe_t isDual = CAEN_DGTZ_DPP_VIRTUALPROBE_DUAL; //Default to a single analog trace
|
||||
PHAVirtualProbe1Options analogProbe1 = PHAVirtualProbe1Options::PHAVP1_Delta2; //Main analog trace defaults to delta2;
|
||||
PHAVirtualProbe2Options analogProbe2 = PHAVirtualProbe2Options::PHAVP2_Input; //Default val; in default config wont be displayed
|
||||
PHADigitalProbe1Options digitalProbe1 = PHADigitalProbe1Options::PHADP_Peaking; //Idk guess this is good default
|
||||
CAEN_DGTZ_DPP_VirtualProbe_t isDual = CAEN_DGTZ_DPP_VIRTUALPROBE_SINGLE; //Default to a single analog trace
|
||||
PHAVirtualProbe1Options analogProbe1 = PHAVirtualProbe1Options::PHAVP1_Input; //Main analog trace defaults to input signal;
|
||||
PHAVirtualProbe2Options analogProbe2 = PHAVirtualProbe2Options::PHAVP2_None; //Default val; in default config wont be displayed
|
||||
PHADigitalProbe1Options digitalProbe1 = PHADigitalProbe1Options::PHADP_TriggerWindow; //Idk guess this is good default
|
||||
};
|
||||
|
||||
struct PSDWaveParameters
|
||||
{
|
||||
CAEN_DGTZ_DPP_VirtualProbe_t isDual = CAEN_DGTZ_DPP_VIRTUALPROBE_DUAL; //Default to a single analog trace
|
||||
CAEN_DGTZ_DPP_VirtualProbe_t isDual = CAEN_DGTZ_DPP_VIRTUALPROBE_SINGLE; //Default to a single analog trace
|
||||
PSDVirtualProbe1Options analogProbe1 = PSDVirtualProbe1Options::PSDVP1_Input; //Main trace defaults to input
|
||||
PSDVirtualProbe2Options analogProbe2 = PSDVirtualProbe2Options::PSDVP2_Baseline; //Defaults to off
|
||||
PSDVirtualProbe2Options analogProbe2 = PSDVirtualProbe2Options::PSDVP2_None; //Defaults to off
|
||||
PSDDigitalProbe1Options digitalProbe1 = PSDDigitalProbe1Options::PSDDP1_Gate; //Defaults to long gate
|
||||
PSDDigitalProbe2Options digitalProbe2 = PSDDigitalProbe2Options::PSDDP2_GateShort; //Defaults to short gate
|
||||
};
|
||||
|
|
|
@ -231,7 +231,7 @@ namespace Daqromancy {
|
|||
AcqDPPModeEvent e;
|
||||
m_eventCallback(e);
|
||||
|
||||
m_scopePanel = new ScopePanel(m_project);
|
||||
m_scopePanel = new ScopePanel(m_digiPanels.size());
|
||||
}
|
||||
ImGui::EndCombo();
|
||||
}
|
||||
|
|
|
@ -1,16 +1,18 @@
|
|||
#include "ScopePanel.h"
|
||||
|
||||
#include "DAQ/DigitizerDefs.h"
|
||||
|
||||
#include "imgui.h"
|
||||
#include "implot.h"
|
||||
|
||||
namespace Daqromancy {
|
||||
|
||||
ScopePanel::ScopePanel(const DYProject::Ref& project) :
|
||||
m_dataReady(false), m_selectedBoard(-1), m_selectedChannel(-1), m_selectedSamplingPeriod(0.0), m_project(project)
|
||||
ScopePanel::ScopePanel(int nboards) :
|
||||
m_dataReady(false), m_selectedBoard(0), m_selectedChannel(0), m_maxNumBoards(nboards)
|
||||
{
|
||||
m_dataHandle = DataDistributor::Connect();
|
||||
for (int i = 0; i < nboards; i++)
|
||||
m_boardListForImGui.push_back(fmt::format("{0}", i));
|
||||
for (int i = 0; i < 16; i++) //bad hardcode, fix later
|
||||
m_channelListForImGui.push_back(fmt::format("{0}", i));
|
||||
}
|
||||
|
||||
ScopePanel::~ScopePanel()
|
||||
|
@ -29,7 +31,9 @@ namespace Daqromancy {
|
|||
if (hit.board == m_selectedBoard && hit.channel == m_selectedChannel)
|
||||
{
|
||||
m_selectedHit = hit;
|
||||
m_selectedSamplingPeriod = GetSamplingPeriod(m_project->GetDigitizerArgs(m_selectedBoard).model);
|
||||
m_selectedXAxis.clear();
|
||||
for (int i = 0; i < hit.waveSize; i++)
|
||||
m_selectedXAxis.push_back(i);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -38,65 +42,45 @@ namespace Daqromancy {
|
|||
|
||||
void ScopePanel::OnImGuiRender()
|
||||
{
|
||||
static std::string selectedBoardString = "";
|
||||
static std::string selectedChannelString = "";
|
||||
static int availChannels = -1;
|
||||
static std::string analog1 = "##analog1";
|
||||
static std::string analog2 = "##analog2";
|
||||
static std::string digital1 = "##digital1";
|
||||
static std::string digital2 = "##digital2";
|
||||
static std::string selectedBoardString = fmt::format("{0}", m_selectedBoard);
|
||||
static std::string selectedChannelString = fmt::format("{0}", m_selectedChannel);
|
||||
|
||||
if (ImGui::Begin("Oscilloscope"))
|
||||
{
|
||||
if (ImGui::BeginCombo("Board", selectedBoardString.c_str()))
|
||||
{
|
||||
for (const auto& boardArgs : m_project->GetDigitizerArgsList())
|
||||
for (int board=0; board<m_maxNumBoards; board++)
|
||||
{
|
||||
if (ImGui::Selectable(boardArgs.name.c_str(), boardArgs.handle == m_selectedBoard))
|
||||
if (ImGui::Selectable(m_boardListForImGui[board].c_str(), board == m_selectedBoard))
|
||||
{
|
||||
m_selectedBoard = boardArgs.handle;
|
||||
availChannels = boardArgs.channels;
|
||||
m_selectedBoard = board;
|
||||
selectedBoardString = fmt::format("{0}", m_selectedBoard);
|
||||
if (boardArgs.firmware == CAEN_DGTZ_DPPFirmware_PHA)
|
||||
{
|
||||
const auto& phaParams = m_project->GetPHAWaveParameters(boardArgs.handle);
|
||||
analog1 = PHAVirtualProbe1ToString(phaParams.analogProbe1);
|
||||
analog2 = PHAVirtualProbe2ToString(phaParams.analogProbe2);
|
||||
digital1 = PHADigitalProbeToString(phaParams.digitalProbe1);
|
||||
digital2 = "Trigger";
|
||||
}
|
||||
else if (boardArgs.firmware == CAEN_DGTZ_DPPFirmware_PSD)
|
||||
{
|
||||
const auto& psdParams = m_project->GetPSDWaveParameters(boardArgs.handle);
|
||||
analog1 = PSDVirtualProbe1ToString(psdParams.analogProbe1);
|
||||
analog2 = PSDVirtualProbe2ToString(psdParams.analogProbe2);
|
||||
digital1 = PSDDigitalProbe1ToString(psdParams.digitalProbe1);
|
||||
digital2 = PSDDigitalProbe2ToString(psdParams.digitalProbe2);
|
||||
}
|
||||
m_selectedXAxis.clear();
|
||||
}
|
||||
}
|
||||
ImGui::EndCombo();
|
||||
}
|
||||
if (ImGui::BeginCombo("Channel", selectedChannelString.c_str()))
|
||||
{
|
||||
for (int channel = 0; channel < availChannels; channel++)
|
||||
for (int channel = 0; channel < 16; channel++) //hardcoded bad, fix later
|
||||
{
|
||||
if (ImGui::Selectable(fmt::format("{0}", channel).c_str(), channel == m_selectedChannel))
|
||||
if (ImGui::Selectable(m_channelListForImGui[channel].c_str(), channel == m_selectedChannel))
|
||||
{
|
||||
m_selectedChannel = channel;
|
||||
selectedChannelString = fmt::format("{0}", m_selectedChannel);
|
||||
m_selectedXAxis.clear();
|
||||
}
|
||||
}
|
||||
ImGui::EndCombo();
|
||||
}
|
||||
if (ImPlot::BeginPlot("ScopeView", ImVec2(-1,-1)))
|
||||
{
|
||||
if (m_selectedHit.waveSize != 0)
|
||||
if (m_selectedXAxis.size() != 0)
|
||||
{
|
||||
ImPlot::PlotLine(analog1.c_str(), (ImU16*)m_selectedHit.trace1Samples.data(), m_selectedHit.trace1Samples.size(), m_selectedSamplingPeriod);
|
||||
ImPlot::PlotLine(analog2.c_str(), (ImU16*)m_selectedHit.trace2Samples.data(), m_selectedHit.trace2Samples.size(), m_selectedSamplingPeriod);
|
||||
ImPlot::PlotLine(digital1.c_str(), (ImU8*)m_selectedHit.digitalTrace1Samples.data(), m_selectedHit.digitalTrace1Samples.size(), m_selectedSamplingPeriod);
|
||||
ImPlot::PlotLine(digital2.c_str(), (ImU8*)m_selectedHit.digitalTrace2Samples.data(), m_selectedHit.digitalTrace2Samples.size(), m_selectedSamplingPeriod);
|
||||
ImPlot::PlotLine("AnalogProbe1", (ImU16*)m_selectedXAxis.data(), (ImU16*)m_selectedHit.trace1Samples.data(), m_selectedXAxis.size());
|
||||
ImPlot::PlotLine("AnalogProbe2", (ImU16*)m_selectedXAxis.data(), (ImU16*)m_selectedHit.trace2Samples.data(), m_selectedXAxis.size());
|
||||
ImPlot::PlotLine("DigitialProbe1", (ImU16*)m_selectedXAxis.data(), (ImU16*)m_selectedHit.digitalTrace1Samples.data(), m_selectedXAxis.size());
|
||||
ImPlot::PlotLine("DigitialProbe2", (ImU16*)m_selectedXAxis.data(), (ImU16*)m_selectedHit.digitalTrace2Samples.data(), m_selectedXAxis.size());
|
||||
}
|
||||
ImPlot::EndPlot();
|
||||
}
|
||||
|
|
|
@ -3,31 +3,32 @@
|
|||
|
||||
#include "DAQ/DigitizerDefs.h"
|
||||
#include "Core/DataDistributor.h"
|
||||
#include "Core/DYProject.h"
|
||||
|
||||
namespace Daqromancy {
|
||||
|
||||
class ScopePanel
|
||||
{
|
||||
public:
|
||||
ScopePanel(const DYProject::Ref& project);
|
||||
ScopePanel(int nboards);
|
||||
~ScopePanel();
|
||||
|
||||
void OnUpdate();
|
||||
void OnImGuiRender();
|
||||
|
||||
private:
|
||||
//uint64_t m_consumerID;
|
||||
DistributorClient m_dataHandle;
|
||||
std::vector<DYData> m_buffer; //Buffered data retrieved from ring
|
||||
DYData m_selectedHit; //Hit associated with selected board/channel
|
||||
std::vector<int16_t> m_selectedXAxis; //X data is not given by DAQ, has to be made based on number of wave samples
|
||||
|
||||
bool m_dataReady;
|
||||
int m_selectedBoard;
|
||||
int m_selectedChannel;
|
||||
double m_selectedSamplingPeriod;
|
||||
int m_maxNumBoards;
|
||||
|
||||
|
||||
DYProject::Ref m_project;
|
||||
std::vector<std::string> m_boardListForImGui;
|
||||
std::vector<std::string> m_channelListForImGui;
|
||||
};
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user