various fixes
This commit is contained in:
parent
2171d03246
commit
1bbfeff571
|
@ -177,6 +177,8 @@ inline void Data::ClearData(){
|
||||||
NumEventsDecoded[ch] = 0;
|
NumEventsDecoded[ch] = 0;
|
||||||
NumNonPileUpDecoded[ch] = 0;
|
NumNonPileUpDecoded[ch] = 0;
|
||||||
|
|
||||||
|
TotNumEvents[ch] = 0 ;
|
||||||
|
|
||||||
calIndexes[ch][0] = -1;
|
calIndexes[ch][0] = -1;
|
||||||
calIndexes[ch][1] = -1;
|
calIndexes[ch][1] = -1;
|
||||||
}
|
}
|
||||||
|
@ -262,7 +264,7 @@ inline void Data::PrintStat() const{
|
||||||
printf(" this is roll-over fake event or no events.\n");
|
printf(" this is roll-over fake event or no events.\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
printf("%2s | %6s | %9s | %9s | %6s | %6s(%4s)\n", "ch", "# Evt.", "Rate [Hz]", "N-PileUp", "Tot. Evt.", "index", "loop");
|
printf("%2s | %6s | %9s | %9s | %6s | %6s(%4s)\n", "ch", "# Evt.", "Rate [Hz]", "Accept", "Tot. Evt.", "index", "loop");
|
||||||
printf("---+--------+-----------+-----------+----------\n");
|
printf("---+--------+-----------+-----------+----------\n");
|
||||||
for(int ch = 0; ch < MaxNChannels; ch++){
|
for(int ch = 0; ch < MaxNChannels; ch++){
|
||||||
printf("%2d | %6d | %9.2f | %9.2f | %6lu | %6d(%2d)\n", ch, NumEventsDecoded[ch], TriggerRate[ch], NonPileUpRate[ch], TotNumEvents[ch], DataIndex[ch], LoopIndex[ch]);
|
printf("%2d | %6d | %9.2f | %9.2f | %6lu | %6d(%2d)\n", ch, NumEventsDecoded[ch], TriggerRate[ch], NonPileUpRate[ch], TotNumEvents[ch], DataIndex[ch], LoopIndex[ch]);
|
||||||
|
@ -422,7 +424,7 @@ inline void Data::DecodeBuffer(bool fastDecode, int verbose){
|
||||||
|
|
||||||
TriggerRate[ch] = (NumEventsDecoded[ch]-1)/sec;
|
TriggerRate[ch] = (NumEventsDecoded[ch]-1)/sec;
|
||||||
//printf("%d %d| %d | %llu, %.3e | %.2f\n", indexStart, DataIndex[ch], NumEventsDecoded[ch], dTime, sec , TriggerRate[ch]);
|
//printf("%d %d| %d | %llu, %.3e | %.2f\n", indexStart, DataIndex[ch], NumEventsDecoded[ch], dTime, sec , TriggerRate[ch]);
|
||||||
NonPileUpRate[ch] = (NumNonPileUpDecoded[ch]-1)/sec;
|
NonPileUpRate[ch] = (NumNonPileUpDecoded[ch])/sec;
|
||||||
|
|
||||||
}else{ // look in to the data in the memory, not just this agg.
|
}else{ // look in to the data in the memory, not just this agg.
|
||||||
|
|
||||||
|
@ -437,7 +439,6 @@ inline void Data::DecodeBuffer(bool fastDecode, int verbose){
|
||||||
unsigned long long dTime = Timestamp[ch][calIndexes[ch][1]] - Timestamp[ch][calIndexes[ch][0]];
|
unsigned long long dTime = Timestamp[ch][calIndexes[ch][1]] - Timestamp[ch][calIndexes[ch][0]];
|
||||||
double sec = dTime * tick2ns / 1e9;
|
double sec = dTime * tick2ns / 1e9;
|
||||||
|
|
||||||
//printf(" %10llu %10llu, %f = %f sec, rate = %f \n", Timestamp[ch][calIndexes[ch][0]], Timestamp[ch][calIndexes[ch][1]], tick2ns, sec, nEvent / sec);
|
|
||||||
|
|
||||||
TriggerRate[ch] = nEvent / sec;
|
TriggerRate[ch] = nEvent / sec;
|
||||||
|
|
||||||
|
@ -445,6 +446,7 @@ inline void Data::DecodeBuffer(bool fastDecode, int verbose){
|
||||||
for( int i = calIndexes[ch][0] ; i <= calIndexes[ch][0] + nEvent; i++ ) {
|
for( int i = calIndexes[ch][0] ; i <= calIndexes[ch][0] + nEvent; i++ ) {
|
||||||
if( PileUp[ch][i % MaxNData] ) pileUpCount ++;
|
if( PileUp[ch][i % MaxNData] ) pileUpCount ++;
|
||||||
}
|
}
|
||||||
|
//printf("%2d | %10llu %10llu, %.0f = %f sec, rate = %f, nEvent %d pileUp %d \n", ch, Timestamp[ch][calIndexes[ch][0]], Timestamp[ch][calIndexes[ch][1]], tick2ns, sec, nEvent / sec, nEvent, pileUpCount);
|
||||||
|
|
||||||
NonPileUpRate[ch] = (nEvent - pileUpCount)/sec;
|
NonPileUpRate[ch] = (nEvent - pileUpCount)/sec;
|
||||||
|
|
||||||
|
|
34
FSUDAQ.cpp
34
FSUDAQ.cpp
|
@ -63,9 +63,12 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent){
|
||||||
layout->addWidget(bnOpenScope, 1, 1);
|
layout->addWidget(bnOpenScope, 1, 1);
|
||||||
connect(bnOpenScope, &QPushButton::clicked, this, &MainWindow::OpenScope);
|
connect(bnOpenScope, &QPushButton::clicked, this, &MainWindow::OpenScope);
|
||||||
|
|
||||||
bnAnalyzer = new QPushButton("Online Analyzer", this);
|
cbAnalyzer = new RComboBox(this);
|
||||||
layout->addWidget(bnAnalyzer, 0, 2);
|
layout->addWidget(cbAnalyzer, 0, 2);
|
||||||
connect(bnAnalyzer, &QPushButton::clicked, this, &MainWindow::OpenAnalyzer);
|
cbAnalyzer->addItem("Choose Online Analyzer", -1);
|
||||||
|
cbAnalyzer->addItem("Split-Pole", 0);
|
||||||
|
cbAnalyzer->addItem("Encore", 1);
|
||||||
|
connect(cbAnalyzer, &RComboBox::currentIndexChanged, this, &MainWindow::OpenAnalyzer);
|
||||||
|
|
||||||
bnCanvas = new QPushButton("Online 1D Histograms", this);
|
bnCanvas = new QPushButton("Online 1D Histograms", this);
|
||||||
layout->addWidget(bnCanvas, 1, 2);
|
layout->addWidget(bnCanvas, 1, 2);
|
||||||
|
@ -735,7 +738,7 @@ void MainWindow::WaitForDigitizersOpen(bool onOff){
|
||||||
bnStopACQ->setStyleSheet("");
|
bnStopACQ->setStyleSheet("");
|
||||||
chkSaveData->setEnabled(!onOff);
|
chkSaveData->setEnabled(!onOff);
|
||||||
bnCanvas->setEnabled(!onOff);
|
bnCanvas->setEnabled(!onOff);
|
||||||
bnAnalyzer->setEnabled(!onOff);
|
cbAnalyzer->setEnabled(!onOff);
|
||||||
|
|
||||||
cbAutoRun->setEnabled(chkSaveData->isChecked());
|
cbAutoRun->setEnabled(chkSaveData->isChecked());
|
||||||
bnSync->setEnabled(false);
|
bnSync->setEnabled(false);
|
||||||
|
@ -1427,17 +1430,30 @@ void MainWindow::OpenCanvas(){
|
||||||
//***************************************************************
|
//***************************************************************
|
||||||
//***************************************************************
|
//***************************************************************
|
||||||
void MainWindow::OpenAnalyzer(){
|
void MainWindow::OpenAnalyzer(){
|
||||||
|
int id = cbAnalyzer->currentData().toInt();
|
||||||
|
|
||||||
|
if( id < 0 ) return;
|
||||||
|
|
||||||
if( onlineAnalyzer == nullptr ) {
|
if( onlineAnalyzer == nullptr ) {
|
||||||
//onlineAnalyzer = new Analyzer(digi, nDigi);
|
//onlineAnalyzer = new Analyzer(digi, nDigi);
|
||||||
//onlineAnalyzer = new SplitPole(digi, nDigi);
|
if( id == 0 ) onlineAnalyzer = new SplitPole(digi, nDigi);
|
||||||
onlineAnalyzer = new Encore(digi, nDigi);
|
if( id == 1 ) onlineAnalyzer = new Encore(digi, nDigi);
|
||||||
onlineAnalyzer->show();
|
if( id >= 0 ) onlineAnalyzer->show();
|
||||||
}else{
|
}else{
|
||||||
onlineAnalyzer->show();
|
|
||||||
onlineAnalyzer->activateWindow();
|
delete onlineAnalyzer;
|
||||||
|
|
||||||
|
if( id == 0 ) onlineAnalyzer = new SplitPole(digi, nDigi);
|
||||||
|
if( id == 1 ) onlineAnalyzer = new Encore(digi, nDigi);
|
||||||
|
|
||||||
|
if( id >= 0 ){
|
||||||
|
onlineAnalyzer->show();
|
||||||
|
onlineAnalyzer->activateWindow();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cbAnalyzer->setCurrentIndex(0);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//***************************************************************
|
//***************************************************************
|
||||||
|
|
4
FSUDAQ.h
4
FSUDAQ.h
|
@ -94,7 +94,9 @@ private:
|
||||||
QPushButton * bnCloseDigitizers;
|
QPushButton * bnCloseDigitizers;
|
||||||
QPushButton * bnOpenScope;
|
QPushButton * bnOpenScope;
|
||||||
QPushButton * bnDigiSettings;
|
QPushButton * bnDigiSettings;
|
||||||
QPushButton * bnAnalyzer;
|
//QPushButton * bnAnalyzer;
|
||||||
|
|
||||||
|
RComboBox * cbAnalyzer;
|
||||||
|
|
||||||
QPushButton * bnOpenScaler;
|
QPushButton * bnOpenScaler;
|
||||||
QPushButton * bnStartACQ;
|
QPushButton * bnStartACQ;
|
||||||
|
|
|
@ -17,7 +17,6 @@ An online analyzer class is created as a template for online analysis. An exampl
|
||||||
|
|
||||||
<span style="color:red;">Notice that, when the FSUDAQ is started, the online analyzer is a null pointer, no event will be built. Once the online anlyzer is created and opened, event will be built, event the window is closed. </span>
|
<span style="color:red;">Notice that, when the FSUDAQ is started, the online analyzer is a null pointer, no event will be built. Once the online anlyzer is created and opened, event will be built, event the window is closed. </span>
|
||||||
|
|
||||||
|
|
||||||
# Operation
|
# Operation
|
||||||
|
|
||||||
When programSettings.txt is presented in the same folder as the FSUDAQ_Qt, the program will load it can config the following
|
When programSettings.txt is presented in the same folder as the FSUDAQ_Qt, the program will load it can config the following
|
||||||
|
@ -39,6 +38,12 @@ the following additional functions are planned and I am working on them
|
||||||
|
|
||||||
- support V1740 DPP-QDC
|
- support V1740 DPP-QDC
|
||||||
|
|
||||||
|
# ToDo
|
||||||
|
|
||||||
|
- Gaussians fitting for 1D Histogram
|
||||||
|
- log scale for 1D and 2D Histogram
|
||||||
|
- Improve the color scheme for 2D histogram
|
||||||
|
|
||||||
# Required / Development enviroment
|
# Required / Development enviroment
|
||||||
|
|
||||||
Ubuntu 22.04
|
Ubuntu 22.04
|
||||||
|
@ -100,6 +105,7 @@ Those file can be compiled using
|
||||||
|
|
||||||
# Known Issues
|
# Known Issues
|
||||||
|
|
||||||
|
* DC offset issue. When porgram default settings, the DC offset is not the same for all channels.
|
||||||
* for PHA firmware, when the peak average changed, the Events per Agg need to be changed.
|
* for PHA firmware, when the peak average changed, the Events per Agg need to be changed.
|
||||||
|
|
||||||
# Known Bugs
|
# Known Bugs
|
||||||
|
|
|
@ -624,8 +624,8 @@ namespace DPP {
|
||||||
{"OR", 7}};
|
{"OR", 7}};
|
||||||
|
|
||||||
const std::vector<std::pair<std::string, unsigned int>> ListLocalTrigValidMode = {{"Disabled", 0},
|
const std::vector<std::pair<std::string, unsigned int>> ListLocalTrigValidMode = {{"Disabled", 0},
|
||||||
{"Crossed", 4},
|
{"Crossed Trigger", 4},
|
||||||
{"Equal", 5},
|
{"Both from Mother board", 5},
|
||||||
{"AND", 6},
|
{"AND", 6},
|
||||||
{"OR", 7}};
|
{"OR", 7}};
|
||||||
|
|
||||||
|
@ -699,8 +699,8 @@ namespace DPP {
|
||||||
{"OR", 7}};
|
{"OR", 7}};
|
||||||
|
|
||||||
const std::vector<std::pair<std::string, unsigned int>> ListLocalTrigValidMode = {{"Disabled", 0},
|
const std::vector<std::pair<std::string, unsigned int>> ListLocalTrigValidMode = {{"Disabled", 0},
|
||||||
{"Crossed", 4},
|
{"Crossed Trigger", 4},
|
||||||
{"Equal", 5},
|
{"Both from Mother board", 5},
|
||||||
{"AND", 6},
|
{"AND", 6},
|
||||||
{"OR", 7}};
|
{"OR", 7}};
|
||||||
|
|
||||||
|
|
|
@ -92,6 +92,7 @@ inline void Encore::SetUpCanvas(){
|
||||||
|
|
||||||
inline void Encore::UpdateHistograms(){
|
inline void Encore::UpdateHistograms(){
|
||||||
|
|
||||||
|
if( this->isVisible() == false ) return;
|
||||||
if( runAnalyzer->isChecked() == false ) return;
|
if( runAnalyzer->isChecked() == false ) return;
|
||||||
|
|
||||||
BuildEvents(); // call the event builder to build events
|
BuildEvents(); // call the event builder to build events
|
||||||
|
|
|
@ -25,7 +25,7 @@ const double mp = 938.2720813; // MeV/c^2
|
||||||
const double mn = 939.56542052; // MeV/c^2
|
const double mn = 939.56542052; // MeV/c^2
|
||||||
const double amu = 931.0;
|
const double amu = 931.0;
|
||||||
|
|
||||||
const string massData="mass20.txt";
|
const string massData="analyzers/mass20.txt";
|
||||||
|
|
||||||
// about the mass**.txt
|
// about the mass**.txt
|
||||||
// Mass Excess = (ATOMIC MASS - A)*amu | e.g. n : (1.088664.91585E-6-1)*amu
|
// Mass Excess = (ATOMIC MASS - A)*amu | e.g. n : (1.088664.91585E-6-1)*amu
|
||||||
|
|
|
@ -249,6 +249,8 @@ private:
|
||||||
RSpinBox * sbEnergy;
|
RSpinBox * sbEnergy;
|
||||||
RSpinBox * sbAngle;
|
RSpinBox * sbAngle;
|
||||||
|
|
||||||
|
QCheckBox * runAnalyzer;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -334,6 +336,9 @@ inline void SplitPole::SetUpCanvas(){
|
||||||
hit.CalZoffset(leTarget->text(), leBeam->text(), leRecoil->text(), sbBfield->value(), sbAngle->value(), sbEnergy->value());
|
hit.CalZoffset(leTarget->text(), leBeam->text(), leRecoil->text(), sbBfield->value(), sbAngle->value(), sbEnergy->value());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
runAnalyzer = new QCheckBox("Run Analyzer", this);
|
||||||
|
boxLayout->addWidget(runAnalyzer, 4, 1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//============ histograms
|
//============ histograms
|
||||||
|
@ -403,6 +408,9 @@ inline void SplitPole::SetUpCanvas(){
|
||||||
|
|
||||||
inline void SplitPole::UpdateHistograms(){
|
inline void SplitPole::UpdateHistograms(){
|
||||||
|
|
||||||
|
if( this->isVisible() == false ) return;
|
||||||
|
if( runAnalyzer->isChecked() == false ) return;
|
||||||
|
|
||||||
BuildEvents(); // call the event builder to build events
|
BuildEvents(); // call the event builder to build events
|
||||||
|
|
||||||
//============ Get events, and do analysis
|
//============ Get events, and do analysis
|
||||||
|
|
Loading…
Reference in New Issue
Block a user