ATLAS Offline Software
Loading...
Searching...
No Matches
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.
 ~MuonHoughTransformSteering ()
 destructor
MuonHoughPatternCollection constructHoughPatterns (const MuonHoughHitContainer &event, double residu_mm, double residu_grad, int max_patterns) const
 construct hough patterns
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
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
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
void fill (const MuonHoughHitContainer &event)
 fill histograms
void resetHisto ()
 reset histograms
const MuonHoughHisto2DContainerhistos () const
 access to histograms
const MuonHoughTransformertransformer () const
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.

Private Member Functions

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

Private Attributes

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

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)} {}
AthMessaging(IMessageSvc *msgSvc, const std::string &name)
Constructor.
std::unique_ptr< MuonHoughTransformer > m_houghtransformer
the actual houghtransform

◆ ~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}
#define ATH_MSG_DEBUG(x)

◆ 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}
#define ATH_MSG_VERBOSE(x)
std::vector< std::unique_ptr< MuonHoughPattern > > MuonHoughPatternCollection
This typedef represents a collection and container of MuonHoughPattern objects.
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

◆ 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 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ 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 163 of file AthMessaging.h.

164{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.

◆ 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 178 of file AthMessaging.h.

179{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ 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_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ 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.

57{};

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_lvl

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

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ 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: