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

#include <MuonHoughTransformSteering.h>

Inheritance diagram for MuonHoughTransformSteering:
Collaboration diagram for MuonHoughTransformSteering:

Public Member Functions

 MuonHoughTransformSteering (std::unique_ptr< MuonHoughTransformer >)
 Class is build as Strategy, Context pattern. More...
 
 ~MuonHoughTransformSteering ()
 destructor More...
 
MuonHoughPatternCollection constructHoughPatterns (const MuonHoughHitContainer &event, double residu_mm, double residu_grad, int max_patterns) const
 construct hough patterns More...
 
std::unique_ptr< MuonHoughPatternconstructHoughPattern (const MuonHoughHitContainer &event, double residu_mm, double residu_grad, int maximum_number) const
 construct hough pattern on a certain maxima number of histogram More...
 
std::unique_ptr< MuonHoughPatternconstructHoughPattern (const MuonHoughHitContainer &event, std::pair< double, double > coordsmaximum, double residu_mm, double residu_grad, int sector) const
 construct hough pattern at a certain coordinate (maximum) in certain sector More...
 
std::unique_ptr< MuonHoughPatternconstructHoughPattern (const MuonHoughHitContainer &event, int binnumber, double residu_mm, double residu_grad, int sector) const
 construct hough pattern at a certain binnumber (maximum) in certain sector More...
 
void fill (const MuonHoughHitContainer &event)
 fill histograms More...
 
void resetHisto ()
 reset histograms More...
 
const MuonHoughHisto2DContainerhistos () const
 access to histograms More...
 
const MuonHoughTransformertransformer () const
 
bool msgLvl (const MSG::Level lvl) const
 Test the output level. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

Private Member Functions

void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

std::unique_ptr< MuonHoughTransformerm_houghtransformer {}
 the actual houghtransform More...
 
std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

Definition at line 15 of file MuonHoughTransformSteering.h.

Constructor & Destructor Documentation

◆ MuonHoughTransformSteering()

MuonHoughTransformSteering::MuonHoughTransformSteering ( std::unique_ptr< MuonHoughTransformer houghtransformer)

Class is build as Strategy, Context pattern.

constructor

Definition at line 12 of file MuonHoughTransformSteering.cxx.

12  :
13  AthMessaging{"MuonHoughTransformSteering"},
14  m_houghtransformer{std::move(houghtransformer)} {}

◆ ~MuonHoughTransformSteering()

MuonHoughTransformSteering::~MuonHoughTransformSteering ( )
default

destructor

Member Function Documentation

◆ constructHoughPattern() [1/3]

std::unique_ptr< MuonHoughPattern > MuonHoughTransformSteering::constructHoughPattern ( const MuonHoughHitContainer event,
double  residu_mm,
double  residu_grad,
int  maximum_number 
) const

construct hough pattern on a certain maxima number of histogram

Definition at line 40 of file MuonHoughTransformSteering.cxx.

41  {
42  ATH_MSG_DEBUG("MuonHoughTransformSteering::constructHoughPattern (start) ");
43 
44  std::unique_ptr<MuonHoughPattern> houghpattern = m_houghtransformer->associateHitsToMaximum(event, residu_mm, residu_grad,
45  maximum_number);
46 
47  ATH_MSG_DEBUG("MuonHoughTransformSteering::constructHoughPattern (end) ");
48 
49  return houghpattern;
50 }

◆ constructHoughPattern() [2/3]

std::unique_ptr< MuonHoughPattern > MuonHoughTransformSteering::constructHoughPattern ( const MuonHoughHitContainer event,
int  binnumber,
double  residu_mm,
double  residu_grad,
int  sector 
) const

construct hough pattern at a certain binnumber (maximum) in certain sector

Definition at line 57 of file MuonHoughTransformSteering.cxx.

58  {
59  return m_houghtransformer->associateHitsToBinnumber(event, binnumber, residu_mm, residu_grad, sector);
60 }

◆ constructHoughPattern() [3/3]

std::unique_ptr< MuonHoughPattern > MuonHoughTransformSteering::constructHoughPattern ( const MuonHoughHitContainer event,
std::pair< double, double >  coordsmaximum,
double  residu_mm,
double  residu_grad,
int  sector 
) const

construct hough pattern at a certain coordinate (maximum) in certain sector

Definition at line 52 of file MuonHoughTransformSteering.cxx.

53  {
54  return m_houghtransformer->associateHitsToCoords(event, coords, residu_mm, residu_grad, sector);
55 }

◆ constructHoughPatterns()

MuonHoughPatternCollection MuonHoughTransformSteering::constructHoughPatterns ( const MuonHoughHitContainer event,
double  residu_mm,
double  residu_grad,
int  max_patterns 
) const

construct hough patterns

Parameters
[in]eventHitcontainer
[in]residu_mmmaximum residu for hit to be associated to pattern
[in]residu_gradmaximum residu for hit to be associated to pattern
[in]max_patternsmaximum number of patterns to be built
[in]which_segmentupper (1) or lower (0) segment, this option is off by default
[out]HoughPatternCollection

Definition at line 18 of file MuonHoughTransformSteering.cxx.

19  {
20  MuonHoughPatternCollection houghpatterns;
21  houghpatterns.reserve(max_patterns);
22  std::vector<std::pair<int, int> > maxima = m_houghtransformer->getMaxima(max_patterns); // sector,binnumber , sorted vector
23 
24  for (const auto& [sector, binnumber] : maxima) {
25  if (binnumber == -1) {
26  ATH_MSG_VERBOSE("binnumber == -1 (no max found), max patterns = " << max_patterns );
27  break;
28  }
29  std::unique_ptr<MuonHoughPattern> houghpattern = constructHoughPattern(event, binnumber, residu_mm,
30  residu_grad, sector);
31  houghpatterns.emplace_back(std::move(houghpattern));
32  }
33 
34  // subtract all hits that were just added to a pattern
35  // m_houghtransformer->fill(event,true);
36 
37  return houghpatterns;
38 }

◆ fill()

void MuonHoughTransformSteering::fill ( const MuonHoughHitContainer event)

fill histograms

Definition at line 62 of file MuonHoughTransformSteering.cxx.

62 { m_houghtransformer->fill(event); }

◆ histos()

const MuonHoughHisto2DContainer& MuonHoughTransformSteering::histos ( ) const
inline

access to histograms

Definition at line 51 of file MuonHoughTransformSteering.h.

51 { return m_houghtransformer->histos(); }

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40 {
42  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 164 of file AthMessaging.h.

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level  lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 179 of file AthMessaging.h.

180 { return msg() << lvl; }

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level  lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152 {
153  if (!m_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

◆ resetHisto()

void MuonHoughTransformSteering::resetHisto ( )

reset histograms

Definition at line 64 of file MuonHoughTransformSteering.cxx.

64 { m_houghtransformer->resetHisto(); }

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level  lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29 {
30  m_lvl = lvl;
31 }

◆ transformer()

const MuonHoughTransformer& MuonHoughTransformSteering::transformer ( ) const
inline

Definition at line 53 of file MuonHoughTransformSteering.h.

53 { return *m_houghtransformer; }

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_houghtransformer

std::unique_ptr<MuonHoughTransformer> MuonHoughTransformSteering::m_houghtransformer {}
private

the actual houghtransform

Definition at line 57 of file MuonHoughTransformSteering.h.

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.


The documentation for this class was generated from the following files:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
event
POOL::TEvent event(POOL::TEvent::kClassAccess)
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
AthMessaging
Class to provide easy MsgStream access and capabilities.
Definition: AthMessaging.h:55
MuonHoughTransformSteering::m_houghtransformer
std::unique_ptr< MuonHoughTransformer > m_houghtransformer
the actual houghtransform
Definition: MuonHoughTransformSteering.h:57
MuonHoughTransformSteering::constructHoughPattern
std::unique_ptr< MuonHoughPattern > constructHoughPattern(const MuonHoughHitContainer &event, double residu_mm, double residu_grad, int maximum_number) const
construct hough pattern on a certain maxima number of histogram
Definition: MuonHoughTransformSteering.cxx:40
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
MuonHoughPatternCollection
std::vector< std::unique_ptr< MuonHoughPattern > > MuonHoughPatternCollection
This typedef represents a collection and container of MuonHoughPattern objects.
Definition: MuonHoughPatternCollection.h:13