35 #include "GaudiKernel/ServiceHandle.h"
36 #include "GaudiKernel/ISvcLocator.h"
37 #include "GaudiKernel/ITHistSvc.h"
38 #include "GaudiKernel/IClassIDSvc.h"
50 declareInterface<IjFEXFPGA>(
this);
65 return StatusCode::SUCCESS;
72 return StatusCode::SUCCESS;
105 return StatusCode::FAILURE;
130 std::vector<int> pileup_ID;
131 std::vector<int> pileup_HAD_jet;
132 std::vector<int> pileup_EM_jet;
133 std::vector<int> pileup_Total_jet;
134 std::vector<int> pileup_HAD_met;
135 std::vector<int> pileup_EM_met;
136 std::vector<int> pileup_Total_met;
139 pileup_ID.push_back(
key);
140 pileup_HAD_jet.push_back(
val[0]);
143 pileup_HAD_met.push_back(
val[1]);
151 inputOutputCollection->
addValue_pileup(
"pileup_rho_EM", pileup_rho[0]);
152 inputOutputCollection->
addValue_pileup(
"pileup_rho_HAD1", pileup_rho[1]);
153 inputOutputCollection->
addValue_pileup(
"pileup_rho_HAD2", pileup_rho[2]);
154 inputOutputCollection->
addValue_pileup(
"pileup_rho_HAD3", pileup_rho[3]);
155 inputOutputCollection->
addValue_pileup(
"pileup_rho_FCAL", pileup_rho[4]);
157 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_HAD_jet" , pileup_HAD_jet);
158 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_EM_jet" , pileup_EM_jet);
159 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_Total_jet", pileup_Total_jet);
160 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_HAD_met" , pileup_HAD_met);
161 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_EM_met" , pileup_EM_met);
162 inputOutputCollection->
addValue_pileup(
"pileup_map_Et_values_Total_met", pileup_Total_met);
176 std::unique_ptr<jFEXTOB> jXE_tob = std::make_unique<jFEXTOB>();
179 std::unique_ptr<jFEXTOB> jTE_tob = std::make_unique<jFEXTOB>();
183 int hemisphere =
m_id == 0 ? 1 : -1;
200 for(
int mphi = 0; mphi <= max_phi_it; mphi++) {
201 for(
int meta = 0; meta <= max_eta_it; meta++) {
228 std::tuple<int,bool> jTElow;
229 std::tuple<int,bool> jTEhigh;
247 ATH_MSG_DEBUG(
"================ Central Algorithms ================");
259 int TT_seed_ID[3][3]= {{0}};
260 int TT_First_ETring[36]= {0};
261 int First_ETring_it = 0;
263 int Jet_SearchWindow[7][7] = {{0}};
264 int Jet_SearchWindowDisplaced[7][7] = {{0}};
265 int largeRCluster_IDs[15][15]= {{0}};
268 for(
int i = -7;
i< 8;
i++ ) {
269 for(
int j = -7; j< 8; j++) {
271 if(std::abs(
i)<4 && std::abs(j)<4) {
316 std::unique_ptr<jFEXTOB> jJ_tob = std::make_unique<jFEXTOB>();
318 if ( SRJet_tobword != 0 ){
325 std::unique_ptr<jFEXTOB> jLJ_tob = std::make_unique<jFEXTOB>();
337 if ( is_tau_LocalMax ) {
345 std::unique_ptr<jFEXTOB> jTau_tob = std::make_unique<jFEXTOB>();
348 if ( jTau_tobword != 0 ){
380 std::unique_ptr<jFEXTOB> jJ_tob = std::make_unique<jFEXTOB>();
383 if ( SRFCAL_Jet_tobword != 0 ){
391 std::unique_ptr<jFEXTOB> jLJ_tob = std::make_unique<jFEXTOB>();
393 if ( LRFCAL_Jet_tobword != 0 )
m_LRJet_tobwords.push_back(std::move(jLJ_tob));
411 std::vector<int> Ciso;
412 std::vector<int> Chad1;
413 std::vector<int> Chad2;
427 Ciso.push_back(wp_loose.iso_fw());
428 Ciso.push_back(wp_medium.iso_fw());
429 Ciso.push_back(wp_tight.iso_fw());
430 Chad1.push_back(wp_loose.frac_fw());
431 Chad1.push_back(wp_medium.frac_fw());
432 Chad1.push_back(wp_tight.frac_fw());
433 Chad2.push_back(wp_loose.frac2_fw());
434 Chad2.push_back(wp_medium.frac2_fw());
435 Chad2.push_back(wp_tight.frac2_fw());
436 int Cval[9] = {Ciso[0], Ciso[1], Ciso[2], Chad1[0], Chad1[1], Chad1[2], Chad2[0], Chad2[1], Chad2[2]};
438 elCluster.
setup(Cval,jFEXETResolution);
445 std::vector<uint32_t> FwdEltob_aux{FwdEl_tobword,TTID};
446 if ( FwdEl_tobword != 0 && etEM>minEtThreshold)
m_FwdEl_tobwords.push_back(FwdEltob_aux);
465 for(
int j=4; j<17; j++) {
470 ATH_MSG_DEBUG(
"============================ jFEXtauAlgo ============================");
473 for(
int mphi = 8; mphi < 24; mphi++) {
474 for(
int meta = 8; meta < max_meta; meta++) {
476 bool is_tau_LocalMax =
m_jFEXtauAlgoTool->isSeedLocalMaxima_fwd(jTowersIDs[mphi][meta]);
479 if ( is_tau_LocalMax ) {
483 std::unique_ptr<jFEXTOB> jTau_tob = std::make_unique<jFEXTOB>();
485 if ( jTau_tobword != 0 ){
492 return StatusCode::SUCCESS;
498 const int cols =
sizeof tmp_jTowersIDs_subset[0] /
sizeof tmp_jTowersIDs_subset[0][0];
502 ATH_MSG_DEBUG(
"\n==== jFEXFPGA ========= FPGA (" <<
m_id <<
") [on jFEX " <<
m_jfexid <<
"] IS RESPONSIBLE FOR jTOWERS :");
504 for (
int thisRow=
rows-1; thisRow>=0; thisRow--){
505 for (
int thisCol=0; thisCol<
cols; thisCol++){
516 const int cols =
sizeof tmp_jTowersIDs_subset[0] /
sizeof tmp_jTowersIDs_subset[0][0];
521 ATH_MSG_DEBUG(
"\n==== jFEXFPGA ========= FPGA (" <<
m_id <<
") [on jFEX " <<
m_jfexid <<
"] IS RESPONSIBLE FOR jTOWERS :");
523 for (
int thisRow=
rows-1; thisRow>=0; thisRow--) {
524 for (
int thisCol=0; thisCol<
cols; thisCol++) {
525 if(thisCol !=
cols-1) {
539 std::vector<std::unique_ptr<jFEXTOB>> tobsSort;
544 tobsSort.push_back(std::move(j));
546 std::sort (tobsSort.begin(), tobsSort.end(), std::bind(
TOBetSort<std::unique_ptr<jFEXTOB>>, std::placeholders::_1, std::placeholders::_2,
FEXAlgoSpaceDefs::jJ_etBit, 0x7ff));
556 std::vector<std::unique_ptr<jFEXTOB>> tobsSort;
561 tobsSort.push_back(std::move(j));
563 std::sort (tobsSort.begin(), tobsSort.end(), std::bind(
TOBetSort<std::unique_ptr<jFEXTOB>>, std::placeholders::_1, std::placeholders::_2,
FEXAlgoSpaceDefs::jLJ_etBit, 0x1fff));
573 ATH_MSG_DEBUG(
"number of Forward Elec tobs: " << tobsSort.size() <<
" in FPGA: " <<
m_id<<
" before truncation");
575 std::sort (tobsSort.begin(), tobsSort.end(),
etFwdElSort);
584 std::vector<std::unique_ptr<jFEXTOB>> tobsSort;
589 tobsSort.push_back(std::move(j));
598 std::vector<std::unique_ptr<jFEXTOB>> tobsSort;
603 tobsSort.push_back(std::move(j));
614 std::vector<std::unique_ptr<jFEXTOB>> tobsSort;
619 tobsSort.push_back(std::move(j));
634 ATH_MSG_DEBUG(
"In jFEXFPGA::getTTowerET_EM, TTower ID not found in map: " << TTID );
647 ATH_MSG_DEBUG(
"In jFEXFPGA::getTTowerET_HAD, TTower ID not found in map: " << TTID );
669 ATH_MSG_DEBUG(
"In jFEXFPGA::getTTowerET_forMET (EM energy), TTower ID not found in map: " << TTID );
679 ATH_MSG_DEBUG(
"In jFEXFPGA::getTTowerET_forMET (HAD energy), TTower ID not found in map: " << TTID );
684 return tmp_EM + tmp_HAD;