fix the time jumping problem for eventbuilder

This commit is contained in:
splitPoleDAQ 2024-01-11 17:32:58 -05:00
parent bdc02a5639
commit ea2bf2cb01
3 changed files with 54 additions and 21 deletions

View File

@ -10,7 +10,7 @@
#include "TTree.h" #include "TTree.h"
#define MAX_MULTI 100 #define MAX_MULTI 100
#define BUFFERFILL 0.1 // only 0.5 * MAXNData will be filled in memeory each time #define TIMEJUMP 1e8 // 0.1 sec or 10 Hz, any signal less than 10 Hz should increase the value.
template<typename T> void swap(T * a, T *b ); template<typename T> void swap(T * a, T *b );
int partition(int arr[], int kaka[], TString file[], unsigned int fileSize[], unsigned int numBlock[], int t2ns[], int start, int end); int partition(int arr[], int kaka[], TString file[], unsigned int fileSize[], unsigned int numBlock[], int t2ns[], int start, int end);
@ -25,11 +25,16 @@ int main(int argc, char **argv) {
printf("=========================================\n"); printf("=========================================\n");
if (argc <= 3) { if (argc <= 3) {
printf("Incorrect number of arguments:\n"); printf("Incorrect number of arguments:\n");
printf("%s [timeWindow] [traceOn/Off] [verbose] [inFile1] [inFile2] .... \n", argv[0]); printf("%s [timeWindow] [Buffer] [traceOn/Off] [verbose] [inFile1] [inFile2] .... \n", argv[0]);
printf(" timeWindow : number of tick, 1 tick. default = 100 \n"); printf(" timeWindow : in ns \n");
printf(" Buffer : Fraction of %d, recommand 0.4 \n", MaxNData);
printf(" traceOn/Off : is traces stored \n"); printf(" traceOn/Off : is traces stored \n");
printf(" verbose : > 0 for debug \n"); printf(" verbose : > 0 for debug \n");
printf(" Output file name is contructed from inFile1 \n"); printf(" Output file name is contructed from inFile1 \n");
printf("\n");
printf(" * there is a TIMEJUMP = 1e8 ns in EventBuilder.cpp.\n");
printf(" This control the time diff for a time jumping.\n");
printf(" Any signal with trigger rate < 1/TIMEJUMP should increase the value.\n");
return 1; return 1;
} }
@ -42,12 +47,13 @@ int main(int argc, char **argv) {
///============= read input ///============= read input
unsigned int timeWindow = atoi(argv[1]); unsigned int timeWindow = atoi(argv[1]);
bool traceOn = atoi(argv[2]); float bufferSize = atof(argv[2]);
unsigned int debug = atoi(argv[3]); bool traceOn = atoi(argv[3]);
int nFile = argc - 4; unsigned int debug = atoi(argv[4]);
int nFile = argc - 5;
TString inFileName[nFile]; TString inFileName[nFile];
for( int i = 0 ; i < nFile ; i++){ for( int i = 0 ; i < nFile ; i++){
inFileName[i] = argv[i+4]; inFileName[i] = argv[i+5];
} }
/// Form outFileName; /// Form outFileName;
@ -63,8 +69,9 @@ int main(int argc, char **argv) {
for( int i = 0; i < nFile; i++) printf("%2d | %s \n", i, inFileName[i].Data()); for( int i = 0; i < nFile; i++) printf("%2d | %s \n", i, inFileName[i].Data());
printf("=====================================\n"); printf("=====================================\n");
printf(" Time Window = %u \n", timeWindow); printf(" Time Window = %u \n", timeWindow);
printf(" Buffer size = %.0f event/channel\n", MaxNData * bufferSize);
printf("===================================== input files:\n"); printf("===================================== input files:\n");
printf("Scanning files.....\n");
///============= sorting file by the serial number & order ///============= sorting file by the serial number & order
int ID[nFile]; /// serial+ order*1000; int ID[nFile]; /// serial+ order*1000;
@ -192,13 +199,14 @@ int main(int argc, char **argv) {
printf("================= Building events....\n"); printf("================= Building events....\n");
MultiBuilder * mb = new MultiBuilder(data, typeList, snList); MultiBuilder * mb = new MultiBuilder(data, typeList, snList);
mb->SetTimeWindow(timeWindow); mb->SetTimeWindow(timeWindow);
mb->SetTimeJump(TIMEJUMP);
///------------------ read data ///------------------ read data
char * buffer = nullptr; char * buffer = nullptr;
unsigned int word[1]; // 4 byte = 32 bit unsigned int word[1]; // 4 byte = 32 bit
int lastDataIndex[nGroup][MAX_MULTI]; // keep track of the DataIndex int lastDataIndex[nGroup][MAX_MULTI]; // keep track of the DataIndex
int lastLoopIndex[nGroup][MAX_MULTI]; // keep track of the DataIndex int lastLoopIndex[nGroup][MAX_MULTI]; // keep track of the LoopIndex
int aggCount[nGroup]; int aggCount[nGroup];
for( int i = 0; i < nGroup; i++){ for( int i = 0; i < nGroup; i++){
@ -276,6 +284,12 @@ int main(int argc, char **argv) {
//check if Data Index near MaxNData. if near by 50%, break //check if Data Index near MaxNData. if near by 50%, break
//printf("-----------------------------------\n"); //printf("-----------------------------------\n");
for( int i = 0; i < nGroup; i++){ for( int i = 0; i < nGroup; i++){
if( debug ){
printf("-------------------------> %3d | agg : %d | %u \n", snList[i], aggCount[i], data[i]->aggTime);
//data[i]->PrintStat();
}
for( int ch = 0; ch < data[i]->GetNChannel(); ch ++){ for( int ch = 0; ch < data[i]->GetNChannel(); ch ++){
int iData = data[i]->DataIndex[ch]; int iData = data[i]->DataIndex[ch];
@ -283,21 +297,17 @@ int main(int argc, char **argv) {
if( iData < 0 ) continue; if( iData < 0 ) continue;
if( (iLoop*MaxNData + iData) - (lastLoopIndex[i][ch]*MaxNData + lastDataIndex[i][ch]) > MaxNData * BUFFERFILL ) { if( (iLoop*MaxNData + iData) - (lastLoopIndex[i][ch]*MaxNData + lastDataIndex[i][ch]) > MaxNData * bufferSize ) {
if( debug ) printf("############# BREAK!!!! Group: %d, ch : %d | last : %d(%d), Present : %d(%d) | BufferSize : %.0f \n", i, ch, lastDataIndex[i][ch], lastLoopIndex[i][ch], iData, iLoop, MaxNData * BUFFERFILL); if( debug ) printf("############# BREAK!!!! Group: %d, ch : %d | last : %d(%d), Present : %d(%d) | BufferSize : %.0f \n", i, ch, lastDataIndex[i][ch], lastLoopIndex[i][ch], iData, iLoop, MaxNData * bufferSize);
fillFlag = false; fillFlag = false;
} }
if( debug ){ if( debug ){
unsigned long long t1 = data[i]->Timestamp[ch][iData]; unsigned long long t1 = data[i]->Timestamp[ch][iData];
printf("digi:%d | ch: %2d DataIndex: %5d (%d) [%5d(%d)] | %llu\n", data[i]->boardSN, ch, iData, iLoop, lastDataIndex[i][ch], lastLoopIndex[i][ch], t1); printf("digi:%5d | ch: %2d DataIndex: %5d (%d) [%5d(%d)] | %16llu\n", data[i]->boardSN, ch, iData, iLoop, lastDataIndex[i][ch], lastLoopIndex[i][ch], t1);
} }
} }
if( debug ){
printf("-------------------------> %3d | agg : %d | %u \n", snList[i], aggCount[i], data[i]->aggTime);
//data[i]->PrintStat();
}
} }
}while(fillFlag); }while(fillFlag);

View File

@ -10,6 +10,8 @@ MultiBuilder::MultiBuilder(Data ** multiData, std::vector<int> type, std::vector
timeWindow = 100; timeWindow = 100;
leftOverTime = 100; leftOverTime = 100;
breakTime = -1; breakTime = -1;
timeJump = 1e8;
lastEventTime = 0;
ClearEvents(); ClearEvents();
// for( int i = 0; i < nData; i++){ // for( int i = 0; i < nData; i++){
@ -27,6 +29,9 @@ MultiBuilder::MultiBuilder(Data * singleData, int type, int sn): nData(1){
timeWindow = 100; timeWindow = 100;
leftOverTime = 100; leftOverTime = 100;
breakTime = -1; breakTime = -1;
timeJump = 1e8;
lastEventTime = 0;
ClearEvents(); ClearEvents();
} }
@ -199,10 +204,9 @@ void MultiBuilder::FindLatestTimeOfData(bool verbose){
void MultiBuilder::BuildEvents(bool isFinal, bool skipTrace, bool verbose){ void MultiBuilder::BuildEvents(bool isFinal, bool skipTrace, bool verbose){
FindEarlistTimeAmongLastData(verbose); FindEarlistTimeAmongLastData(verbose); // give lastest Time, Ch, and Digi
//FindLatestTimeOfData(verbose);
FindEarlistTimeAndCh(verbose); FindEarlistTimeAndCh(verbose); //Give the earliest time, ch, digi
if( earlistCh == -1 || nExhaushedCh == nData * MaxNChannels) return; /// no data if( earlistCh == -1 || nExhaushedCh == nData * MaxNChannels) return; /// no data
eventBuilt = 0; eventBuilt = 0;
@ -240,7 +244,8 @@ void MultiBuilder::BuildEvents(bool isFinal, bool skipTrace, bool verbose){
do { do {
unsigned long long time = data[bd]->Timestamp[ch][nextIndex[bd][ch]]; unsigned long long time = data[bd]->Timestamp[ch][nextIndex[bd][ch]];
// printf("Check timestamp : %llu | earlistTime : %llu | timeWindow : %u \n", time, earlistTime, timeWindow); //printf("%6ld, sn: %5d, ch: %2d, timestamp : %16llu | earlistTime : %16llu | timeWindow : %u \n", eventIndex, data[bd]->boardSN, ch, time, earlistTime, timeWindow);
if( time >= earlistTime && (time - earlistTime <= timeWindow) ){ if( time >= earlistTime && (time - earlistTime <= timeWindow) ){
em.sn = snList[bd]; em.sn = snList[bd];
em.bd = bd; em.bd = bd;
@ -268,15 +273,26 @@ void MultiBuilder::BuildEvents(bool isFinal, bool skipTrace, bool verbose){
if( timeWindow <= 0 ) break; if( timeWindow <= 0 ) break;
} }
if( timeWindow > 0 ) { if( events[eventIndex].size() > 1) {
std::sort(events[eventIndex].begin(), events[eventIndex].end(), [](const Hit& a, const Hit& b) { std::sort(events[eventIndex].begin(), events[eventIndex].end(), [](const Hit& a, const Hit& b) {
return a.timestamp < b.timestamp; return a.timestamp < b.timestamp;
}); });
} }
lastEventTime = events[eventIndex].back().timestamp;
///Find the next earlist ///Find the next earlist
FindEarlistTimeAndCh(false); FindEarlistTimeAndCh(false);
// //if there is a time jump, say, bigger than TimeJump. break
if( earlistTime - lastEventTime > timeJump ) {
printf("%6lu, %16llu\n", eventIndex, earlistTime);
printf("%5s - %16llu \n", "", lastEventTime);
printf("%5s > %16llu \n", "", timeJump);
printf("!!!!!!!! Time Jump detected stop event building. stop event buinding and get more data.\n");
return;
}
if( verbose ){ if( verbose ){
printf(">>>>>>>>>>>>>>>>> Event ID : %ld, total built: %ld, multiplicity : %ld\n", eventIndex, totalEventBuilt, events[eventIndex].size()); printf(">>>>>>>>>>>>>>>>> Event ID : %ld, total built: %ld, multiplicity : %ld\n", eventIndex, totalEventBuilt, events[eventIndex].size());
for( int i = 0; i <(int) events[eventIndex].size(); i++){ for( int i = 0; i <(int) events[eventIndex].size(); i++){

View File

@ -48,6 +48,9 @@ public:
void SetTimeWindow(unsigned short ticks) {timeWindow = ticks; leftOverTime = ticks;} void SetTimeWindow(unsigned short ticks) {timeWindow = ticks; leftOverTime = ticks;}
unsigned short GetTimeWindow() const{return timeWindow;} unsigned short GetTimeWindow() const{return timeWindow;}
void SetTimeJump(unsigned long long TimeJumpInNanoSec) {timeJump = TimeJumpInNanoSec;}
unsigned long long GetTimeJump() const {return timeJump;}
void SetLeftOverTime(unsigned long long ticks) {leftOverTime = ticks;} void SetLeftOverTime(unsigned long long ticks) {leftOverTime = ticks;}
unsigned long long GetLeftOverTime() const{return leftOverTime;} unsigned long long GetLeftOverTime() const{return leftOverTime;}
@ -80,6 +83,10 @@ private:
unsigned short timeWindow; unsigned short timeWindow;
unsigned long long leftOverTime; unsigned long long leftOverTime;
unsigned long long breakTime; // timestamp for breaking the event builder unsigned long long breakTime; // timestamp for breaking the event builder
unsigned long long timeJump; //time diff for a time jump, default is 1e8 ns
unsigned long long lastEventTime; // timestamp for detect time jump
int loopIndex[MaxNDigitizer][MaxNChannels]; int loopIndex[MaxNDigitizer][MaxNChannels];
int nextIndex[MaxNDigitizer][MaxNChannels]; int nextIndex[MaxNDigitizer][MaxNChannels];