134 static constexpr
short int N_COL = 1024;
135 static constexpr
short int N_ROW = 512;
140 short int N_RANGE = 51;
142 short int N_RANGE2 = 1;
144 static constexpr
short int N_PIX_DCOL = 50;
150 std::map<
short int,
std::map<
int,
std::vector<
std::vector<
std::vector<
unsigned short int>>>>> mPixelHits;
152 std::map<
short int,
std::
array<
long int, 6>> mThresholds;
154 std::map<
short int,
std::vector<
int>> mNoisyPixID;
156 std::map<
short int,
std::vector<
int>> mIneffPixID;
158 std::map<
short int,
std::vector<
int>> mDeadPixID;
160 std::map<
short int,
std::
array<
int, 200>> mpvCounter;
162 TFile* mRootOutfile =
nullptr;
163 TTree* mThresholdTree =
nullptr;
164 TTree* mScTree =
nullptr;
165 TTree* mSlopeTree =
nullptr;
166 short int vChipid[N_COL];
167 short int vRow[N_COL];
168 short int vThreshold[N_COL];
169 bool vSuccess[N_COL];
171 unsigned char vPoints[N_COL];
172 short int vMixData[N_COL];
174 float vIntercept[N_COL];
175 unsigned char vCharge[N_COL];
176 unsigned char vHits[N_COL];
177 short int mColStep = 8;
180 TH1F* mFitHist =
nullptr;
181 TF1* mFitFunction =
nullptr;
185 void extractAndUpdate(const
short int&, const
short int&);
186 std::vector<
float> calculatePulseParams(const
short int&);
187 std::vector<
float> calculatePulseParams2D(const
short int&);
188 void extractThresholdRow(const
short int&, const
short int&);
189 void finalizeOutput();
191 void setRunType(const
short int&);
194 void initThresholdTree(
bool recreate = true);
195 bool findUpperLower(
std::vector<
std::vector<
unsigned short int>>, const
short int&,
short int&,
short int&,
bool,
int);
196 bool findThreshold(const
short int&,
std::vector<
std::vector<
unsigned short int>>, const
float*,
short int&,
float&,
float&,
int&,
int);
197 bool findThresholdFit(const
short int&,
std::vector<
std::vector<
unsigned short int>>, const
float*, const
short int&,
float&,
float&,
int&,
int);
198 bool findThresholdDerivative(
std::vector<
std::vector<
unsigned short int>>, const
float*, const
short int&,
float&,
float&,
int&,
int);
199 bool findThresholdHitcounting(
std::vector<
std::vector<
unsigned short int>>, const
float*, const
short int&,
float&,
int);
200 void findAverage(const
std::
array<
long int, 6>&,
float&,
float&,
float&,
float&);
201 void saveThreshold();
204 void addDatabaseEntry(const
short int&, const
char*,
std::vector<
float>,
bool);
207 std::vector<
short int> getIntegerVect(
std::
string&);
208 short int getRUID(
short int chipID);
209 std::vector<
short int> getChipListFromRu(
short int,
bool*);
210 short int getLinkID(
short int,
short int);
211 short int getNumberOfActiveLinks(
bool*);
213 std::
string mSelfName;
214 std::
string mDictName;
215 std::
string mNoiseName;
218 bool mVerboseOutput = false;
219 std::
string mMetaType;
220 std::
string mOutputDir;
221 std::
string mMetafileDir = "/
dev/null";
227 unsigned int mFileNumber = 0;
228 static constexpr unsigned int N_ROWS_PER_FILE = 150000;
229 unsigned int mRowCounter = 0;
231 short int mRunType = -1;
232 short int mRunTypeUp = -1;
233 short int mRunTypeRU[N_RU] = {0};
234 short int mRunTypeRUCopy[N_RU] = {0};
235 short int mCdwCntRU[N_RU][N_ROW] = {{0}};
236 short int mLoopVal[N_RU][N_ROW] = {{0}};
237 bool mActiveLinks[N_RU][3] = {{
false}};
238 std::set<short int> mRuSet;
240 char mScanType =
'\0';
241 short int mMin = -1, mMax = -1, mMin2 = 0, mMax2 = 0;
242 short int mStep = 1, mStep2 = 1;
243 short int mStrobeWindow = 5;
249 std::string PixelType;
251 std::string mHostname;
261 short int mCdwVersion = 0;
264 bool isEnded =
false;
267 bool mTagSinglePix =
false;
270 std::string mCcdbMgrUrl =
"";
272 bool mCheckExactRow =
false;
276 int mChipModBase = 1;
279 short int inMinVcasn = 30;
280 short int inMaxVcasn = 100;
281 short int inMinIthr = 25;
282 short int inMaxIthr = 100;
288 bool isManualMode =
false;
290 bool scaleNinj =
false;
291 short int manualMin, manualMin2 = 0;
292 short int manualMax, manualMax2 = 0;
293 short int manualStep = 1, manualStep2 = 1;
294 std::string manualScanType;
295 short int manualStrobeWindow = 5;
298 bool isCRUITS =
false;
301 std::vector<int>* mConfDBmap;
305 bool isDumpS =
false;
307 std::string chipDumpS =
"";
308 int dumpCounterS[24120] = {0};
309 int countCdw[24120] = {0};
311 std::vector<short int> chipDumpList;
314 bool mRunStopRequested =
false;
317 bool doSlopeCalculation =
false;
318 bool mCalculate2DParams =
true;
326 short int mPercentageCut = 25;