ATLAS Offline Software
Public Member Functions | Static Public Member Functions | Static Public Attributes | Private Attributes | List of all members
PileUpHashHelper Class Reference

#include <PileUpHashHelper.h>

Collaboration diagram for PileUpHashHelper:

Public Member Functions

 PileUpHashHelper ()
 
void addToHashSource (const std::string &string)
 Add a plain string to the stream. More...
 
void addToHashSource (const xAOD::EventInfo *eventInfo)
 Add subevents to the stream. More...
 
void clearHashSource ()
 Clear the stream. More...
 
std::string hashSource () const
 Get the current hash base. More...
 
void calculateHash (uuid_t &hash) const
 Calculate the hash. More...
 

Static Public Member Functions

static xAOD::EventInfo::PileUpMixtureID uuidToPileUpMixtureId (const uuid_t &hash)
 Convert uuid_t to xAOD::EventInfo::PileUpMixtureID. More...
 
static void pileUpMixtureIdToUuid (const xAOD::EventInfo::PileUpMixtureID &mixture, uuid_t &hash)
 xAOD::EventInfo::PileUpMixtureID to uuid_t More...
 

Static Public Attributes

static const uint16_t PILEUP_SIZE_BYTES = 8
 Size of individual low/high bits in bytes. More...
 

Private Attributes

std::stringstream m_stream
 

Detailed Description

Definition at line 20 of file PileUpHashHelper.h.

Constructor & Destructor Documentation

◆ PileUpHashHelper()

PileUpHashHelper::PileUpHashHelper ( )
inline

Definition at line 23 of file PileUpHashHelper.h.

23 {}

Member Function Documentation

◆ addToHashSource() [1/2]

void PileUpHashHelper::addToHashSource ( const std::string &  string)

Add a plain string to the stream.

Author
Tadej Novak

Definition at line 11 of file PileUpHashHelper.cxx.

12 {
13  m_stream << string;
14 }

◆ addToHashSource() [2/2]

void PileUpHashHelper::addToHashSource ( const xAOD::EventInfo eventInfo)

Add subevents to the stream.

Definition at line 16 of file PileUpHashHelper.cxx.

17 {
18  const std::vector<xAOD::EventInfo::SubEvent> &subEventsSource = eventInfo->subEvents();
19  std::vector<std::reference_wrapper<const xAOD::EventInfo::SubEvent>> subEvents(subEventsSource.begin(), subEventsSource.end());
20 
21  std::stable_sort(subEvents.begin(), subEvents.end(), [](const xAOD::EventInfo::SubEvent &a, const xAOD::EventInfo::SubEvent &b) {
22  return (a.ptr()->bcid() < b.ptr()->bcid()) ||
23  ((a.ptr()->bcid() == b.ptr()->bcid()) && (a.type() < b.type())) ||
24  ((a.ptr()->bcid() == b.ptr()->bcid()) && (a.type() == b.type()) && (a.ptr()->eventNumber() < b.ptr()->eventNumber()));
25  });
26 
27  // Generate subevents info string
28  bool first = true;
29  for (const xAOD::EventInfo::SubEvent &subevent : subEvents) {
30  if (subevent.type() == xAOD::EventInfo::Signal) {
31  continue;
32  }
33 
34  if (first) {
35  first = false;
36  } else {
37  m_stream << ";";
38  }
39 
40  m_stream << (static_cast<int32_t>(subevent.ptr()->bcid()) - static_cast<int32_t>(eventInfo->bcid())) << "_" << subevent.type() << "_" << subevent.ptr()->eventNumber();
41  }
42 }

◆ calculateHash()

void PileUpHashHelper::calculateHash ( uuid_t &  hash) const

Calculate the hash.

Definition at line 49 of file PileUpHashHelper.cxx.

50 {
51  std::string sourceStr = m_stream.str();
52 
53  MD5 md5Hash(sourceStr);
54  md5Hash.uuid_digest(hash);
55 }

◆ clearHashSource()

void PileUpHashHelper::clearHashSource ( )

Clear the stream.

Definition at line 44 of file PileUpHashHelper.cxx.

45 {
46  m_stream.str(std::string());
47 }

◆ hashSource()

std::string PileUpHashHelper::hashSource ( ) const
inline

Get the current hash base.

Definition at line 35 of file PileUpHashHelper.h.

35 { return m_stream.str(); }

◆ pileUpMixtureIdToUuid()

void PileUpHashHelper::pileUpMixtureIdToUuid ( const xAOD::EventInfo::PileUpMixtureID mixture,
uuid_t &  hash 
)
static

xAOD::EventInfo::PileUpMixtureID to uuid_t

Definition at line 69 of file PileUpHashHelper.cxx.

71 {
72  for (uint16_t i = 0; i < PILEUP_SIZE_BYTES; i++) {
73  hash[i] |= (mixture.lowBits >> (i * sizeof(unsigned char) * CHAR_BIT));
74  hash[i + PILEUP_SIZE_BYTES] |= (mixture.highBits >> (i * sizeof(unsigned char) * CHAR_BIT));
75  }
76 }

◆ uuidToPileUpMixtureId()

xAOD::EventInfo::PileUpMixtureID PileUpHashHelper::uuidToPileUpMixtureId ( const uuid_t &  hash)
static

Convert uuid_t to xAOD::EventInfo::PileUpMixtureID.

Definition at line 57 of file PileUpHashHelper.cxx.

58 {
60 
61  for (uint16_t i = 0; i < PILEUP_SIZE_BYTES; i++) {
62  mixture.lowBits |= (static_cast<unsigned long long>(hash[i]) << (i * sizeof(unsigned char) * CHAR_BIT));
63  mixture.highBits |= (static_cast<unsigned long long>(hash[i + PILEUP_SIZE_BYTES]) << (i * sizeof(unsigned char) * CHAR_BIT));
64  }
65 
66  return mixture;
67 }

Member Data Documentation

◆ m_stream

std::stringstream PileUpHashHelper::m_stream
private

Definition at line 51 of file PileUpHashHelper.h.

◆ PILEUP_SIZE_BYTES

const uint16_t PileUpHashHelper::PILEUP_SIZE_BYTES = 8
static

Size of individual low/high bits in bytes.

Definition at line 48 of file PileUpHashHelper.h.


The documentation for this class was generated from the following files:
xAOD::EventInfo_v1::PileUpMixtureID
Unique pile-up mixture identifier definition.
Definition: EventInfo_v1.h:243
xAOD::char
char
Definition: TrigDecision_v1.cxx:38
xAOD::EventInfo_v1::PileUpMixtureID::lowBits
uint64_t lowBits
Definition: EventInfo_v1.h:244
std::stable_sort
void stable_sort(std::reverse_iterator< DataModel_detail::iterator< DVL > > beg, std::reverse_iterator< DataModel_detail::iterator< DVL > > end, Compare comp)
Specialization of stable_sort for DataVector/List.
Definition: DVL_algorithms.h:711
xAOD::uint16_t
setWord1 uint16_t
Definition: eFexEMRoI_v1.cxx:93
lumiFormat.i
int i
Definition: lumiFormat.py:85
MD5
Definition: MD5.h:20
plotBeamSpotMon.b
b
Definition: plotBeamSpotMon.py:77
xAOD::EventInfo_v1::Signal
@ Signal
The signal event.
Definition: EventInfo_v1.h:266
a
TList * a
Definition: liststreamerinfos.cxx:10
CaloCondBlobAlgs_fillNoiseFromASCII.hash
dictionary hash
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:109
DeMoScan.first
bool first
Definition: DeMoScan.py:536
xAOD::EventInfo_v1::subEvents
const std::vector< SubEvent > & subEvents() const
Get the pileup events that were used in the simulation.
Definition: EventInfo_v1.cxx:596
xAOD::EventInfo_v1::bcid
uint32_t bcid() const
The bunch crossing ID of the event.
PileUpHashHelper::PILEUP_SIZE_BYTES
static const uint16_t PILEUP_SIZE_BYTES
Size of individual low/high bits in bytes.
Definition: PileUpHashHelper.h:48
PileUpHashHelper::m_stream
std::stringstream m_stream
Definition: PileUpHashHelper.h:51
xAOD::EventInfo_v1::SubEvent
Class describing the properties of one pileup sub-event.
Definition: EventInfo_v1.h:286
xAOD::EventInfo_v1::PileUpMixtureID::highBits
uint64_t highBits
Definition: EventInfo_v1.h:245