00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00021
00026
00032
00033
00034 #include <stdio.h>
00035 #include <stdlib.h>
00036 #include <string>
00037 #include <map>
00038 #include <utility>
00039
00040
00041 #include "midas.h"
00042
00043
00044 #include <TH1.h>
00045 #include <TH2.h>
00046 #include <TDirectory.h>
00047
00048
00049 #include "TOctalFADCIsland.h"
00050 #include "TOctalFADCBankReader.h"
00051 #include "TGlobalData.h"
00052 #include "TSetupData.h"
00053
00054 using std::string;
00055 using std::map;
00056 using std::vector;
00057 using std::pair;
00058
00059
00060 INT MDQ_FADCBufferOverflow_init(void);
00061 INT MDQ_FADCBufferOverflow_BOR(INT run_number);
00062 INT MDQ_FADCBufferOverflow_EOR(INT run_number);
00063 INT MDQ_FADCBufferOverflow(EVENT_HEADER*, void*);
00064
00065 extern HNDLE hDB;
00066 extern TGlobalData* gData;
00067 extern TSetupData* gSetup;
00068
00069 static TH1* hDQ_FADCBufferOverflow_Total;
00070 static TH1* hDQ_FADCBufferOverflow_Fraction;
00071 static TH2* hDQ_FADCBufferOverflow_TotalByEvent;
00072 static int n_total_midas_events;
00073
00074
00075 ANA_MODULE MDQ_FADCBufferOverflow_module =
00076 {
00077 "MDQ_FADCBufferOverflow",
00078 "Andrew Edmonds",
00079 MDQ_FADCBufferOverflow,
00080 MDQ_FADCBufferOverflow_BOR,
00081 MDQ_FADCBufferOverflow_EOR,
00082 MDQ_FADCBufferOverflow_init,
00083 NULL,
00084 NULL,
00085 0,
00086 NULL,
00087 };
00088
00091 INT MDQ_FADCBufferOverflow_init()
00092 {
00093
00094 if (!gDirectory->Cd("DataQuality_LowLevel")) {
00095
00096 std::string dir_name("DataQuality_LowLevel/");
00097 gDirectory->mkdir(dir_name.c_str());
00098 gDirectory->Cd(dir_name.c_str());
00099 }
00100
00101
00102 char key_name[80];
00103 int size,run_number;
00104 sprintf(key_name, "Runinfo/Run number");
00105 size=sizeof(int);
00106 db_get_value(hDB,0,key_name, &run_number, &size, TID_INT,1);
00107
00108
00109 hDQ_FADCBufferOverflow_Total = new TH1F(
00110 "hDQ_FADCBufferOverflow_Total",
00111 Form("Total number of MIDAS Events with buffer overflows per board, run %d",run_number),
00112 4,128, 132);
00113 hDQ_FADCBufferOverflow_Total->SetBit(TH1::kCanRebin);
00114 hDQ_FADCBufferOverflow_Total->GetXaxis()->SetTitle("FADC Board Number");
00115 hDQ_FADCBufferOverflow_Total->GetYaxis()->SetTitle("Number of events with buffer overflows");
00116
00117 hDQ_FADCBufferOverflow_Fraction = new TH1F(
00118 "hDQ_FADCBufferOverflow_Fraction",
00119 Form("Fraction of MIDAS Events with FADC buffer overflows by board, run %d",run_number),
00120 4,128, 132);
00121 hDQ_FADCBufferOverflow_Fraction->SetBit(TH1::kCanRebin);
00122 hDQ_FADCBufferOverflow_Fraction->GetXaxis()->SetTitle("FADC Board Number");
00123 hDQ_FADCBufferOverflow_Fraction->GetYaxis()->SetTitle("Fraction of events with buffer overflows");
00124
00125 hDQ_FADCBufferOverflow_TotalByEvent = new TH2F(
00126 "hDQ_FADCBufferOverflow_TotalByEvent",
00127 Form("FADC buffer overflows by board and event, run %d",run_number),
00128 4,128, 132,5000,0,5000);
00129 hDQ_FADCBufferOverflow_TotalByEvent->SetBit(TH1::kCanRebin);
00130 hDQ_FADCBufferOverflow_TotalByEvent->GetXaxis()->SetTitle("FADC Board Number");
00131 hDQ_FADCBufferOverflow_TotalByEvent->GetYaxis()->SetTitle("MIDAS event");
00132
00133 gDirectory->Cd("/MidasHists/");
00134
00135 return SUCCESS;
00136 }
00137
00141 INT MDQ_FADCBufferOverflow_BOR(INT run_number)
00142 {
00143 n_total_midas_events = 1;
00144
00145 return SUCCESS;
00146 }
00147
00151 INT MDQ_FADCBufferOverflow(EVENT_HEADER *pheader, void *pevent)
00152 {
00153
00154 int midas_event_number = pheader->serial_number;
00155
00156
00157 unsigned int* raw;
00158 int bankSize = bk_locate(pevent,"NBUF",&raw);
00159
00160 int board_number = 0;
00161 int n_buffers_overflow = 0;
00162
00163 bool Boards[256];
00164 for(int i=0; i<256; ++i) Boards[i] = false;
00165
00166 for (int i = 0; i < bankSize; i++) {
00167 board_number = *(raw+i);
00168
00169 if(*(raw+i) >= 0 && *(raw+i) < 255) Boards[i] = true;
00170
00171 n_buffers_overflow++;
00172
00173
00174
00175 hDQ_FADCBufferOverflow_Total->Fill(board_number, 1);
00176 hDQ_FADCBufferOverflow_Fraction->Fill(board_number, 1);
00177 hDQ_FADCBufferOverflow_TotalByEvent->Fill(board_number,midas_event_number, 1);
00178
00179 }
00180
00181
00182
00183
00184
00185
00186
00187
00188
00189 ++n_total_midas_events;
00190
00191 return SUCCESS;
00192 }
00193
00194 INT MDQ_FADCBufferOverflow_EOR(INT run_number)
00195 {
00196
00197
00198
00199 hDQ_FADCBufferOverflow_Fraction->Scale(1.0 / n_total_midas_events);
00200
00201
00202
00203 return SUCCESS;
00204 }
00205