505 ,
unsigned int version,
int verbosity,
unsigned int robsourceid
506 ,
const EventContext& ctx) {
508 int s, c, f, nfrag, ngain, nchan, nsamp,
size, ch, extra = 0, pmt, fragType, nhits = 0;
509 int id,
type, rflag,
unit, pulse, nsmpl, algor, niter;
510 const unsigned int* data;
511 unsigned short time, flag, prev, edge, chan,
bad;
512 char fr[2] = {
'F',
'R' };
513 char gb[2] = {
'G',
'B' };
514 std::string unitName[4] = {
"ADC count",
"pCb",
"Cs pCb",
"MeV" };
515 std::string shapeName[4] = {
"Phys",
"Laser",
"CIS",
"Simul" };
516 std::string algName[8] = {
"Unknown",
"OF1",
"OF2",
"Fit",
"ManyAmps",
"Flat",
"Alg6",
"Alg7" };
517 boost::io::ios_base_all_saver coutsave(std::cout);
526 bool isFrag5 =
false;
528 std::vector<unsigned int> OFC;
532 bool beamROD = (subdet_id == 0x50 || subdet_id >= 0x60);
533 if (subdet_id >= 0x60) {
540 find_frag(roddata, rodsize, version, verbosity, frag.data(), nfrag);
542 if (verbosity > 9)
return;
544 for (f = 0; f < nfrag; ++f) {
546 id = frag[f]->id & 0xFFFF;
547 type = (frag[f]->id >> 16) & 0xFF;
548 rflag = (frag[f]->id) >> 24;
549 unit = (rflag & 0xC0) >> 6;
550 pulse = (rflag & 0x30) >> 4;
551 nsmpl = (rflag & 0x08) >> 3;
552 algor = (rflag & 0x04) >> 2;
553 niter = (rflag & 0x03);
555 data = frag[f]->data;
559 const unsigned char * adc;
560 const unsigned short * result;
561 int tmdb_ch1 = std::min(5U,((robsourceid)>>16)&0xF);
562 bool EB = (tmdb_ch1>2);
564 int tmdb_ch2 = (((robsourceid))&0xF)*nmod;
565 const char * dr56EB[10] = {
"D5-L",
"D5-R",
"D6-L",
"D6-R",
"D4-L",
"D4-R",
"XX-X",
"XX-X",
"XX-X",
"XX-X" };
566 const char * dr56LB[10] = {
"D0-x",
"D1-L",
"D1-R",
"D2-L",
"D2-R",
"D3-L",
"D3-R",
"B8-L",
"B8-R",
"XX-X" };
567 const char ** dr56rl = (EB) ? dr56EB : dr56LB;
568 const char * ch11[6] = {
"AUX",
"LBA",
"LBC",
"EBA",
"EBC",
"UNK" };
569 const char * ch12[6] = {
"aux",
"lba",
"lbc",
"eba",
"ebc",
"unk" };
570 const char * dr56hlEB[4] = {
" D6L ",
" D6H ",
" D56L",
" D56H"};
571 const char * dr56hlLB[4] = {
" DxL ",
" DxH ",
" DxxL",
" DxxH"};
573 const char * dr56thEB[4] = {
" D5 ",
" D6 ",
" D56 ",
"BCID "};
574 const char * dr56thLB[4] = {
" Dx ",
" Dy ",
" Dxy ",
"BCID "};
575 const char ** dr56th = (
m_runPeriod < 3) ? (EB ? dr56hlEB : dr56hlLB)
576 : (EB ? dr56thEB : dr56thLB);
578 const char * tit[4] = {
"TMDB digits",
"TMDB energy",
"TMDB decision",
"Unknown"};
580 std::cout << std::hex << std::endl << tit[
type&3] <<
" fragment 0x" <<
type <<
" vers 0x"<<
id <<
", "
581 << std::dec <<
size <<
" words found"<< std::endl << std::endl;
586 int ntd = (EB) ? 3 : 1;
587 int ntdl = (EB) ? 9 : 5;
595 std::cout <<
"ch cell ";
596 for (
int ind=nsamp; ind>0; --ind) {
597 std::cout <<
" S"<<ind;
599 std::cout << std::endl;
600 adc =
reinterpret_cast<const unsigned char *
>(data);
601 for (
int pword=0;pword<nch;++pword) {
602 int pword1=pword%nchmod;
603 if (!EB && nchmod==8) {
605 if (pword1==0) pword1=9;
608 if (pword1>6) pword1=9;
611 if (pword1>9) pword1=9;
613 std::cout << std::setw(2) << pword <<
" | " << ch11[tmdb_ch1] <<std::setfill(
'0')<<std::setw(2) <<tmdb_ch2+
count
614 <<
"-" <<std::setfill(
' ')<<std::setw(4)<<dr56rl[pword1];
615 for (
int ind=nsamp-1; ind>-1; --ind) {
616 std::cout <<
" | " << std::setw(3) << (
static_cast<unsigned>(adc[pword+nch*ind]) );
618 std::cout << std::endl;
619 if ((pword+1)%nchmod==0)
count+=1;
626 std::cout <<
"ch cell energy" << std::endl;
627 for (
int pword=0;pword<
size;++pword) {
628 int pword1=pword%nchmod;
629 if (!EB && nchmod==8) {
631 if (pword1==0) pword1=9;
634 if (pword1>6) pword1=9;
637 if (pword1>9) pword1=9;
639 std::cout << std::setw(2) << pword<<
" | " << ch11[tmdb_ch1] <<std::setfill(
'0')<<std::setw(2) <<tmdb_ch2+
count
640 <<
"-" <<std::setfill(
' ')<<std::setw(4)<<dr56rl[pword1]
641 <<
" | "<< std::setw(6) <<
static_cast<int>(data[pword])
643 if ((pword+1)%nchmod==0)
count+=1;
649 std::cout <<
"nn name TMDB SL_Board SL_Trigger_Sector "
650 << dr56th[3] << dr56th[2] << dr56th[1] << dr56th[0] << std::endl;
651 result =
reinterpret_cast<const unsigned short *
>(data);
654 int tmdb = (tmdb_ch2) / 8 + 1;
655 int slb = tmdb * 3 - 1;
656 std::string tmdb_name =
"TM0" + (EB ? std::to_string(tmdb) :
"X");
657 for (
int pword = 0; pword < ntd; ++pword) {
658 count = (EB) ? pword * 3 : pword * 4 + 1;
659 unsigned short r = result[pword];
661 int slts1 = slb * 2 - 2;
662 int slts2 = slts1 + 1;
663 std::string slt_sectors =
" - ";
665 std::stringstream slts12;
666 slts12 << std::setfill(
' ') << std::setw(2) << slts1 <<
"-"
667 << std::setfill(
' ') << std::setw(2) << std::left << slts2;
668 slt_sectors = slts12.str();
670 std::stringstream slb_name;
671 slb_name <<
"SL_E" << std::setfill(
'0') << std::setw(2) << (EB ? std::to_string(slb) :
"XX");
672 for(
int pqword = 0; pqword < 4; ++pqword){
673 std::cout << std::setw(2) << pqword + pword * 4 <<
" | "
674 << ((
count > 0 &&
count < ntdl) ? ch11[tmdb_ch1] : ch12[tmdb_ch1])
675 << std::setfill(
'0') << std::setw(2) << tmdb_ch2 +
count
676 << std::setfill(
' ') << std::setw(6) << tmdb_name
677 << std::setfill(
' ') << std::setw(10) << slb_name.str()
678 << std::setfill(
' ') << std::setw(15) << slt_sectors
679 << std::setfill(
' ') << std::setw(11) << ((
m_runPeriod < 3) ? ((
r >> 3) & 1) : bcid)
680 << std::setw(5) << ((
r >> 2) & 1) << std::setw(5) << ((
r >> 1) & 1) << std::setw(5) << (
r & 1) << std::endl;
685 if (slb > 24) slb = 1;
693 }
else if (
id < 0x100 || beamROD) {
701 if ((
type == 0x1) || (
type == 0x2)) {
702 bool isLastChannelEOB = ((data[
size - 1] >> 24) & 0x7) == 0x4;
704 std::cout <<
"\nBeam ToF TDC, ";
706 std::cout <<
"\nBeam TDC 0x" << std::setfill(
'0') << std::hex << std::setw(2) <<
id <<
setupDec <<
", ";
708 std::cout << (isLastChannelEOB ?
size - 1 :
size) <<
" hits found";
710 for (c = 0; c <
size; ++c) {
711 time = data[c] & 0x1FFF;
712 unsigned short res1 = (data[c] >> 13) & 0x1;
714 chan = (
type == 0x1) ? (data[c] >> 17) & 0x3FF
715 : (data[c] >> 16) & 0x7FF;
718 int wordType = (data[c] >> 24) & 0x7;
719 if (wordType == 0x2) {
720 std::cout <<
"\n header, " << ((data[c] >> 8) & 0x3F) <<
" channels";
721 }
else if (wordType == 0x4) {
722 std::cout <<
"\n end of block, event counter: " << (data[c] & 0xFFFFFF) << std::endl;
724 std::cout <<
"\n unknown word: 0x" << std::hex << data[c] << std::dec << std::endl;
729 std::cout <<
"\n ch" << std::setw(3) << chan <<
":";
732 }
else if (nhits % 8 == 0) {
737 std::cout <<
" U" << std::setw(4) << time;
739 std::cout <<
" " << std::setw(4) << time;
742 std::cout << std::endl;
752 std::cout <<
"\nBeam TDC 0x" << std::setfill(
'0') << std::hex << std::setw(2) <<
id <<
setupDec <<
", " <<
size <<
" hits found";
754 for (c = 0; c <
size; ++c) {
755 time = data[c] & 0xFFFF;
756 flag = data[c] >> 16;
758 chan = (flag >> 1) & 0x0F;
759 bad = (flag >> 5) & 0x01;
764 std::cout <<
"\n ch" << std::setw(3) << chan <<
":";
767 }
else if (nhits % 8 == 0) {
772 std::cout <<
" " << gb[
bad] << fr[edge] << std::setw(6) << time;
774 std::cout <<
" " << fr[edge] << std::setw(6) << time;
777 std::cout << std::endl;
782 if ((
type == 0x1) || (
type == 0x2)) {
783 bool isLastChannelEOB = ((data[
size - 1] >> 24) & 0x7) == 0x4;
784 std::cout <<
"\nBeam ADC, " << (isLastChannelEOB ?
size - 1 :
size) <<
" hits found";
786 for (c = 0; c <
size; ++c) {
787 time = data[c] & 0x1FFF;
788 unsigned short res1 = (data[c] >> 13) & 0x1;
789 chan = (
type == 0x1) ? (data[c] >> 17) & 0x3FF
790 : (data[c] >> 16) & 0x7FF;
793 int wordType = (data[c] >> 24) & 0x7;
794 if (wordType == 0x2) {
795 std::cout <<
"\n header, " << ((data[c] >> 8) & 0x3F) <<
" channels";
796 }
else if (wordType == 0x4) {
797 std::cout <<
"\n end of block, event counter: " << (data[c] & 0xFFFFFF) << std::endl;
799 std::cout <<
"\n unknown word: 0x" << std::hex << data[c] << std::dec << std::endl;
804 std::cout <<
"\n ch" << std::setw(3) << chan <<
":";
807 }
else if (nhits % 8 == 0) {
812 std::cout <<
" U" << std::setw(4) << time;
814 std::cout <<
" " << std::setw(4) << time;
817 std::cout << std::endl;
827 std::cout <<
"\nTile Beam ADC, " <<
size <<
" channels found";
829 std::cout <<
"\nBeam ADC 0x" << std::hex << std::setfill(
'0') << std::setw(2) <<
id <<
setupDec <<
", " <<
size <<
" channels found";
831 for (c = 0; c <
size; ++c) {
832 if (c % 8 == 0) std::cout <<
setupMod << c / 8 <<
":";
833 std::cout << std::setw(9) << data[c];
835 std::cout << std::endl;
839 std::cout <<
"\nMuon ADC, " <<
size <<
" channels found";
840 for (c = 0; c <
size; ++c) {
841 if (c % 8 == 0) std::cout <<
setupMod << c / 8 <<
":";
842 std::cout << std::setw(9) << data[c];
844 std::cout << std::endl;
848 std::cout <<
"\nMuon2 ADC, " <<
size <<
" channels found";
849 for (c = 0; c <
size; ++c) {
850 if (c % 8 == 0) std::cout <<
setupMod << c / 8 <<
":";
851 std::cout << std::setw(9) << data[c];
853 std::cout << std::endl;
859 std::cout<<
"\nLaser Pattern Unit, " <<
size <<
" words found (hex)";
861 std::cout<<
"\nCommon Pattern Unit, " <<
size <<
" words found (hex)";
863 for (c = 0; c <
size; ++c) {
864 if (c % 8 == 0) std::cout <<
setupMod << c/8 <<
":";
867 std::cout << std::endl;
873 std::cout<<
"\nLASTROD Laser Object, " <<
size <<
" words found (hex)";
874 for (c = 0; c <
size; ++c) {
875 if (c % 8 == 0) std::cout <<
setupMod << c/8 <<
":";
878 std::cout<<std::endl<<std::endl;
881 std::cout<<
"CRITICAL ERROR! Unknown format!"<<std::endl;
883 const unsigned int * p;
885 int Filter = 0, ReqAmp = 0, MeasAmp = 0, Delay = 0, TDC1 = 0, TDC2 = 0;
889 std::cout <<
" Laser Counter: " << std::setw(5) << Counter << std::endl;
891 if ((*p & 0xFF000000) == 0x20000000) {
892 ReqAmp = *p & 0xFFFF;
894 Filter = (((*p >> 16) & 7) ^ 7) + 2;
895 if (Filter > 8) Filter -= 8;
896 std::cout <<
" Filter Wheel: " << std::setw(5) << Filter << std::endl;
898 std::cout <<
" Required Amp: " << std::setw(5) << ReqAmp << std::endl;
900 std::cout <<
"ERROR in Laser Fragment: decoding word 14." << std::endl;
904 if ((*p & 0xFF000000) == 0x21000000) {
905 Delay = (*p >> 12) & 0xFFF;
906 MeasAmp = *p & 0xFFF;
907 std::cout <<
" Measured Amp: " << std::setw(5) << MeasAmp << std::endl;
908 std::cout <<
" Delay: " << std::setw(5) << Delay << std::endl;
910 std::cout <<
"ERROR in Laser Fragment: decoding word 15." << std::endl;
914 bool TDCPrint =
true;
916 if ((*p & 0xFF000000) == 0x22000000) {
918 TDC1 = (*p >> 16) & 0xF;
919 TDC2 = (*p >> 20) & 0xF;
924 std::cout <<
"ERROR in Laser Fragment: decoding word 16." << std::endl;
928 if ((*p & 0xFF000000) == 0x23000000) {
930 TDC1 = (TDC1 << 12) + (*p & 0xFFF);
931 TDC2 = (TDC2 << 12) + ((*p >> 12) & 0xFFF);
936 std::cout <<
"ERROR in Laser Fragment: decoding word 17." << std::endl;
941 std::cout <<
" TDC1 data: " << std::setw(5) << TDC1 << std::endl;
942 std::cout <<
" TDC2 data: " << std::setw(5) << TDC2 << std::endl;
945 int chan0 = 0, chan1 = 0, chan2 = 0, chan3 = 0, chan4 = 0, chan5 = 0, chan6 = 0, chan7 = 0;
947 if ((*p & 0xFF000000) == 0x44000000) {
948 chan0 = (*p & 0xFFF) ^ 0xFFF;
949 chan1 = ((*p >> 12) & 0xFFF) ^ 0xFFF;
951 std::cout <<
"ERROR in Laser Fragment: decoding word 18." << std::endl;
955 if ((*p & 0xFF000000) == 0x45000000) {
956 chan2 = (*p & 0xFFF) ^ 0xFFF;
957 chan3 = ((*p >> 12) & 0xFFF) ^ 0xFFF;
959 std::cout <<
"ERROR in Laser Fragment: decoding word 19." << std::endl;
963 if ((*p & 0xFF000000) == 0x46000000) {
964 chan4 = (*p & 0xFFF) ^ 0xFFF;
965 chan5 = ((*p >> 12) & 0xFFF) ^ 0xFFF;
967 std::cout <<
"ERROR in Laser Fragment: decoding word 20." << std::endl;
971 if ((*p & 0xFF000000) == 0x47000000) {
972 chan6 = (*p & 0xFFF) ^ 0xFFF;
973 chan7 = ((*p >> 12) & 0xFFF) ^ 0xFFF;
975 std::cout <<
"ERROR in Laser Fragment: decoding word 21." << std::endl;
979 int diode1_Ped = 0, diode1_PedRMS = 0
980 , diode2_Ped = 0, diode2_PedRMS = 0
981 , diode3_Ped = 0, diode3_PedRMS = 0
982 , diode4_Ped = 0, diode4_PedRMS = 0
983 , PMT1_Ped = 0, PMT1_PedRMS = 0
984 , PMT2_Ped = 0, PMT2_PedRMS = 0;
986 diode1_Ped = (*p >> 16) & 0xFFFF;
987 diode1_PedRMS = *p & 0xFFFF;
990 diode2_Ped = (*p >> 16) & 0xFFFF;
991 diode2_PedRMS = *p & 0xFFFF;
994 diode3_Ped = (*p >> 16) & 0xFFFF;
995 diode3_PedRMS = *p & 0xFFFF;
998 diode4_Ped = (*p >> 16) & 0xFFFF;
999 diode4_PedRMS = *p & 0xFFFF;
1002 PMT1_Ped = (*p >> 16) & 0xFFFF;
1003 PMT1_PedRMS = *p & 0xFFFF;
1006 PMT2_Ped = (*p >> 16) & 0xFFFF;
1007 PMT2_PedRMS = *p & 0xFFFF;
1010 time_t Ped_Last_Run = *p;
1013 int diode1_alpha = 0, diode1_alphaRMS = 0
1014 , diode2_alpha = 0, diode2_alphaRMS = 0
1015 , diode3_alpha = 0, diode3_alphaRMS = 0
1016 , diode4_alpha = 0, diode4_alphaRMS = 0;
1018 diode1_alpha = (*p >> 16) & 0xFFFF;
1019 diode1_alphaRMS = *p & 0xFFFF;
1022 diode2_alpha = (*p >> 16) & 0xFFFF;
1023 diode2_alphaRMS = *p & 0xFFFF;
1026 diode3_alpha = (*p >> 16) & 0xFFFF;
1027 diode3_alphaRMS = *p & 0xFFFF;
1030 diode4_alpha = (*p >> 16) & 0xFFFF;
1031 diode4_alphaRMS = *p & 0xFFFF;
1034 time_t Alpha_Last_Run = *p;
1037 time_t PedAlpha_Last_Run(0);
1039 int diode1_PedAlpha = 0, diode1_PedAlphaRMS = 0
1040 , diode2_PedAlpha = 0, diode2_PedAlphaRMS = 0
1041 , diode3_PedAlpha = 0, diode3_PedAlphaRMS = 0
1042 , diode4_PedAlpha = 0, diode4_PedAlphaRMS = 0;
1045 diode1_PedAlpha = (*p >> 16) & 0xFFFF;
1046 diode1_PedAlphaRMS = *p & 0xFFFF;
1049 diode2_PedAlpha = (*p >> 16) & 0xFFFF;
1050 diode2_PedAlphaRMS = *p & 0xFFFF;
1053 diode3_PedAlpha = (*p >> 16) & 0xFFFF;
1054 diode3_PedAlphaRMS = *p & 0xFFFF;
1057 diode4_PedAlpha = (*p >> 16) & 0xFFFF;
1058 diode4_PedAlphaRMS = *p & 0xFFFF;
1061 PedAlpha_Last_Run = *p;
1065 std::cout << std::endl <<
" | ADC | Pedestal(RMS) | Alpha (RMS) | PedAlpha(RMS) |" << std::endl;
1067 std::cout <<
" Diode 1 | " << std::setw(5) << chan0 <<
" | " <<
setupPr1 << diode1_Ped / 10.0 <<
" (" <<
setupPr2 << diode1_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode1_alpha / 10.0 <<
" (" <<
setupPr2 << diode1_alphaRMS / 100.0 <<
") |" << std::endl;
1068 std::cout <<
" Diode 2 | " << std::setw(5) << chan1 <<
" | " <<
setupPr1 << diode2_Ped / 10.0 <<
" (" <<
setupPr2 << diode2_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode2_alpha / 10.0 <<
" (" <<
setupPr2 << diode2_alphaRMS / 100.0 <<
") |" << std::endl;
1069 std::cout <<
" Diode 3 | " << std::setw(5) << chan2 <<
" | " <<
setupPr1 << diode3_Ped / 10.0 <<
" (" <<
setupPr2 << diode3_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode3_alpha / 10.0 <<
" (" <<
setupPr2 << diode3_alphaRMS / 100.0 <<
") |" << std::endl;
1070 std::cout <<
" Diode 4 | " << std::setw(5) << chan3 <<
" | " <<
setupPr1 << diode4_Ped / 10.0 <<
" (" <<
setupPr2 << diode4_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode4_alpha / 10.0 <<
" (" <<
setupPr2 << diode4_alphaRMS / 100.0 <<
") |" << std::endl;
1072 std::cout <<
" Diode 1 | " << std::setw(5) << chan0 <<
" | " <<
setupPr1 << diode1_Ped / 10.0 <<
" (" <<
setupPr2 << diode1_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode1_alpha / 10.0 <<
" (" <<
setupPr2 << diode1_alphaRMS / 100.0 <<
") | " <<
setupPr1 << diode1_PedAlpha / 10.0 <<
" (" <<
setupPr2 << diode1_PedAlphaRMS / 100.0 <<
") |" << std::endl;
1073 std::cout <<
" Diode 2 | " << std::setw(5) << chan1 <<
" | " <<
setupPr1 << diode2_Ped / 10.0 <<
" (" <<
setupPr2 << diode2_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode2_alpha / 10.0 <<
" (" <<
setupPr2 << diode2_alphaRMS / 100.0 <<
") | " <<
setupPr1 << diode2_PedAlpha / 10.0 <<
" (" <<
setupPr2 << diode2_PedAlphaRMS / 100.0 <<
") |" << std::endl;
1074 std::cout <<
" Diode 3 | " << std::setw(5) << chan2 <<
" | " <<
setupPr1 << diode3_Ped / 10.0 <<
" (" <<
setupPr2 << diode3_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode3_alpha / 10.0 <<
" (" <<
setupPr2 << diode3_alphaRMS / 100.0 <<
") | " <<
setupPr1 << diode3_PedAlpha / 10.0 <<
" (" <<
setupPr2 << diode3_PedAlphaRMS / 100.0 <<
") |" << std::endl;
1075 std::cout <<
" Diode 4 | " << std::setw(5) << chan3 <<
" | " <<
setupPr1 << diode4_Ped / 10.0 <<
" (" <<
setupPr2 << diode4_PedRMS / 100.0 <<
") | " <<
setupPr1 << diode4_alpha / 10.0 <<
" (" <<
setupPr2 << diode4_alphaRMS / 100.0 <<
") | " <<
setupPr1 << diode4_PedAlpha / 10.0 <<
" (" <<
setupPr2 << diode4_PedAlphaRMS / 100.0 <<
") |" << std::endl;
1078 std::cout <<
" PMT 1 | " << std::setw(5) << chan4 <<
" | " <<
setupPr1 << PMT1_Ped / 10.0 <<
" (" <<
setupPr2 << PMT1_PedRMS / 100.0 <<
") | x | x |" << std::endl;
1079 std::cout <<
" PMT 2 | " << std::setw(5) << chan5 <<
" | " <<
setupPr1 << PMT2_Ped / 10.0 <<
" (" <<
setupPr2 << PMT2_PedRMS / 100.0 <<
") | x | x |" << std::endl;
1080 std::cout <<
" InjChrg | " << std::setw(5) << chan6 <<
" | x | x | x |" << std::endl;
1081 std::cout <<
" Spare | " << std::setw(5) << chan7 <<
" | x | x | x |" << std::endl;
1083 std::cout << std::endl <<
" | Date & Time (GMT) | Date & Time (CERN)" << std::endl;
1087 gmtime_r(&Ped_Last_Run, &TimeInfo);
1088 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1090 std::cout <<
" Pedestal | " << buf <<
" | " <<
cern_local_time(Ped_Last_Run) << std::endl;
1092 gmtime_r(&Alpha_Last_Run, &TimeInfo);
1093 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1095 std::cout <<
" Alpha | " << buf <<
" | " <<
cern_local_time(Alpha_Last_Run) << std::endl;
1097 gmtime_r(&PedAlpha_Last_Run, &TimeInfo);
1098 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1100 std::cout <<
" PedAlpha | " << buf <<
" | " <<
cern_local_time(PedAlpha_Last_Run) << std::endl;
1102 int diodeTemp = 0, secsDiodeT = 0
1103 , boxTemp = 0, secsBoxT = 0
1104 , boxHum = 0, secsBoxH = 0
1105 , gasFlow = 0, secsGasF = 0;
1107 diodeTemp = *p & 0xFFF;
1108 secsDiodeT = (*p >> 12) & 0xFFFFF;
1110 boxTemp = *p & 0xFFF;
1111 secsBoxT = (*p >> 12) & 0xFFFFF;
1113 boxHum = *p & 0xFFF;
1114 secsBoxH = (*p >> 12) & 0xFFFFF;
1116 gasFlow = *p & 0xFFF;
1117 secsGasF = (*p >> 12) & 0xFFFFF;
1120 std::cout << std::endl <<
" | Time | Value |" << std::endl;
1121 std::cout <<
" Laser diode temp | " << std::setw(7) << secsDiodeT <<
" | " <<
setupPr3 << diodeTemp / 10.0 <<
" |" << std::endl;
1122 std::cout <<
" Laser box temp | " << std::setw(7) << secsBoxT <<
" | " <<
setupPr3 << boxTemp / 10.0 <<
" |" << std::endl;
1123 std::cout <<
" Laser box humidity | " << std::setw(7) << secsBoxH <<
" | " <<
setupPr3 << boxHum / 10.0 <<
" |" << std::endl;
1124 std::cout <<
" Laser box gas flow | " << std::setw(7) << secsGasF <<
" | " <<
setupPr3 << gasFlow / 10.0 <<
" |" << std::endl;
1126 std::bitset<32> PLCstatus = *p;
1127 int PLCtime = (*p >> 12) & 0xFFFFF;
1130 int Alpha0 = PLCstatus[0];
1131 int Alpha1 = PLCstatus[1];
1132 int Alpha2 = PLCstatus[2];
1133 int LV = PLCstatus[3];
1134 int HV1 = PLCstatus[4];
1135 int HV2 = PLCstatus[5];
1136 int ShOpen = PLCstatus[6];
1137 int ShClose = PLCstatus[7];
1138 int Ilock = PLCstatus[8];
1139 int Alarm = PLCstatus[9];
1140 int Err = PLCstatus[11];
1142 const char *YesNo[2] = {
" No",
"Yes"};
1143 const char *OnOff[2] = {
"Off",
" On"};
1145 std::cout << std::endl <<
" Time | Err | Alarm | Ilock | ShClose | ShOpen | HV2 | HV1 | LV | Alpha2 | Alpha1 | Alpha0 |"
1146 << std::endl <<
" " << std::setw(7) << PLCtime
1147 <<
" | " << YesNo[Err] <<
" | " << OnOff[Alarm] <<
" | " << OnOff[Ilock] <<
" | " << YesNo[ShClose]
1148 <<
" | " << YesNo[ShOpen] <<
" | " << OnOff[HV2] <<
" | " << OnOff[HV1] <<
" | " << OnOff[LV]
1149 <<
" | " << OnOff[Alpha2] <<
" | " << OnOff[Alpha1] <<
" | " << OnOff[Alpha0] <<
" |" << std::endl;
1151 if (p != &data[
size]) {
1152 std::cout <<
"CRITICAL ERROR! Wrong size" << std::endl;
1162 std::cout<<
"\nLASTROD New Laser Object, " <<
size <<
" words found" << std::endl;
1164 bool first_half_present = (
size == 25 ||
size == 26 ||
size == 128 ||
size == 129);
1165 bool second_half_present = (
size == 99 ||
size == 100 ||
size == 128 ||
size == 129);
1167 if ( ! (first_half_present || second_half_present) ) {
1168 std::cout <<
"CRITICAL ERROR! Unknown format!" << std::endl;
1171 const char *name[17] = {
" PhotoDiode 0",
1194 const unsigned int * p = data;
1196 if (first_half_present) {
1204 std::cout << std::endl <<
" DAQ type: " << std::setw(5) << (data[0]%0xFF) << std::endl;
1205 std::cout <<
" Laser Counter: " << std::setw(5) << data[1] << std::endl;
1206 std::cout <<
" Required Amp: " << std::setw(5) << (data[2]>>16) << std::endl;
1207 std::cout <<
" Measured Amp: " << std::setw(5) << (data[2]&0xFFFF) << std::endl;
1208 std::cout <<
" Filter Wheel: " << std::setw(5) << (data[3]>>16 & 0x000F) << std::endl;
1209 std::cout <<
" Delay: " << std::setw(5) << (data[3]&0xFFFF) << std::endl;
1210 std::cout <<
" Linearity DAC: " << std::setw(5) << (data[4]&0xFFFF) << std::endl;
1211 std::cout << std::endl;
1215 std::cout <<
" HG LG" << std::endl;
1216 for (
int n=0; n<17; ++n) {
1218 std::cout << name[n] <<
": " << std::setw(5) << ((*p)&0xFFFF) << std::setw(6) << ((*p)>>16) <<
" => " << std::setw(5) << (8500-((*p)&0xFFFF)) << std::setw(6) << (8500-((*p)>>16))<< std::endl;
1239 std::bitset<32> status = *(p++);
1240 const char *YesNo[2] = {
" No",
"Yes"};
1241 std::cout << std::endl;
1242 std::cout <<
"| Link| Link| Bad | Bad | TTC | TTC | PLL | PLL |Laser|Laser|Inter| Comb| Busy| Long|" << std::endl;
1243 std::cout <<
"| not | not | VME | TTC |doubl|singl| lock| lock| temp| diod| lock| run | | busy|" << std::endl;
1244 std::cout <<
"| full| down|clock|clock|error|error| VME | TTC |fault| off |close| fini| |>5sec|" << std::endl;
1245 std::cout <<
"|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|" << std::endl;
1246 std::cout <<
"| " << YesNo[status[27]] <<
" | " << YesNo[status[26]] <<
" | " << YesNo[status[24]] <<
" | " << YesNo[status[22]] <<
" | " << YesNo[status[20]] <<
" | " << YesNo[status[19]] <<
" | " << YesNo[status[16]] <<
" | " << YesNo[status[15]] <<
" | " << YesNo[status[10]] <<
" | " << YesNo[status[9]] <<
" | " << YesNo[status[8]] <<
" | " << YesNo[status[6]] <<
" | " << YesNo[status[1]] <<
" | " << YesNo[status[0]] <<
" |" << std::endl;
1248 std::cout << std::endl <<
" FPGA Global Status: 0x" << std::hex
1249 << status.to_ulong() <<
" => " << status.to_string() << std::dec << std::endl;
1251 gmtime_r(&tim, &TimeInfo);
1252 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1253 std::cout <<
"DCS Time Stamp (GMT): " << buf <<
" => " <<
cern_local_time(tim) << std::endl;
1254 std::cout <<
" PhotoDiode Polarity: " << std::setw(5) << (*p++) << std::endl;
1258 if (second_half_present) {
1259 std::cout <<
" Calibration Type: " << std::setw(5) << (*p++) << std::endl;
1261 gmtime_r(&tim, &TimeInfo);
1262 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1263 std::cout <<
" Time Stamp (GMT): " << buf <<
" => " <<
cern_local_time(tim) << std::endl;
1265 double nevt = double(p[96]);
1266 if (p[96]==0 || (p[96]==3072 && (*p)<21504000)) {
1267 std::cout <<
" Number of events: " << p[96] <<
" => assuming 1024" << std::endl << std::endl;
1270 std::cout <<
" Number of events: " << std::setw(5) << p[96] << std::endl << std::endl;
1272 std::cout <<
" pedHG rmsHG pedLG rmsLG" << std::endl;
1273 for (
int n=0; n<16; ++n) {
1275 uint32_t sum0 = *(p++);
1276 uint32_t sum1 = *(p++);
1278 uint32_t lsb0 = *(p++);
1279 uint32_t msb0 = *(p++);
1280 uint32_t lsb1 = *(p++);
1281 uint32_t msb1 = *(p++);
1282 uint64_t ssq0 = ((uint64_t) msb0 << 32) | ((uint64_t) lsb0);
1283 uint64_t ssq1 = ((uint64_t) msb1 << 32) | ((uint64_t) lsb1);
1286 double ped0 = double(sum0)/nevt;
1287 double ped1 = double(sum1)/nevt;
1289 double rms0 = double(ssq0)/nevt - ped0*ped0;
1290 double rms1 = double(ssq1)/nevt - ped1*ped1;
1291 if (rms0>0.0) rms0 = sqrt(rms0);
1292 if (rms1>0.0) rms1 = sqrt(rms1);
1294 std::cout << name[n] <<
":" << std::setw(11) << sum0 << std::setw(11) << sum1 << std::setw(11) << msb0 << std::setw(11) << lsb0 << std::setw(11) << msb1 << std::setw(11) << lsb1 <<
" => " << std::setw(7) << std::setprecision(1) << 8500.-ped0 <<
" +/- " << std::setw(7) << std::setprecision(1) << rms0 <<
" " << std::setw(7) << std::setprecision(1) << 8500.-ped1 <<
" +/- " << std::setw(7) << std::setprecision(1) << rms1 << std::endl;
1302 std::cout <<
"\nLaser ADC, " <<
size <<
" channels found";
1303 for (c = 0; c <
size; ++c) {
1304 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1305 std::cout << std::setw(9) << data[c];
1307 std::cout << std::endl;
1311 std::cout <<
"\nECAL ADC, " <<
size <<
" channels found";
1312 for (c = 0; c <
size; ++c) {
1313 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1314 std::cout << std::setw(9) << data[c];
1316 std::cout << std::endl;
1320 std::cout <<
"\nDigi parameters, " <<
size <<
" words found";
1321 for (c = 0; c <
size; ++c) {
1322 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1323 std::cout << std::setw(11) << data[c];
1325 std::cout << std::endl;
1328 const unsigned int *p = data;
1329 int Counter = 0, Mode = 0, Samples = 0, Pipeline = 0, I3Delay = 0,
Event = 0, Phase = 0,
1330 DAC = 0, Capacity = 0, Card = 0, RunType = 0, microsec = 0;
1332 bool DefFormat =
true;
1333 if (
size == 4) DefFormat =
false;
1357 const char *RunTypeText;
1359 case 1: RunTypeText =
"Physics";
break;
1360 case 2: RunTypeText =
"Laser";
break;
1361 case 4: RunTypeText =
"Pedestals";
break;
1362 case 8: RunTypeText =
"CIS mono";
break;
1363 case 16: RunTypeText =
"CIS scan";
break;
1364 default: RunTypeText =
"Unknown";
break;
1367 std::cout <<
"\n CIS Counter: " << std::setw(3) << Counter<< std::endl;
1368 std::cout <<
"\n Run Type: " << std::setw(3) << RunType <<
" (" << RunTypeText <<
")";
1370 std::cout <<
"\n Samples: " << std::setw(3) << Samples;
1371 std::cout <<
"\n Pipeline: " << std::setw(3) << Pipeline << std::endl;
1373 const char* ModeText;
1376 ModeText =
"Normal";
1378 case 1: ModeText =
"Calibration";
break;
1379 default: ModeText =
"Unknown";
break;
1384 gmtime_r(&Time, &TimeInfo);
1385 strftime(buf, 80,
"%d.%m.%Y %H:%M:%S", &TimeInfo);
1386 std::cout << std::endl;
1387 std::cout <<
" Time (GMT): " << buf <<
" => " <<
cern_local_time(Time) << std::endl;
1388 std::cout <<
" Microsec.: " << microsec << std::endl << std::endl;
1389 std::cout <<
" Mode: " << std::setw(3) << Mode <<
" (" << ModeText <<
")" << std::endl;
1390 std::cout <<
" Samples: " << std::setw(3) << Samples << std::endl;
1391 std::cout <<
" Pipeline: " << std::setw(3) << Pipeline << std::endl;
1392 std::cout <<
" I3Delay: " << std::setw(3) << I3Delay << std::endl;
1393 std::cout <<
" Event: " << std::setw(3) <<
Event << std::endl;
1394 std::cout <<
" Phase: " << std::setw(3) << Phase << std::endl;
1395 std::cout <<
" DAC: " << std::setw(3) << DAC << std::endl;
1396 std::cout <<
" Capacity: " << std::setw(3) << Capacity <<
" pF" << std::endl;
1397 std::cout <<
" Card: " << std::setw(3) << Card << std::endl;
1400 int last =
size - 1;
1401 for (; last > 15; --last) {
1402 if (data[last] != 0)
break;
1405 std::cout <<
"\n Remaing " << last - 15 <<
" non-zero words (hex):";
1406 for (c = 16; c <= last; ++c) {
1407 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1408 std::cout << std::hex << std::setw(11) << data[c] << std::dec;
1410 std::cout << std:: endl;
1415 std::cout <<
"CRITICAL ERROR! Unknown format!" << std::endl;
1420 std::cout <<
"\nAdder FADC, " <<
size <<
" words found (hex)" ;
1421 for (c = 0; c <
size; ++c) {
1422 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1423 std::cout << std::hex << std::setw(9) << data[c] << std::dec;
1425 std::cout << std::endl;
1436 std::cout <<
"\nCoincidence trigger frag " <<
id -
COIN_TRIG1_FRAG + 1 <<
", " <<
size <<
" words found (hex)";
1437 for (c = 0; c <
size; ++c) {
1438 if (c % 8 == 0) std::cout <<
setupMod << c/8<<
":";
1439 std::cout << std::hex << std::setw(11) << data[c] << std::dec;
1441 std::cout << std::endl;
1445 std::cout <<
"\nUnknown fragment [0x" << std::hex <<
id << std::dec <<
"], " <<
size <<
" words found" << std::endl;
1452 fragType = (*itr).second;
1454 fragType = (
id >> 8);
1455 if (fragType > 4 || fragType < 1) fragType = 2;
1466 std::cout <<
"\nDigitizer fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found:"
1467 <<
"\t" << nchan / 3 <<
" chips, " << nsamp <<
"+2 samples" << std::endl;
1470 extra =
size - nchan * (nsamp + 2) / 3;
1471 }
else if (ngain == 2) {
1472 extra =
size - nchan / 2 * (2 * nsamp + 3) / 3;
1477 if (version == 0x1 || version == 0x2) {
1478 std::cout <<
"\nfirst data word:" << std::setw(12) << data[0] <<
" (0x"<<
setup0 << data[0] <<
setupDec <<
")";
1483 std::cout <<
"\n" << std::setw(3) << extra <<
" extra words:";
1484 for (c =
size - extra; c <
size; ++c) {
1485 std::cout << std::setw(12) << data[c] <<
" (0x"<<
setup0 << data[c] <<
setupDec <<
")";
1486 if ((c -
size + extra) % 2 == 1 && c!=
size-1) std::cout <<
"\n ";
1488 std::cout << std::endl;
1491 std::cout <<
"\nPMT Ch | BCID M G";
1492 for (s = 0; s < nsamp; ++s) {
1493 std::cout << std::setw(4) << s <<
" ";
1496 std::cout <<
" Head/Data/CRC\n---|---|-------------------------";
1497 for (s = 0; s < nsamp; ++s) {
1498 std::cout <<
"-----";
1503 for (ch = 0; ch < nchan; ++ch) {
1504 pmt =
m_cabling->channel2hole(fragType, ch % 48);
1505 if (extra == 0 && pmt < 0) pmt = -pmt;
1508 std::cout <<
"\n" << std::setw(3) << pmt << std::setw(3) << ch <<
" |";
1510 std::cout <<
"\n -- " << std::setw(2) << ch <<
" |";
1514 std::cout << std::setw(5) << (channel[ch].bcid) << std::setw(2) << ((channel[ch].flag >> 3) & 3);
1519 std::cout << std::setw(2) << (channel[ch].gain);
1521 for (s = 0; s < nsamp; ++s) {
1522 std::cout << std::setw(5) << (channel[ch].sample[s]);
1526 if (channel[ch].
head != 0) {
1527 std::cout <<
" 0x" <<
setup0 << channel[ch].head <<
setupDec <<
" Head";
1529 std::cout <<
" " <<
setup0 << channel[ch].head <<
setupDec <<
" Head";
1534 if (channel[ch].first != 0) {
1535 std::cout <<
" 0x" <<
setup0 << channel[ch].first <<
setupDec <<
" Data";
1537 std::cout <<
" " <<
setup0 << channel[ch].first <<
setupDec <<
" Data";
1542 if (channel[ch].crc != 0) {
1543 std::cout <<
" 0x" <<
setup0 << channel[ch].crc <<
setupDec <<
" CRC ";
1545 std::cout <<
" " <<
setup0 << channel[ch].crc <<
setupDec <<
" CRC ";
1565 for (
int i = 0; i < 7; i++) {
1566 if (Frag5Data[ch].s[i] != channel[ch].sample[i]) chOK =
false;
1569 std::cout <<
" RawERR ";
1572 for (
int i = 0; i < 7; i++) {
1573 std::cout << std::setw(5) << Frag5Data[ch].
s[i] ;
1578 if (!OK) std::cout <<
"\nOF weights: ERROR";
1582 std::cout << std::endl;
1584 for (
int ch = 0; ch < 48; ch++) {
1586 for (
int i = 0; i < 7; i++) {
1587 if (Frag5Data[ch].s[i] != channel[ch].sample[i]) chOK =
false;
1600 if (Frag5Data[ch].gain != (
int) channel[ch].gain) chOK =
false;
1603 std::cout <<
" " << ch <<
",";
1606 std::cout <<
"\nCompare Raw <=> Frag5: ";
1608 std::cout <<
"OK" << std::endl;
1610 std::cout <<
"ERROR" << std::endl;
1618 std::cout <<
"\nRaw data compressed fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found" << std::endl;
1623 std::cout <<
"\nRaw data compressed fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found:"
1624 <<
"\t" << ngain <<
" gain, " << nchan <<
" channels in total" << std::endl;
1626 std::cout <<
"\nPMT Ch |";
1627 for (
int j = 1; j <= ((nsamp / 2) + 1); j++) {
1628 std::cout <<
" HexWord" << j <<
" ";
1632 for (
int l = 1; l <= nsamp; l++) {
1633 std::cout <<
" Smp" << l;
1637 int ch = rawcomp[i].chan;
1638 pmt =
m_cabling->channel2hole(fragType, ch % 48);
1640 std::cout <<
"\n" << std::setw(3) << pmt << std::setw(3) << ch <<
" |";
1642 std::cout <<
"\n -- " << std::setw(2) << ch <<
" |";
1644 std::cout << std::hex << std::setfill(
'0');
1645 for (
int j = 0; j < ((nsamp / 2) + 1); j++) {
1646 std::cout <<
" " << std::setw(8) << rawcomp[i].words[j] <<
" ";
1648 std::cout <<
setupDec <<
"| " << rawcomp[i].gain;
1649 for (
int l = 0; l < nsamp; l++) {
1650 std::cout << std::setw(6) << rawcomp[i].samples[l];
1652 if (!rawcomp[i].verif) std::cout <<
" Wrong Data";
1659 std::cout <<
"\nReco non calibrated energy fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found:"
1660 <<
"\t" << ngain <<
" gain, " << nchan <<
" channels in total" << std::endl
1661 <<
"\tATTENTION: HIGH gain amplitude is divided by 64" << std::endl;
1663 std::cout <<
"\nPMT Ch | full word | G amp time q amp time qual";
1664 for (ch = 0; ch < nchan; ++ch) {
1665 pmt =
m_cabling->channel2hole(fragType, ch % 48);
1667 std::cout <<
"\n" << std::setw(3) << pmt << std::setw(3) << ch <<
" |";
1669 std::cout <<
"\n -- " << std::setw(2) << ch <<
" |";
1671 std::cout <<
" 0x" <<
setup0 << recochan[ch].word <<
setupDec <<
" | "
1672 << std::setw(1) << recochan[ch].gain << std::setw(6) << recochan[ch].amp << std::setw(5) << recochan[ch].time
1673 << std::setw(3) << recochan[ch].quality << std::setw(10) << std::setprecision(1) << float (recochan[ch].gain ? recochan[ch].d_amp / 64. : recochan[ch].d_amp)
1674 << std::setw(11) << std::setprecision(4) << (float) recochan[ch].d_time << std::setw(8) << std::setprecision(1) << (float) recochan[ch].d_quality;
1684 std::cout <<
"\nReco calibrated energy fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found:"
1685 <<
"\t" << ((nchan > 48 && nchan < 96) ? 1 : ngain) <<
" gain, " << unitName[
unit] <<
" units, " << nchan <<
" channels in total" << std::endl;
1688 std::cout <<
"Reco flags: 0x" << std::hex << std::setfill(
'0') << rflag <<
setupDec <<
" units: " << unitName[
unit] <<
" pulse_shape: " << shapeName[pulse] <<
" nsamples: " << 7 + 2 * nsmpl <<
" algorithm: " << algName[algor + 1] <<
" niterations: " << niter << std::endl;
1690 std::cout <<
"Reco flags: 0x" << std::hex << std::setfill(
'0') << rflag <<
setupDec <<
" units: " << unitName[
unit] <<
" pulse_shape: " << shapeName[pulse] <<
" nsamples: " << 7 + 2 * nsmpl <<
" algorithm: " << algName[algor * 4 + niter] << std::endl;
1693 std::cout <<
"\nPMT Ch | full word | G amp time b q amp time qual";
1694 for (ch = 0; ch < nchan; ++ch) {
1695 pmt =
m_cabling->channel2hole(fragType, ch % 48);
1697 std::cout <<
"\n" << std::setw(3) << pmt << std::setw(3) << ch <<
" |";
1699 std::cout <<
"\n -- " << std::setw(2) << ch <<
" |";
1702 if (ch >= 48 && nchan < 96) {
1705 std::cout <<
" 0x" <<
setup0 << recocalib[ch].word <<
setupDec <<
" | " << std::setw(1) << recocalib[ch].gain << std::setw(6) << recocalib[ch].amp << std::setw(5) << recocalib[ch].time << std::setw(2) << recocalib[ch].bad << std::setw(3) << recocalib[ch].quality << std::setw(10) << std::setprecision(1) << recocalib[ch].d_amp << std::setw(11) << std::setprecision(4) << recocalib[ch].d_time << std::setw(8) << std::setprecision(1) << recocalib[ch].d_quality;
1707 if (recocalib[ch].
bad != 0) {
1708 std::cout <<
" Bad channel";
1723 std::cout <<
"\nFrag5 Compressed fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found:"
1724 <<
"\t" << 1 <<
" gain, " << unitName[
unit] <<
" units, " << nchan <<
" channels in total" << std::endl;
1733 std::vector<double>
a(7), b(7), c(7), g(7), dg(7);
1735 for (ch = 0; ch < nchan; ++ch) {
1736 for (
int gain = 0; gain < 2; ++gain) {
1745 double calib =
m_tileToolEmscale->channelCalibOnl(drawerIdx, ch, gain, 1.0, chan_unit);
1747 if (
unit != 0 && gain) calib = calib * 64.0;
1749 for (
int i = 0; i < 7; ++i) {
1768 int size_L2 = (*((
const uint32_t*) data - 3 + 2) >> (32 - 2 - 3)) & 0x7;
1769 std::cout <<
"size_L2: " << size_L2 <<
" |";
1771 double SumEt =
m_rc2bytes5.getSumEt((
const uint32_t*) data - 3);
1772 double SumEz =
m_rc2bytes5.getSumEz((
const uint32_t*) data - 3);
1773 double SumE =
m_rc2bytes5.getSumE((
const uint32_t*) data - 3);
1774 std::cout <<
" SumEt: " << SumEt <<
", SumEz: " << SumEz <<
", SumE: " << SumE << std::endl;
1776 std::cout << std::endl;
1778 m_rc2bytes5.unpack(ofw, (uint32_t*) data - 3, Frag5Data);
1780#define code_ped4 TileRawChannel2Bytes5::code_ped4
1781#define code_ped5 TileRawChannel2Bytes5::code_ped5
1782#define code_amp5 TileRawChannel2Bytes5::code_amp5
1783#define code_amp6 TileRawChannel2Bytes5::code_amp6
1784#define code_raws TileRawChannel2Bytes5::code_raws
1785#define code_rawf TileRawChannel2Bytes5::code_rawf
1786#define code_full TileRawChannel2Bytes5::code_full
1787#define code_dump TileRawChannel2Bytes5::code_dump
1788#define code_null TileRawChannel2Bytes5::code_null
1790 int cnt_ped4, cnt_ped5, cnt_amp5, cnt_amp6, cnt_raws, cnt_rawf, cnt_full, cnt_dump, cnt_null;
1791 cnt_ped4 = cnt_ped5 = cnt_amp5 = cnt_amp6 = cnt_raws = cnt_rawf = cnt_full = cnt_dump = cnt_null = 0;
1792 std::cout <<
"PMT Ch | full word | Type G B ectrl ereco ebin ene time | s1 s2 s3 s4 s5 s6 s7";
1794 const char *strcode_empty =
"----";
1795 const char *strcode_ped4 =
"ped4";
1796 const char *strcode_ped5 =
"ped5";
1797 const char *strcode_amp5 =
"amp5";
1798 const char *strcode_amp6 =
"amp6";
1799 const char *strcode_raws =
"raws";
1800 const char *strcode_rawf =
"rawf";
1801 const char *strcode_full =
"full";
1802 const char *strcode_dump =
"dump";
1803 const char *strcode_null =
"null";
1804 const char *strcode_error =
"ERR ";
1807 for (ch = 0; ch < nchan; ++ch) {
1808 pmt =
m_cabling->channel2hole(fragType, ch % 48);
1810 std::cout <<
"\n" << std::setw(3) << pmt << std::setw(3) << ch <<
" |";
1812 std::cout <<
"\n -- " << std::setw(2) << ch <<
" |";
1815 uint32_t reco = data[ch];
1816 const char *scode = strcode_empty;
1817 int code = Frag5Data[ch].
code;
1818 int gain = Frag5Data[ch].
gain;
1819 int bad = Frag5Data[ch].
bad;
1820 int ene_bin = Frag5Data[ch].
ene_bin;
1821 float ene = Frag5Data[ch].
ene;
1822 float time = Frag5Data[ch].
time;
1824 for (
int i = 0; i < 7; i++) {
1825 s[i] = Frag5Data[ch].
s[i];
1829 case code_ped4: scode = strcode_ped4; cnt_ped4++;
break;
1830 case code_ped5: scode = strcode_ped5; cnt_ped5++;
break;
1831 case code_amp5: scode = strcode_amp5; cnt_amp5++;
break;
1832 case code_amp6: scode = strcode_amp6; cnt_amp6++;
break;
1833 case code_raws: scode = strcode_raws; cnt_raws++;
break;
1834 case code_rawf: scode = strcode_rawf; cnt_rawf++;
break;
1835 case code_full: scode = strcode_full; cnt_full++;
break;
1836 case code_dump: scode = strcode_dump; cnt_dump++;
break;
1837 case code_null: scode = strcode_null; cnt_null++;
break;
1838 default: scode = strcode_error;
break;
1841 int ene_recobin = ene_bin + (gain == 0 ? 512 : 2048);
1851 ene_bin += (gain == 0 ? 512 : 2048);
1858 }
else if (ene_ctrl > 0x7FFF) {
1862 std::cout <<
" 0x" <<
setup0 << reco <<
setupDec <<
" | " << std::setw(4) << scode <<
" " << gain <<
" " <<
bad;
1870 std::cout << std::setw(7) << ene_ctrl << std::setw(7) << ene_recobin << std::setw(6) << ene_bin << std::setw(10) << std::setprecision(4) << ene <<
" -- ";
1874 std::cout << std::setw(7) << ene_ctrl << std::setw(7) << ene_recobin << std::setw(6) << ene_bin << std::setw(10) << std::setprecision(4) << ene << std::setw(6) << std::setprecision(1) << time <<
" ";
1878 std::cout <<
" ----- ----- ---- --- -- ";
1883 std::cout <<
"| " << std::setw(4) << s[0] << std::setw(5) << s[1] << std::setw(5) << s[2] << std::setw(5) << s[3] << std::setw(5) << s[4] << std::setw(5) << s[5] << std::setw(5) << s[6] <<
" " ;
1884 if (ene_ctrl != ene_recobin) {
1886 std::cout <<
" ERR";
1890 std::cout <<
"\n\nFrag5 Self-Consistency: ";
1892 std::cout <<
"OK" << std::endl;
1894 std::cout <<
"ERROR" << std::endl;
1897 std::cout <<
"\nped4" << cnt_ped4 <<
", ped5 " << cnt_ped5 <<
", amp5 " << cnt_amp5 <<
", amp6 " << cnt_amp6 <<
", raws " << cnt_raws <<
", rawf " << cnt_rawf <<
", full " << cnt_full <<
", dump " << cnt_dump <<
", null " << cnt_null << std::endl;
1904 std::cout <<
"\nFELIX fragment 0x" << std::hex <<
id << std::dec <<
", " <<
size <<
" words found" << std::endl;
1908 std::cout << std::hex << std::endl;
1909 bool phase2format = (
size>
head && correct_data[2] == 0x12345678 && correct_data[
size-1] == 0x87654321);
1911 int thisVersion = (((correct_data[3] >> 16) & 0xFFFF) == 0) ? 1 : 0;
1912 const char * namesV0[] = {
"size_packet",
"elink",
"SOP",
"runParam1",
"runParam2",
"runParam3",
"runParam4",
"BC_MD_ID",
"L1ID" };
1913 const char * namesV1[] = {
"size_packet",
"elink",
"SOP",
"version",
"MODULE_BC_MD",
"L1ID",
"BCR" ,
"runParam1",
"runParam2",
"runParam3"};
1914 const char ** names = (thisVersion) ? namesV1 : namesV0;
1915 if (thisVersion)
head = 10;
1916 for (
int i=0; i<
head; ++i) {
1917 std::cout << std::setw(13) << names[i] << std::setw(10) << correct_data[i] << std::endl;
1921 for (
int i=0; i<
head; ++i) {
1922 std::cout <<
" Word" << std::setw(3) << i << std::setw(10) << correct_data[i] << std::endl;
1925 std::cout << std::dec << std::endl;
1926 FelixData_t digitsHighGain, digitsLowGain, digitsMetaData;
1927 unpack_frag6(correct_data.data(),
size, digitsHighGain, digitsLowGain, digitsMetaData);
1929 std::cout <<
" MD1 MD2 MD3 MD4" << std::endl;
1930 std::cout <<
"-----------------------------------------------------";
1931 const char * metaNamesV0[] = {
"BCID",
"L1ID",
"ModuleID",
"RunType",
"RunNumber",
"PedHi",
"PedLo",
"ChargeInj",
"TimeInj",
"Capacitor",
"ECR" };
1932 const char * metaNamesV1[] = {
"BCID",
"L1ID",
"ModuleID",
"RunType",
"RunNumber",
"PedHi",
"PedLo",
"ChargeInj",
"TimeInj",
"Capacitor",
"ECR",
"BCR",
"Version",
"FragID" };
1933 const char ** metaNames = (version) ? metaNamesV1 : metaNamesV0;
1934 for (
size_t i = 0; i < digitsMetaData.size(); ++i) {
1935 std::cout << std::endl << std::setw(13) << metaNames[i];
1936 for (
size_t j = 0; j<digitsMetaData[i].size(); ++j) {
1937 std::cout << std::setw(10) << digitsMetaData[i][j];
1940 std::cout << std::endl << std::endl;
1943 if (digitsLowGain[0].
size()>0)
1944 nsamp = std::max(nsamp,digitsLowGain[0].
size());
1945 if (digitsHighGain[0].
size()>0)
1946 nsamp =std::max(nsamp,digitsHighGain[0].
size());
1948 std::cout <<
" ch G ";
1949 for (
size_t s = 0; s < nsamp; ++s) {
1950 std::cout << std::setw(5) << s;
1952 std::string
a(8+nsamp*5,
'-');
1953 std::cout << std::endl <<
a;
1955 for (
size_t ch = 0; ch < digitsHighGain.size() ; ++ch) {
1956 std::cout << std::endl << std::setw(3) << ch <<
" HG ";
1957 for (
size_t s = 0; s < digitsHighGain[ch].size(); ++s) {
1958 std::cout << std::setw(5) << (digitsHighGain[ch][s]);
1962 for (
size_t ch = 0; ch < digitsLowGain.size() ; ++ch) {
1963 std::cout << std::endl << std::setw(3) << ch <<
" LG ";
1964 for (
size_t s = 0; s < digitsLowGain[ch].size(); ++s) {
1965 std::cout << std::setw(5) << (digitsLowGain[ch][s]);
1968 std::cout << std::endl << std::endl;
1976 std::cout <<
"\nQuality fragment 0x" << std::hex <<
id <<
", " << std::dec <<
size <<
" words found:" << std::endl;
1979 std::cout <<
" ATTENTION: Error bits found in the Data Quality fragment 0xA" << std::endl;
1982 std::cout <<
" --------------------------------------" << std::endl;
1983 std::cout <<
" | Quality Block | Word (16bit)" << std::endl;
1985 std::cout <<
" | DSP BCID | " << std::dec << (DQword.
dspbcid & 0x7FFF) << std::endl;
1987 std::cout <<
" | DSP BCID | not filled (" << std::dec << DQword.
dspbcid <<
")" << std::endl;
1989 std::cout <<
" | Global CRC | " << std::hex <<
"0x" << std::setw(1) << DQword.
global_crc << std::setfill(
'0') << std::endl;
1990 std::cout <<
" | BCID checks | " <<
setup0x4 << DQword.
bcid << std::endl;
1991 std::cout <<
" | Mem parity err | " <<
setup0x4 << DQword.
memory << std::endl;
1992 std::cout <<
" | Single strobe err | " <<
setup0x4 << DQword.
Sstrobe << std::endl;
1993 std::cout <<
" | Double strobe err | " <<
setup0x4 << DQword.
Dstrobe << std::endl;
2000 std::cout <<
" --------------------------------------" << std::setfill(
' ') << std::dec << std::endl;
2004 std::cout <<
"\nUnknown (type " <<
type <<
") fragment 0x" << std::hex <<
id <<
", " << std::dec <<
size <<
" words found" << std::endl;
2007 std::cout << std::endl;
2009 std::cout <<
"\nType " <<
type <<
" fragment 0x" << std::hex <<
id <<
", " << std::dec <<
size <<
" words found" << std::endl;
2010 std::cout <<
"\nEmpty Event" << std::endl;