working on Scope with PSD
This commit is contained in:
parent
29c8c95d0d
commit
53c36185c9
171
Scope.cpp
171
Scope.cpp
|
@ -116,10 +116,11 @@ Scope::Scope(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataTh
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) SetUpPHAPanel();
|
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) SetUpPHAPanel();
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) SetUpPSDPanel();
|
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) SetUpPSDPanel();
|
||||||
|
|
||||||
ReadSettingsFromBoard();
|
//ReadSettingsFromBoard();
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
bnReadSettingsFromBoard = new QPushButton("Refresh Settings", this);
|
bnReadSettingsFromBoard = new QPushButton("Refresh Settings", this);
|
||||||
layout->addWidget(bnReadSettingsFromBoard, rowID, 2);
|
layout->addWidget(bnReadSettingsFromBoard, rowID, 2);
|
||||||
connect(bnReadSettingsFromBoard, &QPushButton::clicked, this, &Scope::ReadSettingsFromBoard);
|
connect(bnReadSettingsFromBoard, &QPushButton::clicked, this, &Scope::ReadSettingsFromBoard);
|
||||||
|
@ -134,6 +135,7 @@ Scope::Scope(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataTh
|
||||||
settingLayout->setSpacing(0);
|
settingLayout->setSpacing(0);
|
||||||
|
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) SetUpPHAPanel();
|
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) SetUpPHAPanel();
|
||||||
|
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) SetUpPSDPanel();
|
||||||
|
|
||||||
}
|
}
|
||||||
//================ Plot view
|
//================ Plot view
|
||||||
|
@ -142,6 +144,7 @@ Scope::Scope(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataTh
|
||||||
plotView->setRenderHints(QPainter::Antialiasing);
|
plotView->setRenderHints(QPainter::Antialiasing);
|
||||||
layout->addWidget(plotView, rowID, 0, 1, 6);
|
layout->addWidget(plotView, rowID, 0, 1, 6);
|
||||||
|
|
||||||
|
|
||||||
//================ Key binding
|
//================ Key binding
|
||||||
rowID ++;
|
rowID ++;
|
||||||
QLabel * lbhints = new QLabel("Type 'r' to restore view, '+/-' Zoom in/out, arrow key to pan.", this);
|
QLabel * lbhints = new QLabel("Type 'r' to restore view, '+/-' Zoom in/out, arrow key to pan.", this);
|
||||||
|
@ -186,11 +189,11 @@ Scope::Scope(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataTh
|
||||||
layout->setColumnStretch(4, 1);
|
layout->setColumnStretch(4, 1);
|
||||||
layout->setColumnStretch(5, 1);
|
layout->setColumnStretch(5, 1);
|
||||||
|
|
||||||
UpdatePanelFromMomeory();
|
|
||||||
|
|
||||||
bnScopeStart->setEnabled(true);
|
bnScopeStart->setEnabled(true);
|
||||||
bnScopeStop->setEnabled(false);
|
bnScopeStop->setEnabled(false);
|
||||||
|
|
||||||
|
UpdatePanelFromMomeory();
|
||||||
|
|
||||||
enableSignalSlot = true;
|
enableSignalSlot = true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -345,6 +348,7 @@ void Scope::SetUpComboBox(RComboBox * &cb, QString str, int row, int col, const
|
||||||
}
|
}
|
||||||
|
|
||||||
void Scope::SetUpSpinBox(RSpinBox * &sb, QString str, int row, int col, const Reg para){
|
void Scope::SetUpSpinBox(RSpinBox * &sb, QString str, int row, int col, const Reg para){
|
||||||
|
|
||||||
QLabel * lb = new QLabel(str, settingGroup);
|
QLabel * lb = new QLabel(str, settingGroup);
|
||||||
lb->setAlignment(Qt::AlignRight | Qt::AlignCenter);
|
lb->setAlignment(Qt::AlignRight | Qt::AlignCenter);
|
||||||
settingLayout->addWidget(lb, row, col);
|
settingLayout->addWidget(lb, row, col);
|
||||||
|
@ -363,6 +367,7 @@ void Scope::SetUpSpinBox(RSpinBox * &sb, QString str, int row, int col, const Re
|
||||||
sb->setStyleSheet("color:blue");
|
sb->setStyleSheet("color:blue");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
connect(sb, &RSpinBox::returnPressed, this, [=](){
|
connect(sb, &RSpinBox::returnPressed, this, [=](){
|
||||||
if( !enableSignalSlot ) return;
|
if( !enableSignalSlot ) return;
|
||||||
if( sb->decimals() == 0 && sb->singleStep() != 1) {
|
if( sb->decimals() == 0 && sb->singleStep() != 1) {
|
||||||
|
@ -534,6 +539,9 @@ void Scope::SetUpPHAPanel(){
|
||||||
|
|
||||||
void Scope::SetUpPSDPanel(){
|
void Scope::SetUpPSDPanel(){
|
||||||
|
|
||||||
|
enableSignalSlot = false;
|
||||||
|
printf("==== %s \n", __func__);
|
||||||
|
|
||||||
int rowID = 0;
|
int rowID = 0;
|
||||||
SetUpSpinBox(sbReordLength, "Record Length [ns] ", rowID, 0, DPP::RecordLength_G);
|
SetUpSpinBox(sbReordLength, "Record Length [ns] ", rowID, 0, DPP::RecordLength_G);
|
||||||
SetUpSpinBox(sbPreTrigger, "Pre Trigger [ns] ", rowID, 2, DPP::PreTrigger);
|
SetUpSpinBox(sbPreTrigger, "Pre Trigger [ns] ", rowID, 2, DPP::PreTrigger);
|
||||||
|
@ -541,6 +549,7 @@ void Scope::SetUpPSDPanel(){
|
||||||
sbDCOffset->setDecimals(2);
|
sbDCOffset->setDecimals(2);
|
||||||
SetUpComboBox(cbDynamicRange, "Dynamic Range ", rowID, 6, DPP::InputDynamicRange);
|
SetUpComboBox(cbDynamicRange, "Dynamic Range ", rowID, 6, DPP::InputDynamicRange);
|
||||||
|
|
||||||
|
|
||||||
rowID ++; //=============================================================
|
rowID ++; //=============================================================
|
||||||
SetUpComboBoxSimple(cbPolarity, "Polarity ", rowID, 0);
|
SetUpComboBoxSimple(cbPolarity, "Polarity ", rowID, 0);
|
||||||
cbPolarity->addItem("Positive", 0);
|
cbPolarity->addItem("Positive", 0);
|
||||||
|
@ -554,7 +563,7 @@ void Scope::SetUpPSDPanel(){
|
||||||
SetUpSpinBox(sbLongGate, "Long Gate [ns] ", rowID, 4, DPP::PSD::LongGateWidth);
|
SetUpSpinBox(sbLongGate, "Long Gate [ns] ", rowID, 4, DPP::PSD::LongGateWidth);
|
||||||
SetUpSpinBox(sbGateOffset, "Gate Offset [ns] ", rowID, 6, DPP::PSD::GateOffset);
|
SetUpSpinBox(sbGateOffset, "Gate Offset [ns] ", rowID, 6, DPP::PSD::GateOffset);
|
||||||
|
|
||||||
|
enableSignalSlot = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Scope::EnableControl(bool enable){
|
void Scope::EnableControl(bool enable){
|
||||||
|
@ -607,20 +616,34 @@ void Scope::UpdateSpinBox(RSpinBox * &sb, const Reg para){
|
||||||
void Scope::UpdatePanelFromMomeory(){
|
void Scope::UpdatePanelFromMomeory(){
|
||||||
|
|
||||||
enableSignalSlot = false;
|
enableSignalSlot = false;
|
||||||
|
printf("==== %s \n", __func__);
|
||||||
|
|
||||||
int ch = cbScopeCh->currentIndex();
|
int ch = cbScopeCh->currentIndex();
|
||||||
|
|
||||||
int factor = digi[ID]->IsDualTrace() ? 2 : 1; // if dual trace,
|
|
||||||
|
|
||||||
unsigned int haha = digi[ID]->GetSettingFromMemory(DPP::RecordLength_G, ch);
|
unsigned int haha = digi[ID]->GetSettingFromMemory(DPP::RecordLength_G, ch);
|
||||||
sbReordLength->setValue(haha * DPP::RecordLength_G.GetPartialStep() * ch2ns / factor);
|
|
||||||
|
|
||||||
haha = digi[ID]->GetSettingFromMemory(DPP::PreTrigger, ch);
|
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ){
|
||||||
sbPreTrigger->setValue(haha * DPP::PreTrigger.GetPartialStep() * ch2ns / factor);
|
int factor = digi[ID]->IsDualTrace() ? 2 : 1; // if dual trace,
|
||||||
|
sbReordLength->setValue(haha * DPP::RecordLength_G.GetPartialStep() * ch2ns / factor);
|
||||||
|
}else{
|
||||||
|
sbReordLength->setValue(haha * DPP::RecordLength_G.GetPartialStep() * ch2ns);
|
||||||
|
}
|
||||||
|
|
||||||
haha = digi[ID]->GetSettingFromMemory(DPP::ChannelDCOffset, ch);
|
haha = digi[ID]->GetSettingFromMemory(DPP::ChannelDCOffset, ch);
|
||||||
sbDCOffset->setValue((1.0 - haha * 1.0 / 0xFFFF) * 100 );
|
sbDCOffset->setValue((1.0 - haha * 1.0 / 0xFFFF) * 100 );
|
||||||
|
|
||||||
UpdateComobox(cbDynamicRange, DPP::InputDynamicRange);
|
UpdateComobox(cbDynamicRange, DPP::InputDynamicRange);
|
||||||
|
UpdateSpinBox(sbPreTrigger, DPP::PreTrigger);
|
||||||
|
|
||||||
|
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ) UpdatePHAPanel();
|
||||||
|
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE ) UpdatePSDPanel();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Scope::UpdatePHAPanel(){
|
||||||
|
enableSignalSlot = false;
|
||||||
|
|
||||||
|
int ch = cbScopeCh->currentIndex();
|
||||||
|
|
||||||
uint32_t DPPAlg = digi[ID]->GetSettingFromMemory(DPP::DPPAlgorithmControl, ch);
|
uint32_t DPPAlg = digi[ID]->GetSettingFromMemory(DPP::DPPAlgorithmControl, ch);
|
||||||
if( Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::Polarity) ){
|
if( Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::Polarity) ){
|
||||||
|
@ -629,64 +652,82 @@ void Scope::UpdatePanelFromMomeory(){
|
||||||
cbPolarity->setCurrentIndex(0);
|
cbPolarity->setCurrentIndex(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( digi[ID]->GetDPPType() == V1730_DPP_PHA_CODE ){
|
UpdateSpinBox(sbInputRiseTime, DPP::PHA::InputRiseTime);
|
||||||
UpdateSpinBox(sbInputRiseTime, DPP::PHA::InputRiseTime);
|
UpdateSpinBox(sbThreshold, DPP::PHA::TriggerThreshold);
|
||||||
UpdateSpinBox(sbThreshold, DPP::PHA::TriggerThreshold);
|
UpdateSpinBox(sbTriggerHoldOff, DPP::PHA::TriggerHoldOffWidth);
|
||||||
UpdateSpinBox(sbTriggerHoldOff, DPP::PHA::TriggerHoldOffWidth);
|
|
||||||
|
|
||||||
UpdateSpinBox(sbTrapRiseTime, DPP::PHA::TrapezoidRiseTime);
|
UpdateSpinBox(sbTrapRiseTime, DPP::PHA::TrapezoidRiseTime);
|
||||||
UpdateSpinBox(sbTrapFlatTop, DPP::PHA::TrapezoidFlatTop);
|
UpdateSpinBox(sbTrapFlatTop, DPP::PHA::TrapezoidFlatTop);
|
||||||
UpdateSpinBox(sbDecayTime, DPP::PHA::DecayTime);
|
UpdateSpinBox(sbDecayTime, DPP::PHA::DecayTime);
|
||||||
UpdateSpinBox(sbPeakingTime, DPP::PHA::PeakingTime);
|
UpdateSpinBox(sbPeakingTime, DPP::PHA::PeakingTime);
|
||||||
|
|
||||||
UpdateComobox(cbSmoothingFactor, DPP::PHA::RCCR2SmoothingFactor);
|
UpdateComobox(cbSmoothingFactor, DPP::PHA::RCCR2SmoothingFactor);
|
||||||
|
|
||||||
int temp = Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::BaselineAvg);
|
int temp = Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::BaselineAvg);
|
||||||
for(int i = 0; i < cbBaselineAvg->count(); i++){
|
for(int i = 0; i < cbBaselineAvg->count(); i++){
|
||||||
if( cbBaselineAvg->itemData(i).toInt() == temp) {
|
if( cbBaselineAvg->itemData(i).toInt() == temp) {
|
||||||
cbBaselineAvg->setCurrentIndex(i);
|
cbBaselineAvg->setCurrentIndex(i);
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
temp = Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::PeakMean);
|
|
||||||
for(int i = 0; i < cbPeakAvg->count(); i++){
|
|
||||||
if( cbPeakAvg->itemData(i).toInt() == temp) {
|
|
||||||
cbPeakAvg->setCurrentIndex(i);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t BdCfg = digi[ID]->GetSettingFromMemory(DPP::BoardConfiguration);
|
|
||||||
|
|
||||||
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::AnalogProbe1);
|
|
||||||
for(int i = 0; i < cbAnaProbe1->count(); i++){
|
|
||||||
if( cbAnaProbe1->itemData(i).toInt() == temp) {
|
|
||||||
cbAnaProbe1->setCurrentIndex(i);
|
|
||||||
dataTrace[0]->setName(cbAnaProbe1->currentText());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::AnalogProbe2);
|
|
||||||
for(int i = 0; i < cbAnaProbe2->count(); i++){
|
|
||||||
if( cbAnaProbe2->itemData(i).toInt() == temp) {
|
|
||||||
cbAnaProbe2->setCurrentIndex(i);
|
|
||||||
dataTrace[1]->setName(cbAnaProbe2->currentText());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::DigiProbel1);
|
|
||||||
for(int i = 0; i < cbDigiProbe1->count(); i++){
|
|
||||||
if( cbDigiProbe1->itemData(i).toInt() == temp) {
|
|
||||||
cbDigiProbe1->setCurrentIndex(i);
|
|
||||||
dataTrace[2]->setName(cbDigiProbe1->currentText());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
temp = Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PHA::PeakMean);
|
||||||
|
for(int i = 0; i < cbPeakAvg->count(); i++){
|
||||||
|
if( cbPeakAvg->itemData(i).toInt() == temp) {
|
||||||
|
cbPeakAvg->setCurrentIndex(i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t BdCfg = digi[ID]->GetSettingFromMemory(DPP::BoardConfiguration);
|
||||||
|
|
||||||
|
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::AnalogProbe1);
|
||||||
|
for(int i = 0; i < cbAnaProbe1->count(); i++){
|
||||||
|
if( cbAnaProbe1->itemData(i).toInt() == temp) {
|
||||||
|
cbAnaProbe1->setCurrentIndex(i);
|
||||||
|
dataTrace[0]->setName(cbAnaProbe1->currentText());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::AnalogProbe2);
|
||||||
|
for(int i = 0; i < cbAnaProbe2->count(); i++){
|
||||||
|
if( cbAnaProbe2->itemData(i).toInt() == temp) {
|
||||||
|
cbAnaProbe2->setCurrentIndex(i);
|
||||||
|
dataTrace[1]->setName(cbAnaProbe2->currentText());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
temp = Digitizer::ExtractBits(BdCfg, DPP::Bit_BoardConfig::DigiProbel1);
|
||||||
|
for(int i = 0; i < cbDigiProbe1->count(); i++){
|
||||||
|
if( cbDigiProbe1->itemData(i).toInt() == temp) {
|
||||||
|
cbDigiProbe1->setCurrentIndex(i);
|
||||||
|
dataTrace[2]->setName(cbDigiProbe1->currentText());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enableSignalSlot = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Scope::UpdatePSDPanel(){
|
||||||
|
enableSignalSlot = false;
|
||||||
|
|
||||||
|
printf("==== %s \n", __func__);
|
||||||
|
|
||||||
|
|
||||||
|
// int ch = cbScopeCh->currentIndex();
|
||||||
|
|
||||||
|
// uint32_t DPPAlg = digi[ID]->GetSettingFromMemory(DPP::DPPAlgorithmControl, ch);
|
||||||
|
// if( Digitizer::ExtractBits(DPPAlg, DPP::Bit_DPPAlgorithmControl_PSD::Polarity) ){
|
||||||
|
// cbPolarity->setCurrentIndex(1);
|
||||||
|
// }else{
|
||||||
|
// cbPolarity->setCurrentIndex(0);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// UpdateSpinBox(sbShortGate, DPP::PSD::ShortGateWidth);
|
||||||
|
// UpdateSpinBox(sbLongGate, DPP::PSD::LongGateWidth);
|
||||||
|
// UpdateSpinBox(sbGateOffset, DPP::PSD::GateOffset);
|
||||||
|
|
||||||
enableSignalSlot = true;
|
enableSignalSlot = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -713,6 +754,14 @@ void Scope::ReadSettingsFromBoard(){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( digi[ID]->GetDPPType() == V1730_DPP_PSD_CODE){
|
||||||
|
|
||||||
|
digi[ID]->ReadRegister(DPP::PSD::ShortGateWidth);
|
||||||
|
digi[ID]->ReadRegister(DPP::PSD::LongGateWidth);
|
||||||
|
digi[ID]->ReadRegister(DPP::PSD::GateOffset);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
UpdatePanelFromMomeory();
|
UpdatePanelFromMomeory();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
2
Scope.h
2
Scope.h
|
@ -55,6 +55,8 @@ private:
|
||||||
void UpdateComobox(RComboBox * &cb, const Reg para);
|
void UpdateComobox(RComboBox * &cb, const Reg para);
|
||||||
void UpdateSpinBox(RSpinBox * &sb, const Reg para);
|
void UpdateSpinBox(RSpinBox * &sb, const Reg para);
|
||||||
void UpdatePanelFromMomeory();
|
void UpdatePanelFromMomeory();
|
||||||
|
void UpdatePHAPanel();
|
||||||
|
void UpdatePSDPanel();
|
||||||
|
|
||||||
Digitizer ** digi;
|
Digitizer ** digi;
|
||||||
unsigned short nDigi;
|
unsigned short nDigi;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user