12 const std::vector<std::string> MainDaqParser::LIST_TIMERS = {
17 "process_coda_physics" ,
18 "process_coda_prestart",
21 "process_phys_flush" ,
23 "process_phys_prestart",
26 "pack_one_spill_data" ,
31 : m_file_size_min(32768)
34 , m_timer_sp_input (new
PHTimer2(
"timer_sp_input"))
35 , m_timer_sp_decode(new
PHTimer2(
"timer_sp_decode"))
36 , m_timer_sp_map (new
PHTimer2(
"timer_sp_map"))
37 , m_use_local_spill_id(false)
38 , m_force_local_spill_id(false)
46 for (
auto it = LIST_TIMERS.begin(); it != LIST_TIMERS.end(); it++) {
54 if (coda )
delete coda;
55 if (list_sd )
delete list_sd;
56 if (list_ed )
delete list_ed;
57 if (list_ed_now)
delete list_ed_now;
58 for (
auto it = m_timers.begin(); it != m_timers.end(); it++)
delete it->second;
59 if (m_timer_sp_input )
delete m_timer_sp_input;
60 if (m_timer_sp_decode)
delete m_timer_sp_decode;
61 if (m_timer_sp_map )
delete m_timer_sp_map;
66 m_file_size_min = file_size_min;
67 m_sec_wait = sec_wait;
72 m_timers[
"open_file"]->restart();
73 int ret = coda->
OpenFile(fname, file_size_min, sec_wait, n_wait);
74 m_timers[
"open_file"]->stop();
75 m_timers[
"open_to_end"]->restart();
81 static EventDataMap::iterator it = list_ed_now->begin();
82 if (it == list_ed_now->end()) {
84 while (list_ed_now->size() == 0 && ! coda->
IsEnded()) {
85 m_timers[
"parse_one_spill"]->restart();
87 m_timers[
"parse_one_spill"]->stop();
89 it = list_ed_now->begin();
91 if (it != list_ed_now->end()) {
105 int MainDaqParser::ParseOneSpill()
107 static bool call_1st =
true;
108 if (call_1st) call_1st =
false;
110 cout <<
"...sleep (" <<
dec_par.
time_wait <<
") to pretend waiting for next spill..." << endl;
112 cout <<
"...done." << endl;
116 cout <<
"MainDaqParser::ParseOneSpill():";
118 int ret = gSystem->GetProcInfo(&info);
120 cout <<
" ret=" << ret;
123 cout <<
" " << dati.AsSQLString() <<
" CpuSys=" << info.fCpuSys <<
" CpuUser=" << info.fCpuUser <<
" MemResident=" << info.fMemResident <<
" MemVirtual=" << info.fMemVirtual;
129 int* event_words = 0;
131 m_timers[
"next_coda_event"]->restart();
134 m_timers[
"next_coda_event"]->stop();
135 m_timer_sp_input->
stop();
136 if (! found_event)
break;
140 int evt_type_id = event_words[1];
146 switch (evt_type_id & 0xFFFF) {
148 m_timers[
"process_coda_physics"]->restart();
149 ret = ProcessCodaPhysics(event_words);
150 m_timers[
"process_coda_physics"]->stop();
153 switch (evt_type_id) {
155 m_timers[
"process_coda_prestart"]->restart();
156 ret = ProcessCodaPrestart(event_words);
157 m_timers[
"process_coda_prestart"]->stop();
162 m_timers[
"process_coda_end"]->restart();
163 ret = ProcessCodaEnd(event_words);
164 m_timers[
"process_coda_end"]->stop();
169 cerr <<
"!!ERROR!! Uncovered Coda event type: " << evt_type_id <<
". Exit." << endl;
174 m_timers[
"process_coda_fee"]->restart();
175 ret = ProcessCodaFee(event_words);
176 m_timers[
"process_coda_fee"]->stop();
186 cerr <<
"!!ERROR!! Uncovered Coda event type: " << evt_type_id <<
". Exit." << endl;
189 m_timer_sp_decode->
stop();
191 cout <<
"WARNING: ParseOneSpill(): ret = " << ret << endl;
204 m_timers[
"open_to_end"]->stop();
208 cout <<
"\nMainDaqParser: Statistics:\n"
209 <<
" Phys events: all = " << run_data.
n_phys_evt <<
"\n"
210 <<
" Flush events: all = " << run_data.
n_flush_evt <<
"\n"
212 <<
" Real events: all = " << run_data.
n_evt_all <<
", decoded = " << run_data.
n_evt_dec <<
"\n"
213 <<
" TDC hits: total = " << run_data.
n_hit <<
", bad = " << run_data.
n_hit_bad <<
"\n"
214 <<
" v1495 hits: total = " << run_data.
n_t_hit <<
", bad = " << run_data.
n_t_hit_bad <<
"\n"
217 cout <<
"MainDaqParser: Timer:\n";
218 for (
auto it = LIST_TIMERS.begin(); it != LIST_TIMERS.end(); it++) {
219 m_timers[*it]->print_stat();
235 int MainDaqParser::ProcessCodaPrestart(
int* words)
241 int run_type = words[4];
258 int MainDaqParser::ProcessCodaEnd(
int* words)
265 int MainDaqParser::ProcessCodaFee(
int* words)
268 cerr <<
"!!ERROR!! Not FEE_EVENT in case of FEE_PREFIX: " << words[1] <<
". Exit." << endl;
272 if (words[3] == (
int)0xe906f011) {
273 return ProcessCodaFeeBoard(words);
274 }
else if (words[3] == (
int)0xe906f012) {
276 return ProcessCodaFeePrescale(words);
277 }
else if (words[3] == (
int)0xe906f005) {
278 return ProcessCodaFeeV1495(words);
284 int MainDaqParser::ProcessCodaFeeBoard(
int* words)
324 run_data.
fee.push_back(data);
326 cout <<
" feeE " << data.
roc <<
" " << data.
board <<
" " << data.
hard
338 int MainDaqParser::ProcessCodaFeePrescale(
int* words)
341 int feeTriggerBits = words[4];
343 for (
int ii = 0; ii < 10; ii++) {
347 for (
int ii = 0; ii < 5; ii++) run_data. nim_enabled[ii] =
get_bin_bit (feeTriggerBits, ii+5);
350 for (
int ii = 0; ii < 8; ii++) {
351 run_data.
prescale[ii] = words[ii + 5];
353 for (
int ii = 0; ii < 5; ii++) run_data.
fpga_prescale[ii] = words[ii + 5];
354 for (
int ii = 0; ii < 3; ii++) run_data. nim_prescale[ii] = words[ii + 10];
359 for (
int ii = 0; ii < 10; ii++) cout <<
" " << run_data.
trig_bit[ii];
361 for (
int ii = 0; ii < 8; ii++) cout <<
" " << run_data.
prescale[ii];
368 int MainDaqParser::ProcessCodaFeeV1495(
int* words)
375 if (
dec_par.
verb > 0) cout <<
" Multiple events. Overwriting." << endl;
379 for (
int ii = 0; ii < num; ii++) {
380 int value = words[5+ii];
382 if (
dec_par.
verb > 0) cout <<
" feeV1495\t" << ii <<
"\t" << value <<
"\n";
397 int MainDaqParser::ProcessCodaPhysics(
int* words)
400 int eventCode = words[1];
410 m_timers[
"process_phys_flush"]->restart();
414 m_timers[
"process_phys_flush"]->stop();
418 m_timers[
"process_phys_slow"]->restart();
419 ret = ProcessPhysSlow(words);
420 m_timers[
"process_phys_slow"]->stop();
423 m_timers[
"process_phys_prestart"]->restart();
424 ret = ProcessPhysPrestart(words);
425 m_timers[
"process_phys_prestart"]->stop();
434 ret = ProcessPhysSpillCounter(words);
437 ret = ProcessPhysRunDesc(words);
440 m_timers[
"process_phys_bos"]->restart();
442 m_timers[
"process_phys_bos"]->stop();
445 m_timers[
"process_phys_eos"]->restart();
446 ret = ProcessPhysBOSEOS(words,
END_SPILL);
447 m_timers[
"process_phys_eos"]->stop();
451 cout <<
"Unknown event code: " << eventCode <<
". Ignore." << endl;
458 int MainDaqParser::ProcessPhysRunDesc(
int* words)
461 int evLength = words[0];
463 for (
int i_wd = 4; i_wd < (evLength + 1); i_wd++) {
464 unsigned int number = words[i_wd];
465 for (
int ii = 0; ii < 4; ii++) {
466 char word = (char)(number & 0xFF);
467 if (word == 0x22) word = 0x27;
469 number = number >> 8;
474 if (
dec_par.
verb) cout <<
" run desc: " << desc.length() <<
" chars." << endl;
481 int MainDaqParser::ProcessPhysPrestart(
int* words)
483 int evLength = words[0];
484 vector<string> list_line;
486 for (
int i_wd = 4; i_wd < (evLength + 1); i_wd++) {
487 unsigned int number = words[i_wd];
488 for (
int ii = 0; ii < 4; ii++) {
489 if ((number & 0xFF) ==
'\n') {
490 list_line.push_back(line);
493 line += (char)(number & 0xFF);
495 number = number >> 8;
498 if (line.length() > 0) list_line.push_back(line);
499 else cerr <<
"Unexpectedly line.length() == 0." << endl;
500 for (
unsigned int ii = 0; ii < list_line.size(); ii++) {
501 cout <<
" pre " << list_line[ii] << endl;
517 int MainDaqParser::ProcessPhysSlow(
int* words)
520 int evLength = words[0];
523 vector<string> list_line;
525 for (
int i_wd = 4; i_wd < (evLength + 1); i_wd++) {
526 unsigned int number = words[i_wd];
527 for (
int ii = 0; ii < 4; ii++) {
528 if ((number & 0xFF) ==
'\n') {
529 list_line.push_back(line);
532 line += (char)(number & 0xFF);
534 number = number >> 8;
537 if (line.length() > 0) list_line.push_back(line);
538 else cout <<
"WARNING: Unexpectedly line.length() == 0." << endl;
540 std::vector<SlowControlData> list_data;
541 for (
unsigned int ii = 0; ii < list_line.size(); ii++) {
542 istringstream iss(list_line[ii]);
543 string ts, name, value, type;
544 iss >> ts >> name >> value >> type;
553 list_data.push_back(data);
557 for (
unsigned int ii = 0; ii < list_data.size(); ii++) {
560 if ( data->
type ==
"target" &&
561 (data->
name ==
"TARGPOS_CONTROL" ||
562 data->
name.substr(0, 4) ==
"FREQ" ||
563 data->
name.substr(0, 4) ==
"PROX" ||
564 data->
name.substr(0, 5) ==
"TARG_" ) ) {
567 SpillData* spill_data = &(*list_sd)[spill_id];
582 int MainDaqParser::ProcessPhysSpillCounter(
int* words)
587 for (
int i_wd = 4; i_wd < n_wd + 1; i_wd++) {
588 int number = words[i_wd];
589 for (
int i_byte = 0; i_byte < 4; i_byte++) {
590 spillNum[i_wd_sc++] = (char)(number & 0xFF);
591 number = number >> 8;
594 spillNum[i_wd_sc] =
'\0';
607 int MainDaqParser::ProcessPhysBOSEOS(
int* words,
const int event_type)
610 string spill_type_str = (event_type ==
BEGIN_SPILL ?
"BOS" :
"EOS" );
614 if (PackOneSpillData() != 0) {
615 cout <<
"Error in PackOneSpillData. Exiting..." << endl;
621 static int spillID_local = 0;
622 if (m_force_local_spill_id ||
638 m_timer_sp_input ->
reset();
639 m_timer_sp_decode->
reset();
648 int evLength = words[0];
649 while (idx < evLength && (words[idx] & 0xfffff000) != 0xe906f000) {
650 int rocEvLength = words[idx];
651 int idx_roc_end = idx + rocEvLength;
652 if ( (rocEvLength + idx) > evLength) {
653 cout <<
"Word limit error: " << rocEvLength <<
" + " << idx <<
" > " << evLength << endl;
660 int codaEvVmeTime = words[idx];
676 if (spill_type !=
TYPE_BOS && rocID == 25) idx = idx_roc_end + 1;
680 if (rocEvLength <= 6) idx = idx_roc_end + 1;
682 while (idx <= idx_roc_end) {
683 int e906flag = words[idx];
686 idx = ProcessBoardData (words, idx, idx_roc_end, e906flag, event_type);
687 if (idx == IDX_SKIP_EVENT)
return 0;
688 else if (idx == IDX_SKIP_ROC ) idx = idx_roc_end + 1;
701 int MainDaqParser::ProcessPhysStdAndFlush(
int* words,
const int event_type)
703 const bool print_event =
false;
704 int evLength = words[0];
710 if (print_event) cout <<
"\nEvent code = 0x" << hex << words[1] << dec <<
" (" << evLength <<
")";
714 while (idx < evLength) {
715 int rocEvLength = words[idx];
719 if (rocEvLength <= 6) {
720 idx += rocEvLength + 1;
724 cerr <<
"ERROR: rocEvLength != 0x0000****." << endl;
731 int idx_roc_end = idx + rocEvLength + 1;
732 if (idx_roc_end > evLength + 1) {
734 cerr <<
"ERROR: ROC Event Length exceeds event length\n"
736 <<
", position = " << idx <<
", rocEvLength = " << words[idx] << endl;
745 cerr <<
"ERROR: rocID > 32." << endl;
750 if (print_event) cout <<
"\n ROC " << setw(2) << rocID <<
" (" << setw(3) << rocEvLength <<
") |";
757 while (idx < idx_roc_end) {
758 int e906flag = words[idx];
760 cerr <<
"ERROR: Not e906flag (0x" << hex << e906flag << dec <<
") " << event_type << endl;
762 cout <<
" At idx = " << idx <<
" / " << evLength <<
".\n";
768 if (e906flag == (
int)0xe906c0da) {
775 if (print_event) cout << hex <<
" " << (e906flag&0xFFFF) <<
"@" << board_id << dec <<
"(" << n_wd_bd <<
")";
776 idx = ProcessBoardData(words, idx, idx_roc_end, e906flag, event_type);
777 if (idx == IDX_SKIP_EVENT) {
778 if (
dec_par.
verb > 1) cout <<
"ERROR: ProcessBoardData() returned IDX_SKIP_EVENT @ 0x" << hex << e906flag << dec <<
", board " << board_id <<
",roc " << rocID <<
", coda " <<
dec_par.
event_count << endl;
780 }
else if (idx == IDX_SKIP_ROC) {
781 if (
dec_par.
verb > 1) cout <<
"ERROR: ProcessBoardData() returned IDX_SKIP_ROC @ 0x" << hex << e906flag << dec <<
", board " << board_id <<
",roc " << rocID <<
", coda " <<
dec_par.
event_count << endl;
785 if (idx != idx_roc_end) {
786 cout <<
"ERROR: idx(" << idx <<
") != idx_roc_end(" << idx_roc_end <<
") @ roc " << rocID <<
", coda " <<
dec_par.
event_count << endl;
790 if (print_event) cout << endl;
811 int MainDaqParser::ProcessBoardData (
int* words,
int idx,
int idx_roc_end,
int e906flag,
const int event_type)
813 if (e906flag == (
int)0xE906F003) { idx = ProcessBoardScaler (words, idx);
814 }
else if (e906flag == (
int)0xE906F005) {
815 if (event_type ==
FLUSH_EVENTS) idx = ProcessBoardV1495TDC (words, idx);
816 else idx = ProcessBoardStdV1495TDC(words, idx);
817 }
else if (e906flag == (
int)0xE906F018) { idx = ProcessBoardJyTDC2 (words, idx, idx_roc_end);
818 }
else if (e906flag == (
int)0xE906F019) {
return IDX_SKIP_ROC;
819 }
else if (e906flag == (
int)0xe906f01b) { idx = ProcessBoardFeeQIE (words, idx);
820 }
else if (e906flag == (
int)0xE906F014) {
821 if (event_type ==
FLUSH_EVENTS) idx = ProcessBoardTriggerCount (words, idx);
822 else idx = ProcessBoardStdTriggerCount(words, idx);
823 }
else if (e906flag == (
int)0xE906F00F) {
824 if (event_type ==
FLUSH_EVENTS) idx = ProcessBoardTriggerBit (words, idx, idx_roc_end);
825 else idx = ProcessBoardStdTriggerBit(words, idx);
826 }
else if (e906flag == (
int)0xE906F010) { idx = ProcessBoardStdJyTDC2 (words, idx, idx_roc_end);
827 }
else if (e906flag == (
int)0xe906f013) { idx = ProcessBoardStdFeeQIE (words, idx);
829 cerr <<
"ERROR: Unknown board flag (0x" << hex << e906flag << dec <<
") at coda " <<
dec_par.
event_count <<
", roc " << (int)
dec_par.
rocID <<
", idx " << idx << endl;
832 Abort(
"Unexpected board type.");
837 int MainDaqParser::ProcessBoardScaler (
int* words,
int idx)
839 int boardID = (0xFFFF & words[idx]);
844 for (
int ii = 0; ii < 32; ii++) {
845 unsigned int value = words[idx];
852 data.
board = boardID;
857 if (
dec_par.
verb > 3) cout <<
" Unmapped Scaler: " << data.
roc <<
" " << data.
board <<
" " << data.
chan <<
"\n";
867 int MainDaqParser::ProcessBoardTriggerBit (
int* words,
int j,
int idx_roc_end)
869 int n_words = words[j];
870 if (n_words == 0)
return j+1;
874 if (n_words % 2 != 0) {
876 Abort(
"N of trigger words % 2 != 0.");
878 int n_evt = n_words / 2;
879 for (
int i_evt = 0; i_evt < n_evt; i_evt++) {
880 int triggerBits = words[j + 2*i_evt ];
881 int evt_id = words[j + 2*i_evt + 1];
885 SetEventInfo(evt, evt_id);
889 for (
int i = 0; i < 10; i++) trigger[i] =
get_bin_bit (triggerBits, i);
890 for (
int i = 0; i < 5; i++) {
892 evt->
MATRIX[i] = trigger[i ];
893 evt->
NIM [i] = trigger[i+5];
900 int MainDaqParser::ProcessBoardTriggerCount (
int* words,
int j)
902 int n_words = words[j];
903 if (n_words == 0)
return j+1;
907 if (n_words % 11 != 0) {
909 Abort(
"N of trigger-count words % 11 != 0.");
911 int n_evt = n_words / 11;
912 for (
int i_evt = 0; i_evt < n_evt; i_evt++) {
913 int idx_evt = j + 11*i_evt;
914 int evt_id = words[idx_evt + 10];
918 SetEventInfo(evt, evt_id);
919 for (
int i_type = 0; i_type < 5; i_type++) {
920 evt->
RawMATRIX [i_type] = words[idx_evt + i_type ];
940 int MainDaqParser::ProcessBoardFeeQIE (
int* words,
int idx)
942 while (words[idx] == (
int)0xe906e906) idx++;
946 int idx_end = idx + n_wd + 1;
948 if (n_wd == 0)
return idx;
950 while (words[idx] == (
int)0xe906e906) { idx++; idx_end++; }
966 for (
int i_evt = 0; i_evt < 7 && idx < idx_end; i_evt++) {
968 int eventID = words[idx_evt + 48];
971 if (n_wd_evt == 44) idx_evt += 5;
972 else if (n_wd_evt != 39) {
980 unsigned int sums_vals[4];
981 for (
int i_sum = 0; i_sum < 4 ; i_sum++) {
987 unsigned int triggerCount = words[idx_evt] | (
get_hex_bits (words[idx_evt+1], 7, 4) );
991 unsigned int turnOnset = words[idx_evt] | (
get_hex_bits (words[idx_evt+1], 7, 4) );
996 unsigned int rfOnset =
get_hex_bits(words[idx_evt],7,4);
999 unsigned int rf_vals[25];
1000 for (
int i_rf = 0; i_rf < 25; i_rf++) {
1001 if (words[idx_evt] == (
int)0xe906e906)
Abort(
"Unexpected 0xe906e906 in QIE.");
1013 SetEventInfo(evt, eventID);
1015 for (
int ii = 0; ii < 4; ii++) evt->
sums[ii] = sums_vals[ii];
1019 for (
int ii = 0; ii < 25 ; ii++) evt->
rf[ii+4] = rf_vals[ii];
1024 if (idx != idx_end) {
1025 cout << idx <<
" != " << idx_end;
1026 Abort(
"idx != idx_end in feeQIE().");
1037 int MainDaqParser::ProcessBoardV1495TDC (
int* words,
int idx)
1039 int idx_begin = idx;
1041 cout <<
"ProcessBoardV1495TDC(): idx = " << idx << endl;
1045 int boardID = words[idx++];
1046 int n_wd_fpga = words[idx++];
1047 if (n_wd_fpga == 0)
return idx;
1048 if (words[idx] == (
int)0xe9060bad) {
1052 int idx_end = idx + n_wd_fpga;
1055 vector<int> list_chan;
1056 vector<int> list_time;
1057 while (idx < idx_end) {
1060 int word_stop = words[idx+1];
1061 int evt_id = words[idx+2];
1064 int evt_id_fpga = (words[idx+3]<<15) + words[idx+4];
1065 if (evt_id != evt_id_fpga) {
1066 cerr <<
"!! EventID mismatch @ v1495: " << evt_id <<
"@CPU vs " << evt_id_fpga <<
"@FPGA at event " <<
dec_par.
event_count <<
":" << i_evt <<
" board 0x" << hex << boardID << dec << endl;
1072 SetEventInfo(evt, evt_id);
1074 if (word_stop == (
int)0xd2ad) {
1077 }
else if (word_stop == (
int)0xd3ad) {
1085 for (
unsigned int ii = 0; ii < list_chan.size(); ii++) {
1090 hit.
board = boardID;
1091 hit.
chan = list_chan[ii];
1092 hit.
time = time_stop - list_time[ii];
1103 list_chan.push_back(
get_hex_bits (words[idx], 3, 2) );
1104 list_time.push_back(
get_hex_bits (words[idx], 1, 2) );
1108 if (idx != idx_end) {
1109 cout <<
"ProcessBoardV1495TDC(): idx != idx_end (" << idx <<
" != " << idx_end <<
") @ coda=" <<
dec_par.
event_count <<
" roc=" <<
dec_par.
rocID <<
" board=" << hex << boardID << dec <<
"\n"
1110 <<
" idx_begin=" << idx_begin <<
" n_wd_fpga=" << n_wd_fpga << endl;
1112 return IDX_SKIP_ROC;
1140 int MainDaqParser::ProcessBoardJyTDC2 (
int* words,
int idx_begin,
int idx_roc_end)
1145 int nWordsBoard =
get_hex_bits (words[idx_begin], 3, 4);
1148 if (nWordsBoard == 0) {
1150 return idx_begin + 1;
1153 if (hex7 != 0 || hex54 != 0) {
1159 return idx_begin + 1;
1163 int idx_events_begin = idx_begin + 2;
1164 int idx_events_end = idx_events_begin + nWordsBoard - 1;
1165 if (words[idx_begin + 1] == (
int)0xe906e906) {
1169 if (idx_events_end > idx_roc_end) {
1171 cerr <<
"ERROR: WORD_OVERFLOW: coda " <<
dec_par.
event_count <<
", roc " << (int)
dec_par.
rocID <<
", event_end " << idx_events_end <<
" vs roc_end " << idx_roc_end <<
".\n";
1172 PrintWords(words, idx_events_begin, idx_events_end);
1175 return IDX_SKIP_ROC;
1179 bool header_found =
false;
1180 double time_header = 0;
1181 vector<int > list_chan;
1182 vector<double> list_time;
1183 for (
int idx = idx_events_begin; idx < idx_events_end; idx++) {
1189 int word = words[idx];
1190 if (
get_bin_bit(word, 16) == 0)
Abort(
"Stop signal is not rising. Not supported.");
1191 double fine = 4.0 -
get_hex_bit (word, 0) * 4.0 / 9.0;
1193 time_header = fine + rough;
1194 header_found =
true;
1197 if (! header_found) {
1203 int evt_id = words[idx];
1207 SetEventInfo(evt, evt_id);
1210 for (
unsigned int ii = 0; ii < list_chan.size(); ii++) {
1215 hit.
board = boardID;
1216 hit.
chan = list_chan[ii];
1217 hit.
time = list_time[ii];
1222 header_found =
false;
1226 if (! header_found) {
1232 int word = words[idx];
1238 double fine = 4.0 -
get_hex_bit (word, 0) * 4.0 / 9.0;
1240 double time = time_header - (fine + rough);
1241 if (time < 0) time += 4096;
1242 list_time.push_back(time);
1246 int chan = cable_chan + 16*cable_id;
1247 list_chan.push_back(chan);
1255 return idx_events_end;
1262 int MainDaqParser::ProcessBoardStdTriggerBit (
int* words,
int idx)
1278 int MainDaqParser::ProcessBoardStdTriggerCount (
int* words,
int idx)
1284 for (
int ii = 0; ii < 5; ii++) {
1297 int MainDaqParser::ProcessBoardStdFeeQIE (
int* words,
int idx)
1301 while (words[idx] == (
int)0xe906e906) idx++;
1305 int idx_end = idx + n_wd + 1;
1307 if (n_wd == 0)
return idx;
1309 while (words[idx] == (
int)0xe906e906) { idx++; idx_end++; }
1312 if (n_wd2 == 0x2C) idx += 5;
1320 for (
int i_sum = 0; i_sum < 4 ; i_sum++) {
1338 for (
int i_rf = 0; i_rf < 25; i_rf++) {
1339 if (words[idx] == (
int)0xe906e906)
Abort(
"Unexpected 0xe906e906 in QIE.");
1344 if (idx != idx_end) {
1345 cout << idx <<
" != " << idx_end;
1346 Abort(
"idx != idx_end in StdFeeQIE().");
1354 int MainDaqParser::ProcessBoardStdV1495TDC (
int* words,
int idx)
1360 int boardID = words[idx++];
1364 bool ignore = (
get_bin_bit(words[idx + 1], 12) != 1);
1366 if ((words[idx] & 0xFFFF) == (int)0xd1ad) {
1370 if ((words[idx + 1] & 0xFFFF) == (int)0xd2ad) {
1373 }
else if ((words[idx + 1] & 0xFFFF) == (int)0xd3ad) {
1380 int numChannels = (words[idx] & 0x0000FFFF);
1381 if (numChannels > 255) {
1388 unsigned int stopTime = (words[idx] & 0x00000FFF);
1395 hit.
board = boardID;
1397 for (
int kk = 0; kk < numChannels; kk++) {
1398 unsigned int channel =
get_hex_bits(words[idx+kk], 3, 2);
1399 unsigned int channelTime =
get_hex_bits(words[idx+kk], 1, 2);
1400 double tdcTime = stopTime - channelTime;
1408 return idx + numChannels;
1417 int MainDaqParser::ProcessBoardStdJyTDC2 (
int* words,
int idx_begin,
int idx_roc_end)
1420 int nWordsBoard =
get_hex_bits (words[idx_begin], 3, 4);
1421 if (nWordsBoard == 0)
return idx_begin + 1;
1422 int idx_end = idx_begin + nWordsBoard;
1423 if (idx_end > idx_roc_end) {
1424 cerr <<
"WARNING: Word overflow. Skip ROC (" <<
dec_par.
rocID <<
")" << endl;
1425 return IDX_SKIP_ROC;
1428 int idx = idx_begin + 1;
1429 if (words[idx] == (
int)0xe906e906) idx++;
1431 int trigger_clock_cycle =
get_hex_bit(words[idx], 0);
1432 double trigger_rough = 4.0 *
get_hex_bits(words[idx], 3, 3);
1433 double trigger_fine;
1435 trigger_fine = 4.0 - trigger_clock_cycle * 4.0 / 9.0;
1437 trigger_fine = 0.5 * trigger_clock_cycle;
1439 double trigger_time = trigger_rough + trigger_fine;
1447 hit.
board = boardID;
1449 while (idx < idx_end) {
1451 if (rising && (words[idx] & 0x80000000) == 0) {
1452 double fine = 4.0 -
get_hex_bit (words[idx], 0) * 4.0 / 9.0;
1454 double time = trigger_time - (fine + rough);
1455 if (time < 0) time += 4096;
1459 int chan = cable_chan + 16*cable_id;
1472 int MainDaqParser::PackOneSpillData()
1474 if (
dec_par.
verb > 2) cout <<
"PackOneSpillData(): n=" << list_ed->size() << endl;
1475 m_timers[
"pack_one_spill_data"]->restart();
1488 for (EventDataMap::iterator it = list_ed->begin(); it != list_ed->end(); ) {
1489 unsigned int evt_id = it->first;
1495 it = list_ed->erase(it);
1501 unsigned int n_taiwan = ed->
list_hit .size();
1503 run_data.
n_hit += n_taiwan;
1508 m_timers[
"map_chan"]->restart();
1509 for (
unsigned int ih = 0; ih < n_taiwan; ih++) {
1515 for (
unsigned int ih = 0; ih < n_v1495; ih++) {
1521 m_timers[
"map_chan"]->stop();
1525 list_ed_now = list_ed;
1528 m_timers[
"pack_one_spill_data"]->stop();
1529 m_timer_sp_map->
stop();
1538 void MainDaqParser::SetEventInfo(
EventInfo* evt,
const int eventID)
std::map< unsigned int, EventData > EventDataMap
std::map< unsigned int, SpillData > SpillDataMap
bool Find(const short roc, const short board, const short chan, std::string &name)
bool Find(const short roc, const short board, const short chan, short &det, short &ele)
bool Find(const short roc, const int board, const short chan, short &det, short &ele, short &lvl)
void PrintData(std::ostream &os=std::cout)
void AddTdcError(const int event, const int roc, const TdcError_t type)
void SetFlushError(const bool val)
void SetID(const int run_id, const int spill_id)
bool NextPhysicsEvent(EventData *&ed, SpillData *&sd, RunData *&rd)
int OpenCodaFile(const std::string fname, const long file_size_min=32768, const int sec_wait=15, const int n_wait=40)
Class to measure the time spent by a code block.
double get_accumulated_time() const
bool has_1st_bos
Set 'true' at the 1st BOS event.
int codaID
current Coda event ID
int time_wait
waiting time in second to pretend the online data flow.
long int hitID
current hit ID, commonly used by Hit and TriggerHit.
bool at_bos
Set 'true' at BOS, which triggers parsing the data in one spill.
ChanMapV1495 chan_map_v1495
short spillType
current spill type
short rocID
current ROC ID
ChanMapTaiwan chan_map_taiwan
int verb
Verbosity. 0 = error, 1 = warning, 2 = info, 3 = debug, 4 = insane.
ChanMapScaler chan_map_scaler
unsigned int event_count
current event count
int eventIDstd
current event ID of standard physics events
unsigned int turn_id_max
Max turnOnset in a spill. Used to drop NIM3 events that came after the beam stops....
HitDataList list_hit_trig
unsigned int triggerCount
unsigned int updating_enabled
unsigned int segmentation
unsigned int falling_enabled
unsigned int selectWindow
unsigned int multihit_elim_enabled
double time_input
In msec.
unsigned int eos_vme_time
ScalerDataList list_scaler
double time_decode
In msec.
unsigned int bos_vme_time
SlowControlDataList list_slow_cont