|
ATLAS Offline Software
|
the tool meant to run at AOD level, to remove the lepton found inside the TauJet.
More...
#include <TauAODLeptonRemovalTool.h>
|
| TauAODLeptonRemovalTool (const std::string &type) |
|
virtual StatusCode | initialize () override |
| Tool initializer. More...
|
|
virtual StatusCode | execute (xAOD::TauJet &) const override |
| Execute - called for each tau candidate. More...
|
|
virtual StatusCode | eventInitialize () override |
| Event initializer - called at the beginning of each event. More...
|
|
virtual StatusCode | executePi0CreateROI (xAOD::TauJet &pTau, CaloConstCellContainer &caloCellContainer, boost::dynamic_bitset<> &map) const override |
|
virtual StatusCode | executeVertexFinder (xAOD::TauJet &pTau, const xAOD::VertexContainer *vertexContainer=nullptr) const override |
|
virtual StatusCode | executeTrackFinder (xAOD::TauJet &pTau, xAOD::TauTrackContainer &tauTrackContainer) const override |
|
virtual StatusCode | executeTrackClassifier (xAOD::TauJet &pTau, xAOD::TauTrackContainer &tauTrackContainer) const override |
|
virtual StatusCode | executeShotFinder (xAOD::TauJet &pTau, xAOD::CaloClusterContainer &shotClusterContainer, xAOD::PFOContainer &PFOContainer) const override |
|
virtual StatusCode | executePi0ClusterCreator (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer, xAOD::PFOContainer &hadronicPFOContainer, const xAOD::CaloClusterContainer &pCaloClusterContainer) const override |
|
virtual StatusCode | executeVertexVariables (xAOD::TauJet &pTau, xAOD::VertexContainer &vertexContainer) const override |
|
virtual StatusCode | executePi0ClusterScaler (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer, xAOD::PFOContainer &chargedPFOContainer) const override |
|
virtual StatusCode | executePi0nPFO (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer) const override |
|
virtual StatusCode | executePanTau (xAOD::TauJet &pTau, xAOD::ParticleContainer &particleContainer, xAOD::PFOContainer &neutralPFOContainer) const override |
|
virtual StatusCode | eventFinalize () override |
| Event finalizer - called at the end of each event. More...
|
|
virtual StatusCode | finalize () override |
| Finalizer. More...
|
|
std::string | find_file (const std::string &fname) const |
|
virtual StatusCode | readConfig () override |
|
virtual void | print () const |
| Print the state of the tool. More...
|
|
ServiceHandle< StoreGateSvc > & | evtStore () |
| The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc . More...
|
|
const ServiceHandle< StoreGateSvc > & | evtStore () const |
| The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc . More...
|
|
const ServiceHandle< StoreGateSvc > & | detStore () const |
| The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc . More...
|
|
virtual StatusCode | sysInitialize () override |
| Perform system initialization for an algorithm. More...
|
|
virtual StatusCode | sysStart () override |
| Handle START transition. More...
|
|
virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override |
| Return this algorithm's input handles. More...
|
|
virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override |
| Return this algorithm's output handles. More...
|
|
Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T > &t) |
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &) |
| Declare a new Gaudi property. More...
|
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &) |
| Declare a new Gaudi property. More...
|
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &) |
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &) |
| Declare a new Gaudi property. More...
|
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc="none") |
| Declare a new Gaudi property. More...
|
|
void | updateVHKA (Gaudi::Details::PropertyBase &) |
|
MsgStream & | msg () const |
|
MsgStream & | msg (const MSG::Level lvl) const |
|
bool | msgLvl (const MSG::Level lvl) const |
|
|
Gaudi::Property< bool > | m_in_trigger {this, "inTrigger", false, "Indicate if the tool is running on trigger"} |
|
Gaudi::Property< bool > | m_in_AOD {this, "inAOD", false, "Indicate if the tool is running on AOD"} |
|
Gaudi::Property< bool > | m_in_EleRM {this, "inEleRM", false, "Indicate if the tool is running on EleRM routine"} |
|
Gaudi::Property< std::string > | m_tauRecToolsTag {this, "calibFolder", "tauRecTools/R22_preprod", "CVMFS path to the tau calibration folder"} |
|
|
std::vector< const xAOD::CaloCluster * > | getOrignalTopoClusters (const xAOD::CaloCluster *cluster) const |
|
const xAOD::TrackParticle * | getOrignalTrackParticle (const xAOD::TrackParticle *trk) const |
|
std::vector< std::pair< const xAOD::TrackParticle *, const xAOD::Electron * > > | getElecAndTrk (const xAOD::TauJet &tau, const xAOD::ElectronContainer &elec_cont) const |
|
std::vector< std::pair< const xAOD::CaloCluster *, const xAOD::Electron * > > | getElecAndCls (const xAOD::TauJet &tau, const xAOD::ElectronContainer &elec_cont) const |
|
std::vector< std::pair< const xAOD::TrackParticle *, const xAOD::Muon * > > | getMuonAndTrk (const xAOD::TauJet &tau, const xAOD::MuonContainer &muon_cont) const |
|
std::vector< std::pair< const xAOD::CaloCluster *, const xAOD::Muon * > > | getMuonAndCls (const xAOD::TauJet &tau, const xAOD::MuonContainer &muon_cont) const |
|
template<typename Tlep , typename Tlinks > |
std::vector< Tlep > | removeTrks (Tlinks &tau_trk_links, std::vector< std::pair< const xAOD::TrackParticle *, Tlep >> &removings) const |
|
template<typename Tlep , typename Tlinks > |
std::vector< Tlep > | removeClss (Tlinks &tau_cls_links, std::vector< std::pair< const xAOD::CaloCluster *, Tlep >> &clusters_and_leps) const |
|
Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKey> More...
|
|
Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
|
|
Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &) |
| specialization for handling Gaudi::Property<SG::VarHandleBase> More...
|
|
Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &) |
| specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
|
|
|
const std::map< std::string, uint > | m_mapMuonIdWp = {{"Tight", 0}, {"Medium", 1}, {"Loose", 2}, {"VeryLoose",3}} |
|
std::string | m_elecWpStr = "DFCommonElectronsLHMedium" |
|
uint | m_muonWpUi = 1 |
|
SG::ReadHandleKey< xAOD::MuonContainer > | m_muonInputContainer {this, "Key_MuonInputContainer", "Muons", "input xAOD muons"} |
|
SG::ReadHandleKey< xAOD::ElectronContainer > | m_elecInputContainer {this, "Key_ElecInputContainer", "Electrons", "input xAOD electrons"} |
|
Gaudi::Property< bool > | m_doMuonTrkRm {this, "doMuonTrkRm", false, "Whether to remove the muon tracks from the tau candidate" } |
|
Gaudi::Property< bool > | m_doElecTrkRm {this, "doElecTrkRm", false, "Whether to remove the electron tracks from the tau candidate" } |
|
Gaudi::Property< bool > | m_doMuonClsRm {this, "doMuonClsRm", false, "Whether to remove the muon clusters from the tau candidate" } |
|
Gaudi::Property< bool > | m_doElecClsRm {this, "doElecClsRm", false, "Whether to remove the electron clusters from the tau candidate" } |
|
Gaudi::Property< std::string > | m_strMinElecIdWp {this, "elecIDWP", "Medium", "minimum electron identification WP, [VeryLoose, Loose, Medium, Tight]"} |
|
Gaudi::Property< std::string > | m_strMinMuonIdWp {this, "muonIDWP", "Medium", "minimum muon identification WP, [VeryLoose, Loose, Medium, Tight]" } |
|
Gaudi::Property< std::string > | m_strElecIdWpPrefix {this, "eleIDWPPrefix", "DFCommonElectronsLH", "The prefix of the electron ID WP, leave to default if in confusion" } |
|
Gaudi::Property< double > | m_lepRemovalConeSize {this, "lepRemovalConeSize", 0.6, "The maximum dR between the lepton and the tau" } |
|
StoreGateSvc_t | m_evtStore |
| Pointer to StoreGate (event store by default) More...
|
|
StoreGateSvc_t | m_detStore |
| Pointer to StoreGate (detector store by default) More...
|
|
std::vector< SG::VarHandleKeyArray * > | m_vhka |
|
bool | m_varHandleArraysDeclared |
|
the tool meant to run at AOD level, to remove the lepton found inside the TauJet.
Definition at line 20 of file TauAODLeptonRemovalTool.h.
◆ StoreGateSvc_t
◆ TauAODLeptonRemovalTool()
TauAODLeptonRemovalTool::TauAODLeptonRemovalTool |
( |
const std::string & |
type | ) |
|
◆ declareGaudiProperty() [1/4]
specialization for handling Gaudi::Property<SG::VarHandleKeyArray>
Definition at line 170 of file AthCommonDataStore.h.
175 hndl.documentation());
◆ declareGaudiProperty() [2/4]
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
161 hndl.documentation());
◆ declareGaudiProperty() [3/4]
specialization for handling Gaudi::Property<SG::VarHandleBase>
Definition at line 184 of file AthCommonDataStore.h.
189 hndl.documentation());
◆ declareGaudiProperty() [4/4]
◆ declareProperty() [1/6]
Declare a new Gaudi property.
- Parameters
-
name | Name of the property. |
hndl | Object holding the property value. |
doc | Documentation string for the property. |
This is the version for types that derive from SG::VarHandleBase
. The property value object is put on the input and output lists as appropriate; then we forward to the base class.
Definition at line 245 of file AthCommonDataStore.h.
250 this->declare(hndl.
vhKey());
251 hndl.
vhKey().setOwner(
this);
253 return PBASE::declareProperty(
name,hndl,
doc);
◆ declareProperty() [2/6]
Declare a new Gaudi property.
- Parameters
-
name | Name of the property. |
hndl | Object holding the property value. |
doc | Documentation string for the property. |
This is the version for types that derive from SG::VarHandleKey
. The property value object is put on the input and output lists as appropriate; then we forward to the base class.
Definition at line 221 of file AthCommonDataStore.h.
229 return PBASE::declareProperty(
name,hndl,
doc);
◆ declareProperty() [3/6]
◆ declareProperty() [4/6]
Declare a new Gaudi property.
- Parameters
-
name | Name of the property. |
property | Object holding the property value. |
doc | Documentation string for the property. |
This is the generic version, for types that do not derive from SG::VarHandleKey
. It just forwards to the base class version of declareProperty
.
Definition at line 333 of file AthCommonDataStore.h.
338 return PBASE::declareProperty(
name, property,
doc);
◆ declareProperty() [5/6]
Declare a new Gaudi property.
- Parameters
-
name | Name of the property. |
property | Object holding the property value. |
doc | Documentation string for the property. |
This dispatches to either the generic declareProperty
or the one for VarHandle/Key/KeyArray.
Definition at line 352 of file AthCommonDataStore.h.
◆ declareProperty() [6/6]
◆ detStore()
◆ eventFinalize()
StatusCode TauRecToolBase::eventFinalize |
( |
| ) |
|
|
overridevirtualinherited |
◆ eventInitialize()
StatusCode TauRecToolBase::eventInitialize |
( |
| ) |
|
|
overridevirtualinherited |
◆ evtStore() [1/2]
◆ evtStore() [2/2]
◆ execute()
StatusCode TauAODLeptonRemovalTool::execute |
( |
xAOD::TauJet & |
pTau | ) |
const |
|
overridevirtual |
Execute - called for each tau candidate.
Reimplemented from TauRecToolBase.
Definition at line 19 of file TauAODLeptonRemovalTool.cxx.
23 if (
bool fail_elec = !elec_input_handle.isValid(), fail_muon = !muon_input_handle.isValid(); fail_elec || fail_muon) {
24 ATH_MSG_ERROR( (fail_elec ?
"Could not retrieve Electron container with key " + elec_input_handle.key() :
"") +
25 (fail_muon ?
"\tCould not retrieve Muon container with key " + muon_input_handle.key() :
"")
27 return StatusCode::FAILURE;
29 auto elec_container = elec_input_handle.cptr();
30 auto muon_container = muon_input_handle.cptr();
34 acc_removed_muons(tau).clear();
35 acc_removed_elecs(tau).clear();
37 auto elec_and_tracks = decltype((
getElecAndTrk)(tau, *elec_container))();
38 auto elec_and_clusters = decltype((
getElecAndCls)(tau, *elec_container))();
39 auto muon_and_tracks = decltype((
getMuonAndTrk)(tau, *muon_container))();
40 auto muon_and_clusters = decltype((
getMuonAndCls)(tau, *muon_container))();
46 if(elec_and_tracks.empty() && elec_and_clusters.empty() && muon_and_tracks.empty() && muon_and_clusters.empty())
return StatusCode::SUCCESS;
48 auto tau_track_links = tau.allTauTrackLinksNonConst();
49 auto tau_cluster_links = tau.clusterLinks();
50 auto trk_removed_muons =
removeTrks(tau_track_links, muon_and_tracks);
51 auto trk_removed_elecs =
removeTrks(tau_track_links, elec_and_tracks);
52 auto cls_removed_muons =
removeClss(tau_cluster_links, muon_and_clusters);
53 auto cls_removed_elecs =
removeClss(tau_cluster_links, elec_and_clusters);
54 tau.clearTauTrackLinks();
55 tau.clearClusterLinks();
56 tau.setClusterLinks(tau_cluster_links);
57 tau.setAllTauTrackLinks(tau_track_links);
59 auto removed_muons = std::move(trk_removed_muons);
60 auto removed_elecs = std::move(trk_removed_elecs);
61 removed_muons.insert(removed_muons.end(), cls_removed_muons.begin(), cls_removed_muons.end());
62 removed_elecs.insert(removed_elecs.end(), cls_removed_elecs.begin(), cls_removed_elecs.end());
63 auto removed_muons_set =
std::set(removed_muons.begin(), removed_muons.end());
64 auto removed_elecs_set =
std::set(removed_elecs.begin(), removed_elecs.end());
66 for (
auto muon : removed_muons_set ){
69 acc_removed_muons(tau).push_back(link);
71 for (
auto elec : removed_elecs_set){
74 acc_removed_elecs(tau).push_back(link);
77 if (!acc_removed_elecs(tau).
empty() || !acc_removed_muons(tau).
empty())
80 acc_modified(tau) =
static_cast<char>(
true);
82 return StatusCode::SUCCESS;
◆ executePanTau()
◆ executePi0ClusterCreator()
◆ executePi0ClusterScaler()
◆ executePi0CreateROI()
◆ executePi0nPFO()
◆ executeShotFinder()
◆ executeTrackClassifier()
◆ executeTrackFinder()
◆ executeVertexFinder()
◆ executeVertexVariables()
◆ extraDeps_update_handler()
Add StoreName to extra input/output deps as needed.
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given
◆ finalize()
StatusCode TauRecToolBase::finalize |
( |
| ) |
|
|
overridevirtualinherited |
◆ find_file()
std::string TauRecToolBase::find_file |
( |
const std::string & |
fname | ) |
const |
|
inherited |
◆ getElecAndCls()
Definition at line 132 of file TauAODLeptonRemovalTool.cxx.
133 std::vector<std::pair<const xAOD::CaloCluster*, const xAOD::Electron*>> ret;
134 std::for_each(elec_container.cbegin(), elec_container.cend(),
135 [&](
auto elec) ->
void {
136 if(tau.p4().DeltaR(elec->p4()) < m_lepRemovalConeSize && elec->passSelection(m_elecWpStr)) {
137 auto elec_cluster_links = elec->caloClusterLinks();
138 for (const auto & elec_cluster_link : elec_cluster_links) {
139 if (elec_cluster_link.isValid()) {
140 auto orig_elec_clusters = getOrignalTopoClusters(*elec_cluster_link);
141 for (auto cluster : orig_elec_clusters){
142 ret.push_back(std::make_pair(cluster, elec));
◆ getElecAndTrk()
Definition at line 114 of file TauAODLeptonRemovalTool.cxx.
115 std::vector<std::pair<const xAOD::TrackParticle*, const xAOD::Electron*>> ret;
116 std::for_each(elec_container.cbegin(), elec_container.cend(),
117 [&](
auto elec) ->
void {
118 if(tau.p4().DeltaR(elec->p4()) < m_lepRemovalConeSize && elec->passSelection(m_elecWpStr)) {
119 auto elec_ID_tracks_links = elec->trackParticleLinks();
120 for (const auto &elec_ID_tracks_link : elec_ID_tracks_links) {
121 if (elec_ID_tracks_link.isValid()) {
122 if(auto orig_ele_trk = getOrignalTrackParticle(*elec_ID_tracks_link); orig_ele_trk)
123 ret.push_back(std::make_pair(orig_ele_trk, elec));
◆ getKey()
Get the (hashed) key of an object that is in the event store.
This is a bit of a special one. StoreGateSvc
and xAOD::TEvent
both provide ways for getting the SG::sgkey_t
key for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.
In order to allow tools to efficiently perform this operation, they can use this helper function.
- See also
- asg::AsgTool::getName
- Parameters
-
ptr | The bare pointer to the object that the event store should know about |
- Returns
- The hashed key of the object in the store. If not found, an invalid (zero) key.
Definition at line 119 of file AsgTool.cxx.
121 #ifdef XAOD_STANDALONE
127 return (
proxy ==
nullptr ? 0 :
proxy->sgkey() );
128 #endif // XAOD_STANDALONE
◆ getMuonAndCls()
Definition at line 165 of file TauAODLeptonRemovalTool.cxx.
166 std::vector<std::pair<const xAOD::CaloCluster*, const xAOD::Muon*>> ret;
167 std::for_each(muon_container.cbegin(), muon_container.cend(),
168 [&](
auto muon) ->
void {
169 if(tau.p4().DeltaR(muon->p4()) < m_lepRemovalConeSize && muon->quality() <= m_muonWpUi) {
170 if(const auto & muon_cluster_link = muon->clusterLink(); muon_cluster_link.isValid()) {
171 auto muon_cluster = std::move(*muon_cluster_link);
172 auto muon_e = muon->e();
173 auto loss_e = muon->floatParameter(xAOD::Muon::ParamEnergyLoss);
174 auto cls_e = muon_cluster->e();
175 auto loss_diff = ((cls_e - loss_e) / (cls_e + loss_e));
176 if (muon_e > cls_e && loss_diff < 0.1 && loss_diff > -0.3) {
177 auto orig_muon_clusters = getOrignalTopoClusters(muon_cluster);
178 for (auto cluster : orig_muon_clusters)
179 ret.push_back(std::make_pair(cluster, muon));
◆ getMuonAndTrk()
Definition at line 152 of file TauAODLeptonRemovalTool.cxx.
153 std::vector<std::pair<const xAOD::TrackParticle*, const xAOD::Muon*>> ret;
154 std::for_each(muon_container.cbegin(), muon_container.cend(),
155 [&](
auto muon) ->
void {
156 if(tau.p4().DeltaR(muon->p4()) < m_lepRemovalConeSize && muon->quality() <= m_muonWpUi) {
157 if(const auto & muon_ID_tracks_link = muon->inDetTrackParticleLink(); muon_ID_tracks_link.isValid())
158 ret.push_back(std::make_pair(std::move(*muon_ID_tracks_link), muon));
◆ getName()
const std::string & asg::AsgTool::getName |
( |
const void * |
ptr | ) |
const |
|
inherited |
Get the name of an object that is / should be in the event store.
This is a bit of a special one. StoreGateSvc
and xAOD::TEvent
both provide ways for getting the std::string
name for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.
In order to allow tools to efficiently perform this operation, they can use this helper function.
- See also
- asg::AsgTool::getKey
- Parameters
-
ptr | The bare pointer to the object that the event store should know about |
- Returns
- The string name of the object in the store. If not found, an empty string.
Definition at line 106 of file AsgTool.cxx.
108 #ifdef XAOD_STANDALONE
114 static const std::string
dummy =
"";
116 #endif // XAOD_STANDALONE
◆ getOrignalTopoClusters()
Definition at line 86 of file TauAODLeptonRemovalTool.cxx.
88 std::vector< const xAOD::CaloCluster* > orig_cls;
89 if(acc_origClusterLinks.isAvailable(*cluster)) {
90 auto links = acc_origClusterLinks(*cluster);
91 for (
const auto &link :
links) {
92 if (link.dataID() !=
"CaloCalTopoClusters")
93 ATH_MSG_WARNING(
"the clusters in the lepton cannot be converted to CaloCalTopoClusters, the ID is " << link.dataID());
95 orig_cls.push_back(*link);
◆ getOrignalTrackParticle()
Definition at line 101 of file TauAODLeptonRemovalTool.cxx.
104 if(acc_origTracks.isAvailable(*trk)) {
105 if (
const auto & orig_link = acc_origTracks(*trk); orig_link.isValid()) {
106 if (orig_link.dataID() !=
"InDetTrackParticles")
107 ATH_MSG_WARNING(
"the tracks in the lepton cannot be converted to InDetTrackParticles, the ID is " << orig_link.dataID());
108 orig_trk = *orig_link;
◆ getProperty()
template<class T >
const T* asg::AsgTool::getProperty |
( |
const std::string & |
name | ) |
const |
|
inherited |
Get one of the tool's properties.
◆ inAOD()
bool TauRecToolBase::inAOD |
( |
| ) |
const |
|
inlineprotectedinherited |
◆ inEleRM()
bool TauRecToolBase::inEleRM |
( |
| ) |
const |
|
inlineprotectedinherited |
◆ initialize()
StatusCode TauAODLeptonRemovalTool::initialize |
( |
| ) |
|
|
overridevirtual |
◆ inputHandles()
Return this algorithm's input handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
◆ inTrigger()
bool TauRecToolBase::inTrigger |
( |
| ) |
const |
|
inlineprotectedinherited |
◆ msg() [1/2]
◆ msg() [2/2]
◆ msg_level_name()
const std::string & asg::AsgTool::msg_level_name |
( |
| ) |
const |
|
inherited |
A deprecated function for getting the message level's name.
Instead of using this, weirdly named function, user code should get the string name of the current minimum message level (in case they really need it...), with:
MSG::name( msg().level() )
This function's name doesn't follow the ATLAS coding rules, and as such will be removed in the not too distant future.
- Returns
- The string name of the current minimum message level that's printed
Definition at line 101 of file AsgTool.cxx.
◆ msgLvl()
◆ outputHandles()
Return this algorithm's output handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
◆ print()
void asg::AsgTool::print |
( |
| ) |
const |
|
virtualinherited |
Print the state of the tool.
Implements asg::IAsgTool.
Reimplemented in JetRecTool, JetFinder, JetModifiedMassDrop, JetFromPseudojet, JetReclusterer, JetReclusteringTool, JetTruthLabelingTool, JetPileupLabelingTool, HI::HIPileupTool, JetDumper, JetBottomUpSoftDrop, JetRecursiveSoftDrop, JetSoftDrop, JetConstituentsRetriever, JetSubStructureMomentToolsBase, JetSplitter, JetToolRunner, JetPruner, JetPseudojetRetriever, JetTrimmer, AsgHelloTool, and KtDeltaRTool.
Definition at line 131 of file AsgTool.cxx.
◆ readConfig()
StatusCode TauRecToolBase::readConfig |
( |
| ) |
|
|
overridevirtualinherited |
Implements ITauToolBase.
Definition at line 27 of file TauRecToolBase.cxx.
32 #ifndef XAOD_STANDALONE
33 bool configPathDeclared =
false;
34 for (Gaudi::Details::PropertyBase* property : getProperties())
36 if (property->name() ==
"ConfigPath")
38 configPathDeclared =
true;
42 if (!configPathDeclared)
43 #elif defined(XAOD_STANDALONE)
44 PropertyMgr::PropMap_t property_map = getPropertyMgr()->getProperties();
45 if (property_map.find(
"ConfigPath") == property_map.end())
47 # error "What environment are we in?!?"
48 #endif // XAOD_STANDALONE
50 ATH_MSG_INFO(
"No config file path property declared yet, this is not recommended");
51 return StatusCode::SUCCESS;
55 const std::string* config_file_path_property;
58 config_file_path_property = getProperty<std::string>(
"ConfigPath");
59 std::string config_file_path =
find_file(*config_file_path_property);
63 THashList* lList =
env.GetTable();
64 for( Int_t
i = 0; lList &&
i < lList->GetEntries(); ++
i )
68 #ifndef XAOD_STANDALONE
70 const std::type_info*
type =
getProperty(lList->At(
i )->GetName()).type_info();
73 if (*
type ==
typeid(
bool))
74 sc = this->setProperty(lList->At(
i )->GetName(),
75 bool(
env.GetValue(lList->At(
i )->GetName(),
bool(
true))));
76 else if (*
type ==
typeid(
int))
77 sc = this->setProperty(lList->At(
i )->GetName(),
78 env.GetValue(lList->At(
i )->GetName(),
int(0)));
79 else if (*
type ==
typeid(
float))
80 sc = this->setProperty(lList->At(
i )->GetName(),
81 env.GetValue(lList->At(
i )->GetName(),
float(0)));
82 else if (*
type ==
typeid(
double))
83 sc = this->setProperty(lList->At(
i )->GetName(),
84 env.GetValue(lList->At(
i )->GetName(),
double(0)));
85 else if (*
type ==
typeid(std::string))
86 sc = this->setProperty(lList->At(
i )->GetName(),
87 env.GetValue(lList->At(
i )->GetName(),
""));
93 sc = this->setProperty(lList->At(
i )->GetName(),
94 bool(
env.GetValue(lList->At(
i )->GetName(),
bool(
true))));
96 sc = this->setProperty(lList->At(
i )->GetName(),
97 env.GetValue(lList->At(
i )->GetName(),
int(0)));
99 sc = this->setProperty(lList->At(
i )->GetName(),
100 env.GetValue(lList->At(
i )->GetName(),
float(0)));
102 sc = this->setProperty(lList->At(
i )->GetName(),
103 env.GetValue(lList->At(
i )->GetName(),
double(0)));
105 sc = this->setProperty(lList->At(
i )->GetName(),
106 env.GetValue(lList->At(
i )->GetName(),
""));
107 #endif // XAOD_STANDALONE
110 #ifndef XAOD_STANDALONE
111 ATH_MSG_FATAL(
"there was a problem to find the correct type enum: "<<
type->name());
114 #endif // XAOD_STANDALONE
115 return StatusCode::FAILURE;
117 if (!
sc.isSuccess()) {
118 ATH_MSG_FATAL(
"failed to set property: " << lList->At(
i )->GetName());
119 return StatusCode::FAILURE;
122 return StatusCode::SUCCESS;
◆ removeClss()
template<typename Tlep , typename Tlinks >
std::vector< Tlep > TauAODLeptonRemovalTool::removeClss |
( |
Tlinks & |
tau_cls_links, |
|
|
std::vector< std::pair< const xAOD::CaloCluster *, Tlep >> & |
clusters_and_leps |
|
) |
| const |
|
private |
Definition at line 212 of file TauAODLeptonRemovalTool.cxx.
213 std::vector<Tlep> ret;
215 std::remove_if(tau_cls_links.begin(), tau_cls_links.end(),
216 [&](
auto tau_cls_link) ->
bool {
218 if(tau_cls_link.isValid()) {
219 auto tau_cls = static_cast<const xAOD::CaloCluster*>(*tau_cls_link);
220 auto where = std::find_if(clusters_and_leps.cbegin(), clusters_and_leps.cend(),
221 [&](auto cluster_and_lep){ return tau_cls == cluster_and_lep.first; });
222 if(where != clusters_and_leps.cend()) {
223 ATH_MSG_DEBUG(
"cluster with pt " << tau_cls->pt()/1000 <<
" GeV removed");
224 ret.push_back(where->second);
◆ removeTrks()
template<typename Tlep , typename Tlinks >
std::vector< Tlep > TauAODLeptonRemovalTool::removeTrks |
( |
Tlinks & |
tau_trk_links, |
|
|
std::vector< std::pair< const xAOD::TrackParticle *, Tlep >> & |
removings |
|
) |
| const |
|
private |
Definition at line 188 of file TauAODLeptonRemovalTool.cxx.
189 std::vector<Tlep> ret;
191 std::remove_if(tau_trk_links.begin(), tau_trk_links.end(),
192 [&](
auto tau_trk_link) ->
bool {
194 if(tau_trk_link.isValid()) {
195 auto tau_trk = (*tau_trk_link)->track();
196 auto where = std::find_if(tracks_and_leps.cbegin(), tracks_and_leps.cend(),
197 [&](auto track_and_lep){ return tau_trk == track_and_lep.first; });
198 if(where != tracks_and_leps.cend()) {
199 ATH_MSG_DEBUG(
"track with pt " << tau_trk->pt()/1000 <<
" GeV removed");
200 ret.push_back(where->second);
◆ renounce()
◆ renounceArray()
◆ sysInitialize()
◆ sysStart()
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
◆ updateVHKA()
◆ m_detStore
◆ m_doElecClsRm
Gaudi::Property<bool> TauAODLeptonRemovalTool::m_doElecClsRm {this, "doElecClsRm", false, "Whether to remove the electron clusters from the tau candidate" } |
|
private |
◆ m_doElecTrkRm
Gaudi::Property<bool> TauAODLeptonRemovalTool::m_doElecTrkRm {this, "doElecTrkRm", false, "Whether to remove the electron tracks from the tau candidate" } |
|
private |
◆ m_doMuonClsRm
Gaudi::Property<bool> TauAODLeptonRemovalTool::m_doMuonClsRm {this, "doMuonClsRm", false, "Whether to remove the muon clusters from the tau candidate" } |
|
private |
◆ m_doMuonTrkRm
Gaudi::Property<bool> TauAODLeptonRemovalTool::m_doMuonTrkRm {this, "doMuonTrkRm", false, "Whether to remove the muon tracks from the tau candidate" } |
|
private |
◆ m_elecInputContainer
◆ m_elecWpStr
std::string TauAODLeptonRemovalTool::m_elecWpStr = "DFCommonElectronsLHMedium" |
|
private |
◆ m_evtStore
◆ m_in_AOD
Gaudi::Property<bool> TauRecToolBase::m_in_AOD {this, "inAOD", false, "Indicate if the tool is running on AOD"} |
|
protectedinherited |
◆ m_in_EleRM
Gaudi::Property<bool> TauRecToolBase::m_in_EleRM {this, "inEleRM", false, "Indicate if the tool is running on EleRM routine"} |
|
protectedinherited |
◆ m_in_trigger
Gaudi::Property<bool> TauRecToolBase::m_in_trigger {this, "inTrigger", false, "Indicate if the tool is running on trigger"} |
|
protectedinherited |
◆ m_lepRemovalConeSize
Gaudi::Property<double> TauAODLeptonRemovalTool::m_lepRemovalConeSize {this, "lepRemovalConeSize", 0.6, "The maximum dR between the lepton and the tau" } |
|
private |
◆ m_mapMuonIdWp
const std::map<std::string, uint> TauAODLeptonRemovalTool::m_mapMuonIdWp = {{"Tight", 0}, {"Medium", 1}, {"Loose", 2}, {"VeryLoose",3}} |
|
private |
◆ m_muonInputContainer
◆ m_muonWpUi
uint TauAODLeptonRemovalTool::m_muonWpUi = 1 |
|
private |
◆ m_strElecIdWpPrefix
Gaudi::Property<std::string> TauAODLeptonRemovalTool::m_strElecIdWpPrefix {this, "eleIDWPPrefix", "DFCommonElectronsLH", "The prefix of the electron ID WP, leave to default if in confusion" } |
|
private |
◆ m_strMinElecIdWp
Gaudi::Property<std::string> TauAODLeptonRemovalTool::m_strMinElecIdWp {this, "elecIDWP", "Medium", "minimum electron identification WP, [VeryLoose, Loose, Medium, Tight]"} |
|
private |
◆ m_strMinMuonIdWp
Gaudi::Property<std::string> TauAODLeptonRemovalTool::m_strMinMuonIdWp {this, "muonIDWP", "Medium", "minimum muon identification WP, [VeryLoose, Loose, Medium, Tight]" } |
|
private |
◆ m_tauRecToolsTag
Gaudi::Property<std::string> TauRecToolBase::m_tauRecToolsTag {this, "calibFolder", "tauRecTools/R22_preprod", "CVMFS path to the tau calibration folder"} |
|
protectedinherited |
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files:
Type
Property type enumeration.
bool toContainedElement(BaseConstReference data, ElementType element, IProxyDict *sg=0)
Set from element pointer and a reference to the container (storable)
Helper class to provide type-safe access to aux data.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
virtual void setOwner(IDataHandleHolder *o)=0
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
::StatusCode StatusCode
StatusCode definition for legacy code.
const std::string & name(Level lvl)
Convenience function for translating message levels to strings.
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
constexpr std::enable_if_t< is_bitmask_v< E >, E & > set(E &lhs, E rhs)
Convenience function to set bits in a class enum bitmask.
virtual void renounce()=0
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
ElementLink implementation for ROOT usage.
std::string PathResolverFindCalibFile(const std::string &logical_file_name)
#define ATH_MSG_WARNING(x)
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Class describing a TrackParticle.
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
bool match(std::string s1, std::string s2)
match the individual directories of two strings