ATLAS Offline Software
Loading...
Searching...
No Matches
Simulation::MatchingBkgVertexPositioner Class Reference

Returns a VertexShift based on what is given in the background input file. More...

#include <MatchingBkgVertexPositioner.h>

Inheritance diagram for Simulation::MatchingBkgVertexPositioner:
Collaboration diagram for Simulation::MatchingBkgVertexPositioner:

Public Member Functions

 MatchingBkgVertexPositioner (const std::string &t, const std::string &n, const IInterface *p)
virtual ~MatchingBkgVertexPositioner ()=default
StatusCode initialize () override final
CLHEP::HepLorentzVector * generate (const EventContext &ctx) const override final

Private Attributes

SG::ReadHandleKey< xAOD::VertexContainerm_vertexContainerKey

Detailed Description

Returns a VertexShift based on what is given in the background input file.

Definition at line 24 of file MatchingBkgVertexPositioner.h.

Constructor & Destructor Documentation

◆ MatchingBkgVertexPositioner()

Simulation::MatchingBkgVertexPositioner::MatchingBkgVertexPositioner ( const std::string & t,
const std::string & n,
const IInterface * p )

Definition at line 12 of file MatchingBkgVertexPositioner.cxx.

15 : base_class(t, n, p) {}

◆ ~MatchingBkgVertexPositioner()

virtual Simulation::MatchingBkgVertexPositioner::~MatchingBkgVertexPositioner ( )
virtualdefault

Member Function Documentation

◆ generate()

CLHEP::HepLorentzVector * Simulation::MatchingBkgVertexPositioner::generate ( const EventContext & ctx) const
finaloverride

Definition at line 25 of file MatchingBkgVertexPositioner.cxx.

26 {
27 // we can currently not reliably determine if the timing information is
28 // available
29 bool enableTime{};
30
31 SG::ReadHandle<xAOD::VertexContainer> vertices(m_vertexContainerKey, ctx);
32 if (!vertices.isValid()) {
33 ATH_MSG_ERROR("Couldn't retrieve xAOD::VertexContainer with key: "
35 return nullptr;
36 }
37
38 for (const xAOD::Vertex *vx : *(vertices.cptr())) {
39 if (vx->vertexType() == xAOD::VxType::PriVtx) {
40 ATH_MSG_INFO("Using primary vertex with position and time: "
41 << vx->position().x() << " " << vx->position().y() << " "
42 << vx->position().z() << " "
43 << (enableTime && vx->hasValidTime() ? vx->time() : 0));
44 return new CLHEP::HepLorentzVector(
45 vx->position().x(), vx->position().y(), vx->position().z(),
46 enableTime && vx->hasValidTime() ? vx->time() : 0);
47 }
48 }
49
50 ATH_MSG_ERROR("No primary vertex found in xAOD::VertexContainer with key: "
52 return nullptr;
53}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_INFO(x)
SG::ReadHandleKey< xAOD::VertexContainer > m_vertexContainerKey
@ PriVtx
Primary vertex.
Vertex_v1 Vertex
Define the latest version of the vertex class.

◆ initialize()

StatusCode Simulation::MatchingBkgVertexPositioner::initialize ( )
finaloverride

Definition at line 17 of file MatchingBkgVertexPositioner.cxx.

17 {
18 ATH_MSG_VERBOSE("Initializing ...");
19
20 ATH_CHECK(m_vertexContainerKey.initialize());
21
22 return StatusCode::SUCCESS;
23}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)

Member Data Documentation

◆ m_vertexContainerKey

SG::ReadHandleKey<xAOD::VertexContainer> Simulation::MatchingBkgVertexPositioner::m_vertexContainerKey
private
Initial value:
{
this, "PrimaryVertexContainerName", "PrimaryVertices"}

Definition at line 38 of file MatchingBkgVertexPositioner.h.

38 {
39 this, "PrimaryVertexContainerName", "PrimaryVertices"};

The documentation for this class was generated from the following files: