37 ATH_MSG_INFO(
"Intialize TauTrackRNNClassifier tool : " << classifier );
43 return StatusCode::SUCCESS;
51 if (!vertexInHandle.
isValid()) {
52 ATH_MSG_ERROR (
"Could not retrieve HiveDataObj with key " << vertexInHandle.
key());
53 return StatusCode::FAILURE;
71 std::vector<xAOD::TauTrack*> vLRTs;
72 std::vector<xAOD::TauTrack*>::iterator it = vTracks.begin();
73 while(it != vTracks.end()) {
76 it = vTracks.erase(it);
89 ATH_CHECK(classifier->classifyTracks(vLRTs, xTau, vertexContainer, tauTrackCon,
true));
100 std::vector<xAOD::TauTrack*> excludedBadTracks;
101 std::vector<xAOD::TauTrack*>::iterator it = vTracks.begin();
102 while(it != vTracks.end()) {
104 excludedBadTracks.push_back(*it);
105 it = vTracks.erase(it);
112 ATH_CHECK(classifier->classifyTracks(excludedBadTracks, xTau, vertexContainer, tauTrackCon,
true));
122 std::vector<xAOD::TauTrack*> excludedTracks;
123 std::vector<xAOD::TauTrack*>::iterator it = vTracks.begin();
124 while(it != vTracks.end()) {
127 excludedTracks.push_back(*it);
128 it = vTracks.erase(it);
136 ATH_CHECK(classifier->classifyTracks(excludedTracks, xTau, vertexContainer, tauTrackCon,
true));
142 ATH_CHECK(classifier->classifyTracks(vTracks, xTau, vertexContainer, tauTrackCon));
149 charge += trk->track()->charge();
172 return StatusCode::SUCCESS;
183 idScoreCharged(*xTrack) = 0.;
184 idScoreConv(*xTrack) = 0.;
185 idScoreIso(*xTrack) = 0.;
186 idScoreFake(*xTrack) = 0.;
188 double dR = xTau.
p4().DeltaR(xTrack->p4());
190 float weight = (xTrack->d0TJVA() ? xTrack->d0SigTJVA() / xTrack->d0TJVA(): 0);
193 bool passed = (xTrack->pt() > 1000.0) && (dR < 0.2) && (weight > 40.);
195 ANA_MSG_DEBUG(
"xTrack: " << xTrack->pt() <<
" dR: " << dR <<
" weight: " << weight <<
" passed: " <<
passed);
208 return StatusCode::SUCCESS;
216TrackRNN::TrackRNN(
const std::string& name)
230 ATH_MSG_INFO(
"Using calibration file: " << inputWeightsPath);
232 std::ifstream nn_config_istream(inputWeightsPath);
239 return StatusCode::FAILURE;
242 return StatusCode::SUCCESS;
250 bool skipTracks)
const
252 if(vTracks.empty()) {
253 return StatusCode::SUCCESS;
264 idScoreCharged(*track) = 0.;
265 idScoreConv(*track) = 0.;
266 idScoreIso(*track) = 0.;
267 idScoreFake(*track) = 0.;
269 return StatusCode::SUCCESS;
280 seqInput[
"input_1"] = valueMap;
284 std::vector<double> vClassProb(5);
286 for (
unsigned int i = 0; i < vTracks.size(); ++i){
295 vClassProb[0] = mValue[
"type_0"][i];
296 vClassProb[1] = mValue[
"type_1"][i];
297 vClassProb[2] = mValue[
"type_2"][i];
298 vClassProb[3] = mValue[
"type_3"][i];
302 idScoreCharged(*vTracks[i]) = vClassProb[0];
303 idScoreConv(*vTracks[i]) = vClassProb[1];
304 idScoreIso(*vTracks[i]) = vClassProb[2];
305 idScoreFake(*vTracks[i]) = vClassProb[3];
308 for (
unsigned int j = 1; j < vClassProb.size(); ++j){
309 if(vClassProb[j] > vClassProb[iMaxIndex]) iMaxIndex = j;
318 }
else if(iMaxIndex == 0){
320 }
else if(iMaxIndex == 1){
322 }
else if(iMaxIndex == 2){
328 bool alreadyUsed =
false;
329 for (
unsigned int i = 0; i < vTracks.size(); ++i){
334 if( vTracks[i]->track() == tau_trk->track()) alreadyUsed =
true;
338 ATH_MSG_INFO(
"Found Already Used charged track new, now putting it as unclassified" );
348 return StatusCode::SUCCESS;
360 unsigned int n_timeSteps = vTracks.size();
365 valueMap[
"log(trackPt)"] = std::vector<double>(n_timeSteps);
366 valueMap[
"log(jetSeedPt)"] = std::vector<double>(n_timeSteps);
367 valueMap[
"trackPt/tauPtIntermediateAxis"] = std::vector<double>(n_timeSteps);
368 valueMap[
"trackEta"] = std::vector<double>(n_timeSteps);
369 valueMap[
"z0sinthetaTJVA"] = std::vector<double>(n_timeSteps);
370 valueMap[
"z0sinthetaSigTJVA"] = std::vector<double>(n_timeSteps);
371 valueMap[
"log(rConv)"] = std::vector<double>(n_timeSteps);
372 valueMap[
"tanh(rConvII/500)"] = std::vector<double>(n_timeSteps);
373 valueMap[
"dRJetSeedAxis"] = std::vector<double>(n_timeSteps);
374 valueMap[
"dRIntermediateAxis"] = std::vector<double>(n_timeSteps);
375 valueMap[
"tanh(d0SigTJVA/10)"] = std::vector<double>(n_timeSteps);
376 valueMap[
"tanh(d0TJVA/10)"] = std::vector<double>(n_timeSteps);
377 valueMap[
"qOverP*1000"] = std::vector<double>(n_timeSteps);
378 valueMap[
"numberOfInnermostPixelLayerHits"] = std::vector<double>(n_timeSteps);
379 valueMap[
"numberOfPixelSharedHits"] = std::vector<double>(n_timeSteps);
380 valueMap[
"numberOfSCTSharedHits"] = std::vector<double>(n_timeSteps);
381 valueMap[
"numberOfTRTHits"] = std::vector<double>(n_timeSteps);
382 valueMap[
"eProbabilityHT"] = std::vector<double>(n_timeSteps);
383 valueMap[
"nPixHits"] = std::vector<double>(n_timeSteps);
384 valueMap[
"nSCTHits"] = std::vector<double>(n_timeSteps);
385 valueMap[
"dz0_TV_PV0"] = std::vector<double>(n_timeSteps);
386 valueMap[
"log_sumpt_TV"] = std::vector<double>(n_timeSteps);
387 valueMap[
"log_sumpt2_TV"] = std::vector<double>(n_timeSteps);
388 valueMap[
"log_sumpt_PV0"] = std::vector<double>(n_timeSteps);
389 valueMap[
"log_sumpt2_PV0"] = std::vector<double>(n_timeSteps);
390 valueMap[
"charge"] = std::vector<double>(n_timeSteps);
392 valueMap[
"(trackPt/jetSeedPt)"] = std::vector<double>(n_timeSteps);
393 valueMap[
"numberOfInnermostPixelLayerEndcapHits"] = std::vector<double>(n_timeSteps);
394 valueMap[
"nSiHits"] = std::vector<double>(n_timeSteps);
397 double log_ptJetSeed = std::log( xTau.
ptJetSeed() );
400 double dz0_TV_PV0 = 0., sumpt_TV = 0., sumpt2_TV = 0., sumpt_PV0 = 0., sumpt2_PV0 = 0.;
401 if(vertexContainer !=
nullptr && !vertexContainer->
empty() && xTau.
vertex()!=
nullptr) {
402 dz0_TV_PV0 = xTau.
vertex()->
z() - vertexContainer->
at(0)->
z();
405 sumpt_PV0 += (*trk)->pt();
406 sumpt2_PV0 += pow((*trk)->pt(), 2.);
409 sumpt_TV += (*trk)->pt();
410 sumpt2_TV += pow((*trk)->pt(), 2.);
414 double log_sumpt_TV = (sumpt_TV>0.) ? std::log(sumpt_TV) : 0.;
415 double log_sumpt2_TV = (sumpt2_TV>0.) ? std::log(sumpt2_TV) : 0.;
416 double log_sumpt_PV0 = (sumpt_PV0>0.) ? std::log(sumpt_PV0) : 0.;
417 double log_sumpt2_PV0 = (sumpt2_PV0>0.) ? std::log(sumpt2_PV0) : 0.;
437 uint8_t numberOfInnermostPixelLayerEndcapHits = 0;
440 numberOfInnermostPixelLayerEndcapHits = tmp_var;
442 uint8_t nSiHits = nPixelHits + nPixelDeadSensors + nSCTHits + nSCTDeadSensors;
444 valueMap[
"log(trackPt)"][i] = std::log( xTrackParticle->
pt() );
445 valueMap[
"log(jetSeedPt)"][i] = log_ptJetSeed;
447 valueMap[
"trackEta"][i] = xTrackParticle->
eta();
448 valueMap[
"z0sinthetaTJVA"][i] = xTrack->z0sinthetaTJVA();
449 valueMap[
"z0sinthetaSigTJVA"][i] = xTrack->z0sinthetaSigTJVA();
450 valueMap[
"log(rConv)"][i] = std::log( xTrack->rConv() );
451 valueMap[
"tanh(rConvII/500)"][i] = std::tanh( xTrack->rConvII()/500. );
455 valueMap[
"tanh(d0SigTJVA/10)"][i] = std::tanh( xTrack->d0SigTJVA()/10. );
456 valueMap[
"tanh(d0TJVA/10)"][i] = std::tanh( xTrack->d0TJVA()/10. );
457 valueMap[
"qOverP*1000"][i] = xTrackParticle->
qOverP()*1000.;
458 valueMap[
"numberOfInnermostPixelLayerHits"][i] = numberOfInnermostPixelLayerHits;
459 valueMap[
"numberOfPixelSharedHits"][i] = nPixelSharedHits;
460 valueMap[
"numberOfSCTSharedHits"][i] = nSCTSharedHits;
461 valueMap[
"numberOfTRTHits"][i] = nTRTHits;
462 valueMap[
"eProbabilityHT"][i] = eProbabilityHT;
463 valueMap[
"nPixHits"][i] = nPixelHits + nPixelDeadSensors;
464 valueMap[
"nSCTHits"][i] = nSCTHits + nSCTDeadSensors;
465 valueMap[
"dz0_TV_PV0"][i] = dz0_TV_PV0;
466 valueMap[
"log_sumpt_TV"][i] = log_sumpt_TV;
467 valueMap[
"log_sumpt2_TV"][i] = log_sumpt2_TV;
468 valueMap[
"log_sumpt_PV0"][i] = log_sumpt_PV0;
469 valueMap[
"log_sumpt2_PV0"][i] = log_sumpt2_PV0;
470 valueMap[
"charge"][i] = xTrackParticle->
charge();
472 valueMap[
"(trackPt/jetSeedPt)"][i] = xTrackParticle->
pt()/xTau.
ptJetSeed();
473 valueMap[
"numberOfInnermostPixelLayerEndcapHits"][i] = numberOfInnermostPixelLayerEndcapHits;
474 valueMap[
"nSiHits"][i] = nSiHits;
482 return StatusCode::SUCCESS;
#define ATH_CHECK
Evaluate an expression and check for errors.
double charge(const T &p)
const T * at(size_type n) const
Access an element, as an rvalue.
bool empty() const noexcept
Returns true if the collection is empty.
ElementLink implementation for ROOT usage.
Helper class to provide type-safe access to aux data.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
const_pointer_type cptr()
Dereference the pointer.
virtual const std::string & key() const override final
Return the StoreGate ID for the referenced object.
TauTrackLinks_t & allTauTrackLinksNonConst()
In order to sort track links.
virtual FourMom_t p4() const
The full 4-momentum of the particle.
double ptIntermediateAxis() const
void setDetail(TauJetParameters::Detail detail, int value)
const Vertex * vertex() const
size_t nTracks(TauJetParameters::TauTrackFlag flag=TauJetParameters::TauTrackFlag::classifiedCharged) const
std::vector< const TauTrack * > tracks(TauJetParameters::TauTrackFlag flag=TauJetParameters::TauTrackFlag::classifiedCharged) const
Get the v<const pointer> to a given tauTrack collection associated with this tau.
bool summaryValue(uint8_t &value, const SummaryType &information) const
Accessor for TrackSummary values.
float qOverP() const
Returns the parameter.
virtual double pt() const override final
The transverse momentum ( ) of the particle.
virtual double eta() const override final
The pseudorapidity ( ) of the particle.
float charge() const
Returns the charge.
float z() const
Returns the z position.
const TrackParticleLinks_t & trackParticleLinks() const
Get all the particles associated with the vertex.
GraphConfig parse_json_graph(std::istream &json)
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.
std::vector< xAOD::TauTrack * > allTauTracksNonConst(const xAOD::TauJet *tau, xAOD::TauTrackContainer *trackCont)
@ nModifiedIsolationTracks
TrackParticle_v1 TrackParticle
Reference the current persistent version:
VertexContainer_v1 VertexContainer
Definition of the current "Vertex container version".
TauTrack_v1 TauTrack
Definition of the current version.
TauJet_v3 TauJet
Definition of the current "tau version".
TauTrackContainer_v1 TauTrackContainer
Definition of the current TauTrack container version.
@ numberOfInnermostPixelLayerEndcapHits
these are the hits in the 0th pixel layer endcap [unit8_t].
@ numberOfTRTHits
number of TRT hits [unit8_t].
@ numberOfSCTDeadSensors
number of dead SCT sensors crossed [unit8_t].
@ eProbabilityHT
Electron probability from High Threshold (HT) information [float].
@ numberOfSCTHits
number of hits in SCT [unit8_t].
@ numberOfInnermostPixelLayerHits
these are the hits in the 0th pixel barrel layer
@ numberOfPixelHits
these are the pixel hits, including the b-layer [unit8_t].
@ numberOfPixelSharedHits
number of Pixel all-layer hits shared by several tracks [unit8_t].
@ numberOfSCTSharedHits
number of SCT hits shared by several tracks [unit8_t].
@ numberOfPixelDeadSensors
number of dead pixel sensors crossed [unit8_t].
std::map< std::string, OutputNodeConfig > outputs