Go to the documentation of this file.00001 #ifndef DQM_HCALMONITORTASKS_HCALRAWDATAMONITOR_H
00002 #define DQM_HCALMONITORTASKS_HCALRAWDATAMONITOR_H
00003
00004 #define NUMDCCS 32
00005 #define NUMSPIGS 15
00006 #define HTRCHANMAX 24
00007
00008
00009 #define TWO___FED (1+((2+1)*NUMDCCS) )
00010 #define THREE_FED (1+((3+1)*NUMDCCS) )
00011 #define TWO__SPGT (1+((2+1)*NUMSPIGS) )
00012 #define THREE_SPG (1+((3+1)*NUMSPIGS) )
00013 #define TWO_CHANN (1+((2+1)*HTRCHANMAX))
00014
00015 #define ETABINS 85
00016 #define PHIBINS 72
00017 #define DEPTHBINS 4
00018
00019 #include "DQM/HcalMonitorTasks/interface/HcalBaseDQMonitor.h"
00020 #include "EventFilter/HcalRawToDigi/interface/HcalUnpacker.h"
00021 #include "EventFilter/HcalRawToDigi/interface/HcalHTRData.h"
00022 #include "DataFormats/FEDRawData/interface/FEDRawDataCollection.h"
00023 #include "DataFormats/FEDRawData/interface/FEDNumbering.h"
00024 #include "DataFormats/FEDRawData/interface/FEDNumbering.h"
00025 #include "DataFormats/FEDRawData/interface/FEDTrailer.h"
00026 #include <math.h>
00027
00034 class HcalRawDataMonitor: public HcalBaseDQMonitor {
00035 public:
00036 HcalRawDataMonitor(const edm::ParameterSet& ps);
00037
00038 HcalRawDataMonitor(){};
00039 ~HcalRawDataMonitor();
00040 protected:
00041 void analyze(const edm::Event& e, const edm::EventSetup& c);
00042 void beginRun(const edm::Run& run, const edm::EventSetup& c);
00043 void beginLuminosityBlock(const edm::LuminosityBlock& lumiSeg,
00044 const edm::EventSetup& c) ;
00045
00046
00047 void endLuminosityBlock(const edm::LuminosityBlock& lumiSeg,
00048 const edm::EventSetup& c);
00049
00050 void processEvent(const FEDRawDataCollection& rawraw,
00051 const HcalUnpackerReport& report);
00052
00053 void unpack(const FEDRawData& raw);
00054 void endJob(void);
00055 void endRun(const edm::Run& run, const edm::EventSetup& c);
00056 void setup(void);
00057
00058 edm::InputTag FEDRawDataCollection_;
00059 edm::InputTag digiLabel_;
00060 const HcalElectronicsMap* readoutMap_;
00061
00062 inline int hashup(uint32_t d=0, uint32_t s=0, uint32_t c=1) {
00063 return (int) ( (d*NUMSPIGS*HTRCHANMAX)+(s*HTRCHANMAX)+(c)); }
00064 void stashHDI(int thehash, HcalDetId thehcaldetid);
00065
00066 inline HcalDetId HashToHDI(int thehash) {
00067 return ( ( (thehash<0) || (thehash>(NUMDCCS*NUMSPIGS*HTRCHANMAX)) )
00068 ?(HcalDetId::Undefined)
00069 :(hashedHcalDetId_[thehash]));
00070 };
00071 uint64_t problemcount[ETABINS][PHIBINS][DEPTHBINS];
00072 bool problemfound[ETABINS][PHIBINS][DEPTHBINS];
00073 void mapDCCproblem (int dcc);
00074 void mapHTRproblem (int dcc, int spigot);
00075 void mapChannproblem(int dcc, int spigot, int htrchan);
00076 void whosebad(int subdet);
00077
00078 private:
00079 MonitorElement* meCh_DataIntegrityFED00_;
00080 MonitorElement* meCh_DataIntegrityFED01_;
00081 MonitorElement* meCh_DataIntegrityFED02_;
00082 MonitorElement* meCh_DataIntegrityFED03_;
00083 MonitorElement* meCh_DataIntegrityFED04_;
00084 MonitorElement* meCh_DataIntegrityFED05_;
00085 MonitorElement* meCh_DataIntegrityFED06_;
00086 MonitorElement* meCh_DataIntegrityFED07_;
00087 MonitorElement* meCh_DataIntegrityFED08_;
00088 MonitorElement* meCh_DataIntegrityFED09_;
00089 MonitorElement* meCh_DataIntegrityFED10_;
00090 MonitorElement* meCh_DataIntegrityFED11_;
00091 MonitorElement* meCh_DataIntegrityFED12_;
00092 MonitorElement* meCh_DataIntegrityFED13_;
00093 MonitorElement* meCh_DataIntegrityFED14_;
00094 MonitorElement* meCh_DataIntegrityFED15_;
00095 MonitorElement* meCh_DataIntegrityFED16_;
00096 MonitorElement* meCh_DataIntegrityFED17_;
00097 MonitorElement* meCh_DataIntegrityFED18_;
00098 MonitorElement* meCh_DataIntegrityFED19_;
00099 MonitorElement* meCh_DataIntegrityFED20_;
00100 MonitorElement* meCh_DataIntegrityFED21_;
00101 MonitorElement* meCh_DataIntegrityFED22_;
00102 MonitorElement* meCh_DataIntegrityFED23_;
00103 MonitorElement* meCh_DataIntegrityFED24_;
00104 MonitorElement* meCh_DataIntegrityFED25_;
00105 MonitorElement* meCh_DataIntegrityFED26_;
00106 MonitorElement* meCh_DataIntegrityFED27_;
00107 MonitorElement* meCh_DataIntegrityFED28_;
00108 MonitorElement* meCh_DataIntegrityFED29_;
00109 MonitorElement* meCh_DataIntegrityFED30_;
00110 MonitorElement* meCh_DataIntegrityFED31_;
00111
00112 MonitorElement* meChann_DataIntegrityCheck_[NUMDCCS];
00113
00114 uint64_t UScount[NUMDCCS][NUMSPIGS];
00115 float HalfHTRDataCorruptionIndicators_ [THREE_FED][THREE_SPG];
00116 float LRBDataCorruptionIndicators_ [THREE_FED][THREE_SPG];
00117 float ChannSumm_DataIntegrityCheck_ [TWO___FED][TWO__SPGT];
00118 float Chann_DataIntegrityCheck_[NUMDCCS][TWO_CHANN][TWO__SPGT];
00119 float DataFlowInd_ [TWO___FED][THREE_SPG];
00120
00121 MonitorElement* meHalfHTRDataCorruptionIndicators_;
00122 MonitorElement* meLRBDataCorruptionIndicators_;
00123 MonitorElement* meChannSumm_DataIntegrityCheck_;
00124 MonitorElement* meDataFlowInd_;
00125
00126
00127 void label_ySpigots(MonitorElement* me_ptr,int ybins);
00128 void label_xFEDs (MonitorElement* me_ptr,int xbins);
00129 void label_xChanns (MonitorElement* me_ptr,int xbins);
00130
00131 HcalDetId hashedHcalDetId_[NUMDCCS * NUMSPIGS * HTRCHANMAX];
00132
00133
00134 void UpdateMEs (void );
00135
00136
00137 std::map<int, short> CDFversionNumber_list;
00138 std::map<int, short>::iterator CDFvers_it;
00139 std::map<int, short> CDFReservedBits_list;
00140 std::map<int, short>::iterator CDFReservedBits_it;
00141 std::map<int, short> DCCEvtFormat_list;
00142 std::map<int, short>::iterator DCCEvtFormat_it;
00143
00144
00145
00146 MonitorElement* meCDFErrorFound_;
00147 MonitorElement* meDCCEventFormatError_;
00148
00149
00150 MonitorElement* meBCN_;
00151 MonitorElement* medccBCN_;
00152 MonitorElement* meBCNCheck_;
00153 MonitorElement* meBCNSynch_;
00154
00155 MonitorElement* meEvtNCheck_;
00156 MonitorElement* meEvtNumberSynch_;
00157
00158 MonitorElement* meOrNCheck_;
00159 MonitorElement* meOrNSynch_;
00160 MonitorElement* meBCNwhenOrNDiff_;
00161
00162 MonitorElement* mefedEntries_;
00163 MonitorElement* meFEDRawDataSizes_;
00164 MonitorElement* meEvFragSize_;
00165 MonitorElement* meEvFragSize2_;
00166 MonitorElement* meDCCVersion_;
00167
00168 void labelHTRBits(MonitorElement* mePlot,unsigned int axisType);
00169 MonitorElement* HTR_StatusWd_HBHE;
00170 MonitorElement* HTR_StatusWd_HF;
00171 MonitorElement* HTR_StatusWd_HO;
00172 MonitorElement* meStatusWdCrate_;
00173 MonitorElement* meInvHTRData_;
00174 MonitorElement* meFibBCN_;
00175
00176
00177
00178 MonitorElement* meCrate0HTRStatus_ ;
00179 MonitorElement* meCrate1HTRStatus_ ;
00180 MonitorElement* meCrate2HTRStatus_ ;
00181 MonitorElement* meCrate3HTRStatus_ ;
00182 MonitorElement* meCrate4HTRStatus_ ;
00183 MonitorElement* meCrate5HTRStatus_ ;
00184 MonitorElement* meCrate6HTRStatus_ ;
00185 MonitorElement* meCrate7HTRStatus_ ;
00186 MonitorElement* meCrate9HTRStatus_ ;
00187 MonitorElement* meCrate10HTRStatus_;
00188 MonitorElement* meCrate11HTRStatus_;
00189 MonitorElement* meCrate12HTRStatus_;
00190 MonitorElement* meCrate13HTRStatus_;
00191 MonitorElement* meCrate14HTRStatus_;
00192 MonitorElement* meCrate15HTRStatus_;
00193 MonitorElement* meCrate17HTRStatus_;
00194
00195 MonitorElement* meUSFractSpigs_;
00196 MonitorElement* meHTRFWVersion_;
00197 MonitorElement* meFib1OrbMsgBCN_;
00198 MonitorElement* meFib2OrbMsgBCN_;
00199 MonitorElement* meFib3OrbMsgBCN_;
00200 MonitorElement* meFib4OrbMsgBCN_;
00201 MonitorElement* meFib5OrbMsgBCN_;
00202 MonitorElement* meFib6OrbMsgBCN_;
00203 MonitorElement* meFib7OrbMsgBCN_;
00204 MonitorElement* meFib8OrbMsgBCN_;
00205
00206 int NumBadHB, NumBadHE, NumBadHO, NumBadHF, NumBadHFLUMI, NumBadHO0, NumBadHO12;
00207
00208 void HTRPrint(const HcalHTRData& htr,int prtlvl);
00209
00210 bool excludeHORing2_;
00211 };
00212
00213 #endif