killed many bugs
This commit is contained in:
parent
c51bd7e662
commit
674f3bdd77
|
@ -434,7 +434,7 @@ inline void Data::DecodeBuffer(bool fastDecode, int verbose){
|
||||||
///printf("nw : %d ,x 4 = %d, nByte : %d \n", nw, 4*nw, nByte);
|
///printf("nw : %d ,x 4 = %d, nByte : %d \n", nw, 4*nw, nByte);
|
||||||
}while(4*nw < nByte);
|
}while(4*nw < nByte);
|
||||||
|
|
||||||
///Calculate trigger rate and first and last Timestamp
|
///^===================Calculate trigger rate and first and last Timestamp
|
||||||
for(int ch = 0; ch < MaxNChannels; ch++){
|
for(int ch = 0; ch < MaxNChannels; ch++){
|
||||||
if( ch > numInputCh ) continue;
|
if( ch > numInputCh ) continue;
|
||||||
|
|
||||||
|
@ -442,6 +442,8 @@ inline void Data::DecodeBuffer(bool fastDecode, int verbose){
|
||||||
// printf("%s | ch %d | %d %d \n", __func__, ch, LoopIndex[ch], DataIndex[ch]);
|
// printf("%s | ch %d | %d %d \n", __func__, ch, LoopIndex[ch], DataIndex[ch]);
|
||||||
IsNotRollOverFakeAgg = true;
|
IsNotRollOverFakeAgg = true;
|
||||||
}else{
|
}else{
|
||||||
|
TriggerRate[ch] = 0;
|
||||||
|
NonPileUpRate[ch] = 0;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -226,9 +226,9 @@ int Digitizer::CloseDigitizer(){
|
||||||
|
|
||||||
if( !isConnected ) return 0;
|
if( !isConnected ) return 0;
|
||||||
isConnected = false;
|
isConnected = false;
|
||||||
|
ret = CAEN_DGTZ_SWStopAcquisition(handle);
|
||||||
printf("-------- Closing Digtizer Board : %d Port : %d \n", boardID, portID);
|
printf("-------- Closing Digtizer Board : %d Port : %d \n", boardID, portID);
|
||||||
printf(" Model %s with handle %d using %s\n", BoardInfo.ModelName, handle, LinkType == CAEN_DGTZ_USB ? "USB" : "Optical Link");
|
printf(" Model %s with handle %d using %s\n", BoardInfo.ModelName, handle, LinkType == CAEN_DGTZ_USB ? "USB" : "Optical Link");
|
||||||
ret = CAEN_DGTZ_SWStopAcquisition(handle);
|
|
||||||
ret |= CAEN_DGTZ_CloseDigitizer(handle);
|
ret |= CAEN_DGTZ_CloseDigitizer(handle);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -388,36 +388,23 @@ int Digitizer::ProgramBoard_QDC(){
|
||||||
|
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
WriteRegister(DPP::QDC::RecordLength, 6000/16, -1);
|
WriteRegister(DPP::QDC::NumberEventsPerAggregate, 0x100, -1);
|
||||||
|
WriteRegister(DPP::QDC::RecordLength, 4000/16, -1);
|
||||||
|
WriteRegister(DPP::QDC::PreTrigger, 1000/16, -1);
|
||||||
|
|
||||||
WriteRegister(DPP::QDC::GateWidth, 100/16, -1);
|
WriteRegister(DPP::QDC::GateWidth, 100/16, -1);
|
||||||
WriteRegister(DPP::QDC::GateOffset, 0, -1);
|
WriteRegister(DPP::QDC::GateOffset, 0, -1);
|
||||||
WriteRegister(DPP::QDC::FixedBaseline, 0, -1);
|
WriteRegister(DPP::QDC::FixedBaseline, 0, -1);
|
||||||
WriteRegister(DPP::QDC::PreTrigger, 1000/16, -1);
|
|
||||||
//WriteRegister(DPP::QDC::DPPAlgorithmControl, 0x300112); // with test pulse
|
//WriteRegister(DPP::QDC::DPPAlgorithmControl, 0x300112); // with test pulse
|
||||||
WriteRegister(DPP::QDC::DPPAlgorithmControl, 0x300102); // No test pulse
|
WriteRegister(DPP::QDC::DPPAlgorithmControl, 0x300102); // No test pulse
|
||||||
|
|
||||||
WriteRegister(DPP::QDC::TriggerHoldOffWidth, 100/16, -1);
|
WriteRegister(DPP::QDC::TriggerHoldOffWidth, 100/16, -1);
|
||||||
WriteRegister(DPP::QDC::TRGOUTWidth, 100/16, -1);
|
WriteRegister(DPP::QDC::TRGOUTWidth, 100/16, -1);
|
||||||
//WriteRegister(DPP::QDC::OverThresholdWidth, 100/16, -1);
|
//WriteRegister(DPP::QDC::OverThresholdWidth, 100/16, -1);
|
||||||
//WriteRegister(DPP::QDC::DCOffset, 100/16, -1);
|
|
||||||
WriteRegister(DPP::QDC::SubChannelMask, 0xFF, -1);
|
WriteRegister(DPP::QDC::SubChannelMask, 0xFF, -1);
|
||||||
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x0, 0xAAAA);
|
WriteRegister(DPP::QDC::DCOffset, 0xAAAA, -1);
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x1, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x2, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x3, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x4, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x5, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x6, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x7, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x8, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0x9, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xA, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xB, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xC, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xD, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xE, 0xAAAA);
|
|
||||||
ret |= CAEN_DGTZ_SetChannelDCOffset(handle, 0xF, 0xAAAA);
|
|
||||||
|
|
||||||
|
|
||||||
WriteRegister(DPP::QDC::TriggerThreshold_sub0, 100, -1);
|
WriteRegister(DPP::QDC::TriggerThreshold_sub0, 100, -1);
|
||||||
WriteRegister(DPP::QDC::TriggerThreshold_sub1, 100, -1);
|
WriteRegister(DPP::QDC::TriggerThreshold_sub1, 100, -1);
|
||||||
|
@ -430,7 +417,6 @@ int Digitizer::ProgramBoard_QDC(){
|
||||||
|
|
||||||
WriteRegister(DPP::BoardConfiguration, 0xC0110);
|
WriteRegister(DPP::BoardConfiguration, 0xC0110);
|
||||||
WriteRegister(DPP::AggregateOrganization, 0x0);
|
WriteRegister(DPP::AggregateOrganization, 0x0);
|
||||||
WriteRegister(DPP::QDC::NumberEventsPerAggregate, 0x100);
|
|
||||||
WriteRegister(DPP::AcquisitionControl, 0x0);
|
WriteRegister(DPP::AcquisitionControl, 0x0);
|
||||||
WriteRegister(DPP::GlobalTriggerMask, 0x0);
|
WriteRegister(DPP::GlobalTriggerMask, 0x0);
|
||||||
WriteRegister(DPP::FrontPanelTRGOUTEnableMask, 0x0);
|
WriteRegister(DPP::FrontPanelTRGOUTEnableMask, 0x0);
|
||||||
|
@ -438,8 +424,6 @@ int Digitizer::ProgramBoard_QDC(){
|
||||||
WriteRegister(DPP::QDC::GroupEnableMask, 0xFF);
|
WriteRegister(DPP::QDC::GroupEnableMask, 0xFF);
|
||||||
WriteRegister(DPP::MaxAggregatePerBlockTransfer, 0x4);
|
WriteRegister(DPP::MaxAggregatePerBlockTransfer, 0x4);
|
||||||
|
|
||||||
if( ret != 0 ) { printf("!!!!!!!! set channels error.\n");}
|
|
||||||
|
|
||||||
isSettingFilledinMemeory = false; /// unlock the ReadAllSettingsFromBoard();
|
isSettingFilledinMemeory = false; /// unlock the ReadAllSettingsFromBoard();
|
||||||
|
|
||||||
usleep(1000*300);
|
usleep(1000*300);
|
||||||
|
|
|
@ -74,7 +74,7 @@ DigiSettingsPanel::DigiSettingsPanel(Digitizer ** digi, unsigned int nDigi, QStr
|
||||||
|
|
||||||
SetUpInfo( "S/N No. ", std::to_string(digi[ID]->GetSerialNumber()), infoLayout[ID], 1, 0);
|
SetUpInfo( "S/N No. ", std::to_string(digi[ID]->GetSerialNumber()), infoLayout[ID], 1, 0);
|
||||||
SetUpInfo("No. Input Ch. ", std::to_string(digi[ID]->GetNumInputCh()), infoLayout[ID], 1, 2);
|
SetUpInfo("No. Input Ch. ", std::to_string(digi[ID]->GetNumInputCh()), infoLayout[ID], 1, 2);
|
||||||
SetUpInfo("Sampling Rate ", std::to_string((int) digi[ID]->GetTick2ns()) + " ns = " + std::to_string( (1000/digi[ID]->GetTick2ns())) + " MHz" , infoLayout[ID], 1, 4);
|
SetUpInfo("Sampling Rate ", std::to_string((int) digi[ID]->GetTick2ns()) + " ns = " + QString::number( (1000/digi[ID]->GetTick2ns()), 'f', 1).toStdString() + " MHz" , infoLayout[ID], 1, 4);
|
||||||
|
|
||||||
SetUpInfo("ADC bit ", std::to_string(digi[ID]->GetADCBits()), infoLayout[ID], 2, 0);
|
SetUpInfo("ADC bit ", std::to_string(digi[ID]->GetADCBits()), infoLayout[ID], 2, 0);
|
||||||
SetUpInfo("ROC version ", digi[ID]->GetROCVersion(), infoLayout[ID], 2, 2);
|
SetUpInfo("ROC version ", digi[ID]->GetROCVersion(), infoLayout[ID], 2, 2);
|
||||||
|
@ -2382,8 +2382,6 @@ void DigiSettingsPanel::SetUpBoard_QDC(){
|
||||||
SetUpComboBoxBit(cbAnaProbe1[ID], "Ana. Probe ", bdCfgLayout[ID], 3, 0, DPP::Bit_BoardConfig::ListAnaProbe_QDC, DPP::BoardConfiguration, DPP::Bit_BoardConfig::AnalogProbe1, 1, 0);
|
SetUpComboBoxBit(cbAnaProbe1[ID], "Ana. Probe ", bdCfgLayout[ID], 3, 0, DPP::Bit_BoardConfig::ListAnaProbe_QDC, DPP::BoardConfiguration, DPP::Bit_BoardConfig::AnalogProbe1, 1, 0);
|
||||||
SetUpComboBoxBit(cbExtTriggerMode[ID], "Ext. Trig. Mode ", bdCfgLayout[ID], 4, 0, DPP::Bit_BoardConfig::ListExtTriggerMode_QDC, DPP::BoardConfiguration, DPP::Bit_BoardConfig::ExtTriggerMode_QDC, 1, 0);
|
SetUpComboBoxBit(cbExtTriggerMode[ID], "Ext. Trig. Mode ", bdCfgLayout[ID], 4, 0, DPP::Bit_BoardConfig::ListExtTriggerMode_QDC, DPP::BoardConfiguration, DPP::Bit_BoardConfig::ExtTriggerMode_QDC, 1, 0);
|
||||||
|
|
||||||
SetUpSpinBox(sbEventPreAgg_QDC[ID], "Event pre Agg. ", bdCfgLayout[ID], 6, 0, DPP::QDC::NumberEventsPerAggregate, -1, true);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DigiSettingsPanel::SetUpChannel_QDC(){
|
void DigiSettingsPanel::SetUpChannel_QDC(){
|
||||||
|
@ -3322,12 +3320,6 @@ void DigiSettingsPanel::UpdatePanelFromMemory(){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//*======================================== QDC only
|
|
||||||
if( digi[ID]->GetDPPType() == V1740_DPP_QDC_CODE ){
|
|
||||||
uint32_t eventPreAgg = digi[ID]->GetSettingFromMemory(DPP::QDC::NumberEventsPerAggregate);
|
|
||||||
sbEventPreAgg_QDC[ID]->setValue(eventPreAgg & 0x3FF);
|
|
||||||
}
|
|
||||||
|
|
||||||
//*======================================== update channels/group setting
|
//*======================================== update channels/group setting
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) UpdateSettings_PHA();
|
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) UpdateSettings_PHA();
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) UpdateSettings_PSD();
|
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) UpdateSettings_PSD();
|
||||||
|
|
72
FSUDAQ.cpp
72
FSUDAQ.cpp
|
@ -321,24 +321,33 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent){
|
||||||
|
|
||||||
MainWindow::~MainWindow(){
|
MainWindow::~MainWindow(){
|
||||||
|
|
||||||
|
if( scalar ) {
|
||||||
|
scalarThread->Stop();
|
||||||
|
scalarThread->quit();
|
||||||
|
scalarThread->exit();
|
||||||
|
CleanUpScalar();
|
||||||
|
delete scalar;
|
||||||
|
}
|
||||||
|
|
||||||
if( digi ) CloseDigitizers();
|
if( digi ) CloseDigitizers();
|
||||||
SaveProgramSettings();
|
SaveProgramSettings();
|
||||||
|
|
||||||
if( scope ) delete scope;
|
if( scope ) delete scope;
|
||||||
|
|
||||||
|
if( histThread){
|
||||||
|
histThread->Stop();
|
||||||
|
histThread->quit();
|
||||||
|
histThread->wait();
|
||||||
|
|
||||||
|
delete histThread;
|
||||||
|
}
|
||||||
|
|
||||||
if( canvas ) delete canvas;
|
if( canvas ) delete canvas;
|
||||||
|
|
||||||
if( onlineAnalyzer ) delete onlineAnalyzer;
|
if( onlineAnalyzer ) delete onlineAnalyzer;
|
||||||
|
|
||||||
if( digiSettings ) delete digiSettings;
|
if( digiSettings ) delete digiSettings;
|
||||||
|
|
||||||
if( scalar ) {
|
|
||||||
CleanUpScalar();
|
|
||||||
scalarThread->Stop();
|
|
||||||
scalarThread->quit();
|
|
||||||
scalarThread->exit();
|
|
||||||
delete scalarThread;
|
|
||||||
}
|
|
||||||
|
|
||||||
delete influx;
|
delete influx;
|
||||||
|
|
||||||
|
@ -688,8 +697,11 @@ void MainWindow::OpenDigitizers(){
|
||||||
|
|
||||||
void MainWindow::CloseDigitizers(){
|
void MainWindow::CloseDigitizers(){
|
||||||
|
|
||||||
LogMsg("Closing Digitizer(s)....");
|
LogMsg("MainWindow::Closing Digitizer(s)....");
|
||||||
|
|
||||||
|
scalarThread->Stop();
|
||||||
|
scalarThread->quit();
|
||||||
|
scalarThread->exit();
|
||||||
CleanUpScalar();
|
CleanUpScalar();
|
||||||
|
|
||||||
if( scope ) {
|
if( scope ) {
|
||||||
|
@ -698,6 +710,16 @@ void MainWindow::CloseDigitizers(){
|
||||||
scope = nullptr;
|
scope = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( histThread){
|
||||||
|
histThread->Stop();
|
||||||
|
histThread->quit();
|
||||||
|
histThread->wait();
|
||||||
|
|
||||||
|
delete histThread;
|
||||||
|
histThread = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if( canvas ){
|
if( canvas ){
|
||||||
canvas->close();
|
canvas->close();
|
||||||
delete canvas;
|
delete canvas;
|
||||||
|
@ -713,23 +735,23 @@ void MainWindow::CloseDigitizers(){
|
||||||
if( digi == nullptr ) return;
|
if( digi == nullptr ) return;
|
||||||
|
|
||||||
for(unsigned int i = 0; i < nDigi; i ++){
|
for(unsigned int i = 0; i < nDigi; i ++){
|
||||||
digi[i]->CloseDigitizer();
|
readDataThread[i]->Stop();
|
||||||
delete digi[i];
|
readDataThread[i]->quit();
|
||||||
|
readDataThread[i]->wait();
|
||||||
if(readDataThread[i]->isRunning()){
|
|
||||||
readDataThread[i]->Stop();
|
|
||||||
readDataThread[i]->quit();
|
|
||||||
readDataThread[i]->wait();
|
|
||||||
}
|
|
||||||
|
|
||||||
delete readDataThread[i];
|
delete readDataThread[i];
|
||||||
|
printf(" readDataThread[%d] is deleted.\n", i);
|
||||||
}
|
}
|
||||||
delete [] digi;
|
|
||||||
digi = nullptr;
|
|
||||||
|
|
||||||
delete [] readDataThread;
|
delete [] readDataThread;
|
||||||
readDataThread = nullptr;
|
readDataThread = nullptr;
|
||||||
|
|
||||||
|
for(unsigned int i = 0; i < nDigi; i ++){
|
||||||
|
digi[i]->CloseDigitizer();
|
||||||
|
delete digi[i];
|
||||||
|
}
|
||||||
|
delete [] digi;
|
||||||
|
digi = nullptr;
|
||||||
|
|
||||||
LogMsg("Done. Closed " + QString::number(nDigi) + " Digitizer(s).");
|
LogMsg("Done. Closed " + QString::number(nDigi) + " Digitizer(s).");
|
||||||
nDigi = 0;
|
nDigi = 0;
|
||||||
|
|
||||||
|
@ -737,6 +759,8 @@ void MainWindow::CloseDigitizers(){
|
||||||
bnStartACQ->setStyleSheet("");
|
bnStartACQ->setStyleSheet("");
|
||||||
bnStopACQ->setStyleSheet("");
|
bnStopACQ->setStyleSheet("");
|
||||||
|
|
||||||
|
printf("End of MainWindow::%s\n", __func__);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::WaitForDigitizersOpen(bool onOff){
|
void MainWindow::WaitForDigitizersOpen(bool onOff){
|
||||||
|
@ -785,7 +809,7 @@ void MainWindow::SetupScalar(){
|
||||||
lbLastUpdateTime = nullptr;
|
lbLastUpdateTime = nullptr;
|
||||||
lbScalarACQStatus = nullptr;
|
lbScalarACQStatus = nullptr;
|
||||||
|
|
||||||
scalarThread = new TimingThread();
|
scalarThread = new TimingThread(scalar);
|
||||||
connect(scalarThread, &TimingThread::timeUp, this, &MainWindow::UpdateScalar);
|
connect(scalarThread, &TimingThread::timeUp, this, &MainWindow::UpdateScalar);
|
||||||
|
|
||||||
unsigned short maxNChannel = 0;
|
unsigned short maxNChannel = 0;
|
||||||
|
@ -1051,11 +1075,9 @@ void MainWindow::StopACQ(){
|
||||||
}
|
}
|
||||||
|
|
||||||
for( unsigned int i = 0; i < nDigi; i++){
|
for( unsigned int i = 0; i < nDigi; i++){
|
||||||
if( readDataThread[i]->isRunning() ) {
|
readDataThread[i]->Stop();
|
||||||
readDataThread[i]->Stop();
|
readDataThread[i]->quit();
|
||||||
readDataThread[i]->quit();
|
readDataThread[i]->wait();
|
||||||
readDataThread[i]->wait();
|
|
||||||
}
|
|
||||||
digiMTX[i].lock();
|
digiMTX[i].lock();
|
||||||
digi[i]->StopACQ();
|
digi[i]->StopACQ();
|
||||||
digiMTX[i].unlock();
|
digiMTX[i].unlock();
|
||||||
|
|
|
@ -8,12 +8,12 @@ INCLUDEPATH += .
|
||||||
|
|
||||||
QT += core widgets charts printsupport
|
QT += core widgets charts printsupport
|
||||||
|
|
||||||
#QMAKE_CXXFLAGS += -g `root-config --cflags --glibs`
|
|
||||||
#LIBS += -lCAENDigitizer -lcurl `root-config --cflags --glibs`
|
|
||||||
|
|
||||||
QMAKE_CXXFLAGS += -g
|
QMAKE_CXXFLAGS += -g
|
||||||
LIBS += -lCAENDigitizer -lcurl
|
LIBS += -lCAENDigitizer -lcurl
|
||||||
|
|
||||||
|
QMAKE_CXXFLAGS_RELEASE = -O0
|
||||||
|
QMAKE_CFLAGS_RELEASE = -O0
|
||||||
|
|
||||||
# You can make your code fail to compile if you use deprecated APIs.
|
# You can make your code fail to compile if you use deprecated APIs.
|
||||||
# In order to do so, uncomment the following line.
|
# In order to do so, uncomment the following line.
|
||||||
# Please consult the documentation of the deprecated API in order to know
|
# Please consult the documentation of the deprecated API in order to know
|
||||||
|
|
|
@ -786,6 +786,7 @@ namespace DPP {
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace QDC { // Register already grouped in channel. and there no control for indiviual channel except the Fine DC offset and threshold, so it is like no group
|
namespace QDC { // Register already grouped in channel. and there no control for indiviual channel except the Fine DC offset and threshold, so it is like no group
|
||||||
|
const Reg NumberEventsPerAggregate ("Number of Events per Aggregate", 0x1020, RW::ReadWrite, false, 0x3FF, -1); /// R/W
|
||||||
const Reg RecordLength ("Record Length" , 0x1024, RW::ReadWrite, false, 0x1FFF, 1); /// R/W
|
const Reg RecordLength ("Record Length" , 0x1024, RW::ReadWrite, false, 0x1FFF, 1); /// R/W
|
||||||
const Reg GateWidth ("GateWidth" , 0x1030, RW::ReadWrite, false, 0xFFF, 1); /// R/W
|
const Reg GateWidth ("GateWidth" , 0x1030, RW::ReadWrite, false, 0xFFF, 1); /// R/W
|
||||||
const Reg GateOffset ("GateOfset" , 0x1034, RW::ReadWrite, false, 0xFF, 1); /// R/W
|
const Reg GateOffset ("GateOfset" , 0x1034, RW::ReadWrite, false, 0xFF, 1); /// R/W
|
||||||
|
@ -811,7 +812,6 @@ namespace DPP {
|
||||||
const Reg TriggerThreshold_sub7 ("Trigger Threshold sub7" , 0x10EC, RW::ReadWrite, false, 0xFFF, -1); /// R/W
|
const Reg TriggerThreshold_sub7 ("Trigger Threshold sub7" , 0x10EC, RW::ReadWrite, false, 0xFFF, -1); /// R/W
|
||||||
|
|
||||||
|
|
||||||
const Reg NumberEventsPerAggregate ("Number of Events per Aggregate", 0x8020, RW::ReadWrite, false, 0x3FF, -1); /// R/W
|
|
||||||
const Reg GroupEnableMask ("Group Enable Mask" , 0x8120, RW::ReadWrite, false, 0xFF, -1); /// R/W
|
const Reg GroupEnableMask ("Group Enable Mask" , 0x8120, RW::ReadWrite, false, 0xFF, -1); /// R/W
|
||||||
|
|
||||||
namespace Bit_DPPAlgorithmControl {
|
namespace Bit_DPPAlgorithmControl {
|
||||||
|
|
11
Scope.cpp
11
Scope.cpp
|
@ -680,6 +680,8 @@ void Scope::SetUpPanel_PHA(){
|
||||||
dataTrace[3]->setName(cbDigiProbe2->currentText());
|
dataTrace[3]->setName(cbDigiProbe2->currentText());
|
||||||
cbDigiProbe2->setEnabled(false);
|
cbDigiProbe2->setEnabled(false);
|
||||||
|
|
||||||
|
dataTrace[4]->setVisible(false);
|
||||||
|
|
||||||
enableSignalSlot = true;
|
enableSignalSlot = true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -751,6 +753,8 @@ void Scope::SetUpPanel_PSD(){
|
||||||
dataTrace[3]->setName(cbDigiProbe2->currentText());
|
dataTrace[3]->setName(cbDigiProbe2->currentText());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
dataTrace[4]->setVisible(false);
|
||||||
|
|
||||||
enableSignalSlot = true;
|
enableSignalSlot = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -846,10 +850,15 @@ void Scope::SetUpPanel_QDC() {
|
||||||
connect(cbAnaProbe1, &RComboBox::currentIndexChanged, this, [=](){
|
connect(cbAnaProbe1, &RComboBox::currentIndexChanged, this, [=](){
|
||||||
if( !enableSignalSlot ) return;
|
if( !enableSignalSlot ) return;
|
||||||
digi[ID]->SetBits(DPP::BoardConfiguration, DPP::Bit_BoardConfig::AnalogProbe1, cbAnaProbe1->currentData().toInt(), cbScopeCh->currentIndex());
|
digi[ID]->SetBits(DPP::BoardConfiguration, DPP::Bit_BoardConfig::AnalogProbe1, cbAnaProbe1->currentData().toInt(), cbScopeCh->currentIndex());
|
||||||
//dataTrace[0]->setName(cbAnaProbe1->currentText());
|
dataTrace[0]->setName(cbAnaProbe1->currentText());
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
dataTrace[1]->setVisible(true); dataTrace[1]->setName("Gate");
|
||||||
|
dataTrace[2]->setVisible(true); dataTrace[2]->setName("Trigger");
|
||||||
|
dataTrace[3]->setVisible(true); dataTrace[3]->setName("Trigger HoldOff");
|
||||||
|
dataTrace[4]->setVisible(true); dataTrace[4]->setName("OverThreshold");
|
||||||
|
|
||||||
enableSignalSlot = true;
|
enableSignalSlot = true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
20
test.cpp
20
test.cpp
|
@ -26,20 +26,30 @@ int getch(void);
|
||||||
//^======================================
|
//^======================================
|
||||||
int main(int argc, char* argv[]){
|
int main(int argc, char* argv[]){
|
||||||
|
|
||||||
Digitizer * digi = new Digitizer(0, 0, false, true);
|
Digitizer * digi = new Digitizer(0, 2, false, true);
|
||||||
|
|
||||||
|
Reg reg("test", 0x1020, RW::ReadWrite, false, 0xFFF, -1);
|
||||||
|
|
||||||
|
digi->WriteRegister(reg, 0x13, -1);
|
||||||
|
|
||||||
|
digi->ReadAllSettingsFromBoard();
|
||||||
|
|
||||||
|
digi->GetSettingFromMemory(DPP::QDC::NumberEventsPerAggregate);
|
||||||
|
|
||||||
|
|
||||||
|
// digi->Reset();
|
||||||
|
// digi->ProgramBoard_PHA();
|
||||||
|
|
||||||
digi->Reset();
|
|
||||||
digi->ProgramBoard_PHA();
|
|
||||||
|
|
||||||
for( int ch = 0; ch < 16; ch++){
|
for( int ch = 0; ch < 16; ch++){
|
||||||
printf("%2d | 0x%X \n", ch, digi->GetSettingFromMemory(DPP::ChannelDCOffset, ch));
|
printf("%2d | 0x%X \n", ch, digi->GetSettingFromMemory(reg, ch));
|
||||||
}
|
}
|
||||||
|
|
||||||
//digi->SetBits(DPP::BoardConfiguration, DPP::Bit_BoardConfig::RecordTrace, 1, -1);
|
//digi->SetBits(DPP::BoardConfiguration, DPP::Bit_BoardConfig::RecordTrace, 1, -1);
|
||||||
|
|
||||||
// Data * data = digi->GetData();
|
// Data * data = digi->GetData();
|
||||||
|
|
||||||
// digi->StartACQ();
|
//digi->StartACQ();
|
||||||
|
|
||||||
// for( int i = 0; i < 4; i ++ ){
|
// for( int i = 0; i < 4; i ++ ){
|
||||||
// usleep(1000*1000);
|
// usleep(1000*1000);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user