fix the time jumping problem for eventbuilder
This commit is contained in:
parent
bdc02a5639
commit
ea2bf2cb01
|
@ -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);
|
||||||
|
|
|
@ -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++){
|
||||||
|
|
|
@ -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];
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user