ATLAS Offline Software
Loading...
Searching...
No Matches
PhotonsLoader.cxx
Go to the documentation of this file.
1/*
2Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
3*/
4
6
7#include "xAODEgamma/Photon.h"
8
10
11 // factory for functions which return the sort variable we
12 // use to order iparticles
15 {
16 using Ip = xAOD::Photon;
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::Photon>(
33 cfg.inputs))
34 {
35 const SG::AuxElement::ConstAccessor<PartLinks> acc("photonLinks");
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::Photon*> PhotonsLoader::getPhotonsFromVertex(
50 const xAOD::Vertex& vertex
51 ) const
52 {
53 std::vector<std::pair<double, const xAOD::Photon*>> particles;
54 for (const xAOD::Photon *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::Photon*> 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*>> PhotonsLoader::getData(
67 const xAOD::Vertex& vertex) const {
68 Photons sorted_particles = getPhotonsFromVertex(vertex);
69 std::vector<const xAOD::IParticle*> sorted_particles_ip;
70 for (const auto& p: sorted_particles) {
71 sorted_particles_ip.push_back(p);
72 }
73 return std::make_tuple(m_config.output_name, m_customSequenceGetter.getFeats(vertex, sorted_particles), sorted_particles_ip);
74 }
75
76 std::string PhotonsLoader::getName() const {
77 return m_name;
78 }
80 return m_config.type;
81 }
82
83}
std::vector< const xAOD::Photon * > Photons
std::vector< const xAOD::Photon * > getPhotonsFromVertex(const xAOD::Vertex &vertex) const
getter_utils::CustomSequenceGetter< xAOD::Photon > m_customSequenceGetter
std::vector< const xAOD::Photon * > IPV
std::function< IPV(const Vertex &)> m_associator
ConstituentsType getType() const override
PhotonsLoader(const ConstituentsInputConfig &cfg)
std::tuple< std::string, FlavorTagInference::Inputs, std::vector< const xAOD::IParticle * > > getData(const xAOD::Vertex &vertex) const override
static PhotonSortVar iparticleSortVar(ConstituentsSortOrder)
std::function< double(const xAOD::Photon *, const Vertex &)> PhotonSortVar
SG::ConstAccessor< T, ALLOC > ConstAccessor
Definition AuxElement.h:569
Class describing an photon.
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.
Photon_v1 Photon
Definition of the current "egamma version".