5 double computeEnergyUncertaintyGolden(
double eta,
double brem,
double energy) {
6 double et = energy / cosh(eta);
12 constexpr Double_t BremBins[nBinsBrem + 1] = {0.8, 1.0, 1.1, 1.2, 1.3, 1.5, 8.0};
15 {0.00567891, 0.0065673, 0.00574742, 0.00542964, 0.00523293, 0.00547518},
17 {0.00552517, 0.00611188, 0.0062729, 0.00574846, 0.00447373, 0.00595789},
19 {0.00356679, 0.00503827, 0.00328016, 0.00592303, 0.00512479, 0.00484166},
21 {0.0109195, 0.0102361, 0.0101576, 0.0120683, 0.0155326, 0.0225035},
23 {0.0109632, 0.0103342, 0.0103486, 0.00862762, 0.0111448, 0.0146648}};
25 static_assert(par0[0][0] == 0.00567891
f);
26 static_assert(par0[0][1] == 0.0065673
f);
27 static_assert(par0[1][3] == 0.00574846
f);
29 constexpr float par1[
nBinsEta][nBinsBrem] = {{0.238685, 0.193642, 0.249171, 0.259997, 0.310505, 0.390506},
31 {0.288736, 0.312303, 0.294717, 0.294491, 0.379178, 0.38164},
33 {0.456456, 0.394912, 0.541713, 0.401744, 0.483151, 0.657995},
35 {1.13803, 1.39866, 1.51353, 1.48587, 1.49732, 1.82363},
37 {0.458212, 0.628761, 0.659144, 0.929563, 1.06724, 1.6427}};
41 {1.30552, 0.137905, 0.653793, 0.790746, -1.42584, -2.34653},
43 {0.610716, 0.778879, -1.58577, 1.45098, -0.0985911, -3.47167},
44 {-3.48281, -6.4736, -8.03308, -7.55974, -7.98843, -10.1027},
46 {0.995183, -2.42889, -2.14073, -6.27768, -7.68512, -13.3504}};
49 for (Int_t iEta = 0; iEta <
nBinsEta; ++iEta) {
50 if (EtaBins[iEta] <= fabs(eta) && fabs(eta) < EtaBins[iEta + 1]) {
56 for (Int_t iBrem = 0; iBrem < nBinsBrem; ++iBrem) {
57 if (BremBins[iBrem] <= brem && brem < BremBins[iBrem + 1]) {
63 iEtaSl = nBinsEta - 1;
64 if (brem < BremBins[0])
66 if (brem > BremBins[nBinsBrem - 1])
67 iBremSl = nBinsBrem - 1;
70 edm::LogError(
"BadRange") <<
"Bad eta value: " << eta <<
" in computeEnergyUncertaintyGolden";
75 edm::LogError(
"BadRange") <<
"Bad brem value: " << brem <<
" in computeEnergyUncertaintyGolden";
79 float uncertainty = 0;
81 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (5 - par2[iEtaSl][iBremSl]);
83 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (100 - par2[iEtaSl][iBremSl]);
85 if (et > 5 && et < 100)
86 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (et - par2[iEtaSl][iBremSl]);
88 return (uncertainty * energy);
91 double computeEnergyUncertaintyBigbrem(
double eta,
double brem,
double energy) {
92 const double et = energy / cosh(eta);
95 constexpr Double_t EtaBins[nBinsEta + 1] = {0.0, 0.8, 1.5, 2.0, 2.5};
98 constexpr Double_t BremBins[nBinsBrem + 1] = {0.8, 8.0};
100 constexpr float par0[
nBinsEta][nBinsBrem] = {{0.00593389}, {0.00266954}, {0.00500623}, {0.00841038}};
102 constexpr float par1[
nBinsEta][nBinsBrem] = {{0.178275}, {0.811415}, {2.34018}, {1.06851}};
104 constexpr float par2[
nBinsEta][nBinsBrem] = {{-7.28273}, {-1.66063}, {-11.0129}, {-4.1259}};
109 for (Int_t iEta = 0; iEta <
nBinsEta; ++iEta) {
110 if (EtaBins[iEta] <= fabs(eta) && fabs(eta) < EtaBins[iEta + 1]) {
116 for (Int_t iBrem = 0; iBrem < nBinsBrem; ++iBrem) {
117 if (BremBins[iBrem] <= brem && brem < BremBins[iBrem + 1]) {
123 iEtaSl = nBinsEta - 1;
124 if (brem < BremBins[0])
126 if (brem > BremBins[nBinsBrem - 1])
127 iBremSl = nBinsBrem - 1;
130 edm::LogError(
"BadRange") <<
"Bad eta value: " << eta <<
" in computeEnergyUncertaintyBigbrem";
135 edm::LogError(
"BadRange") <<
"Bad brem value: " << brem <<
" in computeEnergyUncertaintyBigbrem";
139 float uncertainty = 0;
141 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (5 - par2[iEtaSl][iBremSl]) +
142 par3[iEtaSl][iBremSl] / ((5 - par2[iEtaSl][iBremSl]) * (5 - par2[iEtaSl][iBremSl]));
144 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (100 - par2[iEtaSl][iBremSl]) +
145 par3[iEtaSl][iBremSl] / ((100 - par2[iEtaSl][iBremSl]) * (100 - par2[iEtaSl][iBremSl]));
147 if (et > 5 && et < 100)
148 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (et - par2[iEtaSl][iBremSl]) +
149 par3[iEtaSl][iBremSl] / ((et - par2[iEtaSl][iBremSl]) * (et - par2[iEtaSl][iBremSl]));
151 return (uncertainty * energy);
153 double computeEnergyUncertaintyBadTrack(
double eta,
double brem,
double energy) {
154 const double et = energy / cosh(eta);
157 constexpr Double_t EtaBins[nBinsEta + 1] = {0.0, 0.7, 1.3, 1.8, 2.5};
160 constexpr Double_t BremBins[nBinsBrem + 1] = {0.8, 8.0};
162 constexpr float par0[
nBinsEta][nBinsBrem] = {{0.00601311}, {0.0059814}, {0.00953032}, {0.00728618}};
164 constexpr float par1[
nBinsEta][nBinsBrem] = {{0.390988}, {1.02668}, {2.27491}, {2.08268}};
166 constexpr float par2[
nBinsEta][nBinsBrem] = {{-4.11919}, {-2.87477}, {-7.61675}, {-8.66756}};
168 constexpr float par3[
nBinsEta][nBinsBrem] = {{4.61671}, {0.163447}, {-0.335786}, {-1.27831}};
171 for (Int_t iEta = 0; iEta <
nBinsEta; ++iEta) {
172 if (EtaBins[iEta] <= fabs(eta) && fabs(eta) < EtaBins[iEta + 1]) {
178 for (Int_t iBrem = 0; iBrem < nBinsBrem; ++iBrem) {
179 if (BremBins[iBrem] <= brem && brem < BremBins[iBrem + 1]) {
185 iEtaSl = nBinsEta - 1;
186 if (brem < BremBins[0])
188 if (brem > BremBins[nBinsBrem - 1])
189 iBremSl = nBinsBrem - 1;
192 edm::LogError(
"BadRange") <<
"Bad eta value: " << eta <<
" in computeEnergyUncertaintyBadTrack";
197 edm::LogError(
"BadRange") <<
"Bad brem value: " << brem <<
" in computeEnergyUncertaintyBadTrack";
201 float uncertainty = 0;
203 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (5 - par2[iEtaSl][iBremSl]) +
204 par3[iEtaSl][iBremSl] / ((5 - par2[iEtaSl][iBremSl]) * (5 - par2[iEtaSl][iBremSl]));
206 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (100 - par2[iEtaSl][iBremSl]) +
207 par3[iEtaSl][iBremSl] / ((100 - par2[iEtaSl][iBremSl]) * (100 - par2[iEtaSl][iBremSl]));
209 if (et > 5 && et < 100)
210 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (et - par2[iEtaSl][iBremSl]) +
211 par3[iEtaSl][iBremSl] / ((et - par2[iEtaSl][iBremSl]) * (et - par2[iEtaSl][iBremSl]));
213 return (uncertainty * energy);
216 double computeEnergyUncertaintyShowering(
double eta,
double brem,
double energy) {
217 const double et = energy / cosh(eta);
220 constexpr Double_t EtaBins[nBinsEta + 1] = {0.0, 0.8, 1.2, 1.7, 2.5};
223 constexpr Double_t BremBins[nBinsBrem + 1] = {0.8, 1.8, 2.2, 3.0, 4.0, 8.0};
225 constexpr float par0[
nBinsEta][nBinsBrem] = {{0.0049351, 0.00566155, 0.0051397, 0.00468481, 0.00444475},
227 {0.00201762, 0.00431475, 0.00501004, 0.00632666, 0.00636704},
229 {-0.00729396, 0.00539783, 0.00608149, 0.00465335, 0.00642685},
231 {0.0149449, 0.0216691, 0.0255957, 0.0206101, 0.0180508}};
233 constexpr float par1[
nBinsEta][nBinsBrem] = {{0.579925, 0.496137, 0.551947, 0.63011, 0.684261},
235 {0.914762, 0.824483, 0.888521, 0.960241, 1.25728},
237 {3.24295, 1.72935, 1.80606, 2.13562, 2.07592},
239 {1.00448, 1.18393, 0.00775295, 2.59246, 3.1099}};
241 constexpr float par2[
nBinsEta][nBinsBrem] = {{-9.33987, -5.52543, -7.30079, -6.7722, -4.67614},
243 {-4.48042, -5.02885, -4.77311, -3.36742, -5.53561},
245 {-17.1458, -5.92807, -6.67563, -10.1105, -7.50257},
247 {-2.09368, -4.56674, -44.2722, -13.1702, -13.6208}};
249 constexpr float par3[
nBinsEta][nBinsBrem] = {{1.62129, 1.19101, 1.89701, 1.81614, 1.64415},
251 {-1.50473, -0.153502, -0.355145, -1.16499, -0.864123},
253 {-4.69711, -2.18733, -0.922401, -0.230781, -2.91515},
255 {0.455037, -0.601872, 241.516, -2.35024, -2.11069}};
258 for (Int_t iEta = 0; iEta <
nBinsEta; ++iEta) {
259 if (EtaBins[iEta] <= fabs(eta) && fabs(eta) < EtaBins[iEta + 1]) {
265 for (Int_t iBrem = 0; iBrem < nBinsBrem; ++iBrem) {
266 if (BremBins[iBrem] <= brem && brem < BremBins[iBrem + 1]) {
272 iEtaSl = nBinsEta - 1;
273 if (brem < BremBins[0])
275 if (brem > BremBins[nBinsBrem - 1])
276 iBremSl = nBinsBrem - 1;
279 edm::LogError(
"BadRange") <<
"Bad eta value: " << eta <<
" in computeEnergyUncertaintyShowering";
284 edm::LogError(
"BadRange") <<
"Bad brem value: " << brem <<
" in computeEnergyUncertaintyShowering";
288 float uncertainty = 0;
290 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (5 - par2[iEtaSl][iBremSl]) +
291 par3[iEtaSl][iBremSl] / ((5 - par2[iEtaSl][iBremSl]) * (5 - par2[iEtaSl][iBremSl]));
293 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (100 - par2[iEtaSl][iBremSl]) +
294 par3[iEtaSl][iBremSl] / ((100 - par2[iEtaSl][iBremSl]) * (100 - par2[iEtaSl][iBremSl]));
296 if (et > 5 && et < 100)
297 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (et - par2[iEtaSl][iBremSl]) +
298 par3[iEtaSl][iBremSl] / ((et - par2[iEtaSl][iBremSl]) * (et - par2[iEtaSl][iBremSl]));
300 return (uncertainty * energy);
303 double computeEnergyUncertaintyCracks(
double eta,
double brem,
double energy) {
304 const double et = energy / cosh(eta);
307 constexpr Double_t EtaBins[nBinsEta + 1] = {0.0, 0.42, 0.78, 1.2, 1.52, 1.65};
310 constexpr Double_t BremBins[nBinsBrem + 1] = {0.8, 1.2, 1.5, 2.1, 3., 4, 8.0};
313 {0.0139815, 0.00550839, 0.0108292, 0.00596201, -0.00498136, 0.000621696},
315 {0.00467498, 0.00808463, 0.00546665, 0.00506318, 0.00608425, -4.45641e-06},
317 {0.00971734, 0.00063951, -0.0121618, -0.00604365, 0.00492161, -0.00143907},
319 {-0.0844907, -0.0592498, -0.0828631, -0.0740798, -0.0698045, -0.0699518},
321 {-0.0999971, -0.0999996, -0.0989356, -0.0999965, -0.0833049, -0.020072}};
323 constexpr float par1[
nBinsEta][nBinsBrem] = {{0.569273, 0.674654, 0.523128, 1.02501, 1.75645, 0.955191},
325 {0.697951, 0.580628, 0.814515, 0.819975, 0.829616, 1.18952},
327 {3.79446, 2.47472, 5.12931, 3.42497, 1.84123, 2.3773},
329 {19.9999, 10.4079, 16.6273, 15.9316, 15.4883, 14.7306},
331 {15.9122, 18.5882, 19.9996, 19.9999, 18.2281, 8.1587}};
333 constexpr float par2[
nBinsEta][nBinsBrem] = {{-4.31243, -3.071, -2.56702, -7.74555, -21.3726, -6.2189},
335 {-6.56009, -3.66067, -7.8275, -6.01641, -7.85456, -8.27071},
337 {-49.9996, -25.0724, -49.985, -28.1932, -10.6485, -15.4014},
339 {-39.9444, -25.1133, -49.9999, -50, -49.9998, -49.9998},
341 {-30.1268, -42.6113, -46.6999, -47.074, -49.9995, -25.2897}};
343 static_assert(par0[0][3] == 0.00596201
f);
344 static_assert(par1[0][3] == 1.02501
f);
345 static_assert(par2[0][3] == -7.74555
f);
347 static_assert(par0[2][4] == 0.00492161
f);
348 static_assert(par1[2][4] == 1.84123
f);
349 static_assert(par2[2][4] == -10.6485
f);
351 static_assert(par0[4][3] == -0.0999965
f);
352 static_assert(par1[4][3] == 19.9999
f);
353 static_assert(par2[4][3] == -47.074
f);
356 for (Int_t iEta = 0; iEta <
nBinsEta; ++iEta) {
357 if (EtaBins[iEta] <= fabs(eta) && fabs(eta) < EtaBins[iEta + 1]) {
363 for (Int_t iBrem = 0; iBrem < nBinsBrem; ++iBrem) {
364 if (BremBins[iBrem] <= brem && brem < BremBins[iBrem + 1]) {
370 iEtaSl = nBinsEta - 1;
371 if (brem < BremBins[0])
373 if (brem > BremBins[nBinsBrem - 1])
374 iBremSl = nBinsBrem - 1;
377 edm::LogError(
"BadRange") <<
"Bad eta value: " << eta <<
" in computeEnergyUncertaintyCracks";
382 edm::LogError(
"BadRange") <<
"Bad brem value: " << brem <<
" in computeEnergyUncertaintyCracks";
386 float uncertainty = 0;
388 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (5 - par2[iEtaSl][iBremSl]);
390 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (100 - par2[iEtaSl][iBremSl]);
392 if (et > 5 && et < 100)
393 uncertainty = par0[iEtaSl][iBremSl] + par1[iEtaSl][iBremSl] / (et - par2[iEtaSl][iBremSl]);
395 return (uncertainty * energy);
403 if (c == GsfElectron::GOLDEN)
404 return computeEnergyUncertaintyGolden(eta, brem, energy);
405 if (c == GsfElectron::BIGBREM)
406 return computeEnergyUncertaintyBigbrem(eta, brem, energy);
407 if (c == GsfElectron::SHOWERING)
408 return computeEnergyUncertaintyShowering(eta, brem, energy);
409 if (c == GsfElectron::BADTRACK)
410 return computeEnergyUncertaintyBadTrack(eta, brem, energy);
411 if (c == GsfElectron::GAP)
412 return computeEnergyUncertaintyCracks(eta, brem, energy);
413 throw cms::Exception(
"GsfElectronAlgo|InternalError") <<
"unknown classification";
double electronEnergyUncertainty(reco::GsfElectron::Classification c, double eta, double brem, double energy)