ATLAS Offline Software
Loading...
Searching...
No Matches
IParticlesLoader.cxx
Go to the documentation of this file.
1/*
2Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
3*/
4
6
8
10
11 // factory for functions which return the sort variable we
12 // use to order iparticles
15 {
16 using Ip = xAOD::IParticle;
17 using Vertex = xAOD::Vertex;
18 switch(config) {
20 return [](const Ip* tp, const Vertex&) {return tp->pt();};
21 default: {
22 throw std::logic_error("Unknown sort function");
23 }
24 }
25 } // end of iparticle sort getter
26
28 const ConstituentsInputConfig & cfg
29 ):
32 m_customSequenceGetter(getter_utils::CustomSequenceGetter<xAOD::IParticle>(
33 cfg.inputs))
34 {
35 const SG::AuxElement::ConstAccessor<PartLinks> acc("particleLinks");
36 m_associator = [acc](const xAOD::Vertex& vertex) -> IPV {
37 IPV particles;
38 for (const ElementLink<IPC>& link : acc(vertex)){
39 if (!link.isValid()) {
40 throw std::logic_error("invalid particle link");
41 }
42 particles.push_back(*link);
43 }
44 return particles;
45 };
46 m_name = cfg.name;
47 }
48
49 std::vector<const xAOD::IParticle*> IParticlesLoader::getIParticlesFromVertex(
50 const xAOD::Vertex& vertex
51 ) const
52 {
53 std::vector<std::pair<double, const xAOD::IParticle*>> particles;
54 for (const xAOD::IParticle *tp : m_associator(vertex)) {
55 particles.emplace_back(m_iparticleSortVar(tp, vertex), tp);
56 }
57 std::sort(particles.begin(), particles.end(), std::greater<>());
58 std::vector<const xAOD::IParticle*> only_particles;
59 only_particles.reserve(particles.size());
60for (const auto& particle: particles) {
61 only_particles.push_back(particle.second);
62 }
63 return only_particles;
64 }
65
66 std::tuple<std::string, FlavorTagInference::Inputs, std::vector<const xAOD::IParticle*>> IParticlesLoader::getData(
67 const xAOD::Vertex& vertex) const {
68 IParticles sorted_particles = getIParticlesFromVertex(vertex);
69 return std::make_tuple(m_config.output_name, m_customSequenceGetter.getFeats(vertex, sorted_particles), sorted_particles);
70 }
71
72 std::string IParticlesLoader::getName() const {
73 return m_name;
74 }
76 return m_config.type;
77 }
78
79}
std::vector< const xAOD::IParticle * > IParticles
ConstituentsType getType() const override
std::vector< const xAOD::IParticle * > getIParticlesFromVertex(const xAOD::Vertex &vertex) const
getter_utils::CustomSequenceGetter< xAOD::IParticle > m_customSequenceGetter
std::vector< const xAOD::IParticle * > IPV
IParticlesLoader(const ConstituentsInputConfig &)
static IParticleSortVar iparticleSortVar(ConstituentsSortOrder)
std::function< IPV(const Vertex &)> m_associator
std::function< double(const xAOD::IParticle *, const Vertex &)> IParticleSortVar
std::tuple< std::string, FlavorTagInference::Inputs, std::vector< const xAOD::IParticle * > > getData(const xAOD::Vertex &vertex) const override
SG::ConstAccessor< T, ALLOC > ConstAccessor
Definition AuxElement.h:569
Class providing the definition of the 4-vector interface.
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.
ICaloAffectedTool is abstract interface for tools checking if 4 mom is in calo affected region.
Vertex_v1 Vertex
Define the latest version of the vertex class.