ATLAS Offline Software
Loading...
Searching...
No Matches
TilePulseShape Class Reference

#include <TilePulseShape.h>

Inheritance diagram for TilePulseShape:
Collaboration diagram for TilePulseShape:

Public Member Functions

 TilePulseShape (IMessageSvc *msgSvc, const std::string &name)
 TilePulseShape (IMessageSvc *msgSvc, const std::string &name, const TString &fileName)
 TilePulseShape (IMessageSvc *msgSvc, const std::string &name, const std::vector< double > &shapevec)
virtual ~TilePulseShape ()
void loadPulseShape (const TString &fileName)
void setPulseShape (const std::vector< double > &shapevec)
TGraph * getGraph (double t0=0., double ped=0., double amp=1.)
double eval (double x, bool useSpline=true, bool useUndershoot=false)
void resetDeformation ()
int scalePulse (double leftSF=1., double rightSF=1.)
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

TGraph * m_pulseShape {nullptr}
TGraph * m_deformedShape {nullptr}
TSpline * m_deformedSpline {nullptr}
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 17 of file TilePulseShape.h.

Constructor & Destructor Documentation

◆ TilePulseShape() [1/3]

TilePulseShape::TilePulseShape ( IMessageSvc * msgSvc,
const std::string & name )

Definition at line 19 of file TilePulseShape.cxx.

20 : AthMessaging(msgSvc, name)
21{
22}
AthMessaging()
Default constructor:

◆ TilePulseShape() [2/3]

TilePulseShape::TilePulseShape ( IMessageSvc * msgSvc,
const std::string & name,
const TString & fileName )

Definition at line 25 of file TilePulseShape.cxx.

26 : AthMessaging(msgSvc, name)
27{
28 loadPulseShape(fileName);
29}
void loadPulseShape(const TString &fileName)

◆ TilePulseShape() [3/3]

TilePulseShape::TilePulseShape ( IMessageSvc * msgSvc,
const std::string & name,
const std::vector< double > & shapevec )

Definition at line 32 of file TilePulseShape.cxx.

33 : AthMessaging(msgSvc, name)
34{
35 setPulseShape(shapevec);
36}
void setPulseShape(const std::vector< double > &shapevec)

◆ ~TilePulseShape()

TilePulseShape::~TilePulseShape ( )
virtual

Definition at line 39 of file TilePulseShape.cxx.

40{
42 if(m_pulseShape) delete m_pulseShape;
44}
TGraph * m_pulseShape
TSpline * m_deformedSpline

Member Function Documentation

◆ eval()

double TilePulseShape::eval ( double x,
bool useSpline = true,
bool useUndershoot = false )

Definition at line 75 of file TilePulseShape.cxx.

76{
77
78 //=== make sure pulseshape is available
79 if(!m_deformedShape){
80 ATH_MSG_ERROR("No pulseshape loaded!");
81 return 0.;
82 }
83
84 //=== interpolate pulseShape value, TMath::BinarySearch returns
85 //=== index of value smaller or equal to the search value.
86 //=== -> Need to catch boundary values
87 double y(0.);
88 int n(m_deformedShape->GetN());
89 int idx = TMath::BinarySearch(n,m_deformedShape->GetX(),x);
90 if(idx<0){
91 //=== left out of bounds, return leftmost value
92// y = (_deformedShape->GetY())[0];
93 y = 0;
94 ATH_MSG_DEBUG("Left out of bounds. Replacing y = " << (m_deformedShape->GetY())[0] << " with y = 0. (idx = " << idx << ", x = " << x << ")");
95 }
96 else if(idx>=n-1){
97 //=== right out of bounds, return rightmost value
98// y = (_deformedShape->GetY())[n-1];
99 if(useUndershoot){
100 y = 0.00196 * (1 - exp(- x / 20664.59) ) - 0.00217;
101 }
102 else{
103 y = 0;
104 ATH_MSG_DEBUG("Right out of bounds. Replacing y = " << (m_deformedShape->GetY())[0] << " with y = 0. (idx = " << idx << ", x = " << x << ")");
105 }
106 }
107 else{
108 //=== linear interpolation
109 double xLo = (m_deformedShape->GetX())[idx ];
110 double xHi = (m_deformedShape->GetX())[idx+1];
111 double yLo = (m_deformedShape->GetY())[idx ];
112 double yHi = (m_deformedShape->GetY())[idx+1];
113 double yLinear = yLo + (yHi-yLo)/(xHi-xLo) * (x-xLo);
114 //=== spline interpolation
115 double ySpline = m_deformedSpline->Eval(x);
116
117 if(useSpline) y = ySpline;
118 else y = yLinear;
119 }
120
121 return y;
122}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_DEBUG(x)
#define y
#define x
TGraph * m_deformedShape

◆ getGraph()

TGraph * TilePulseShape::getGraph ( double t0 = 0.,
double ped = 0.,
double amp = 1. )

Definition at line 165 of file TilePulseShape.cxx.

166{
167 TGraph* gr = (TGraph*) m_deformedShape->Clone();
168 for(int i=0; i<gr->GetN(); i++){
169 double x,y;
170 gr->GetPoint(i,x,y);
171 y*=amp;
172 y+=ped;
173 x+=t0;
174 gr->SetPoint(i,x,y);
175 }
176 return gr;
177}
#define gr
static Double_t t0

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

◆ loadPulseShape()

void TilePulseShape::loadPulseShape ( const TString & fileName)

Definition at line 47 of file TilePulseShape.cxx.

48{
50 if(m_pulseShape) delete m_pulseShape;
51 m_pulseShape = new TGraph(fileName.Data());
52 if(m_pulseShape->IsZombie()) {
53 throw GaudiException(std::string("could not load pulseshape from file: ") + fileName.Data(),
54 "TilePulseShape", StatusCode::FAILURE);
55 } else ATH_MSG_INFO("Loaded pulseshape from file: " << fileName);
57}
#define ATH_MSG_INFO(x)

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

◆ resetDeformation()

void TilePulseShape::resetDeformation ( )

Definition at line 126 of file TilePulseShape.cxx.

127{
128 if(m_deformedShape==m_pulseShape) return;
129
130 delete m_deformedShape;
131 delete m_deformedSpline;
133 m_deformedSpline = new TSpline3("deformedSpline",m_deformedShape);
134}

◆ scalePulse()

int TilePulseShape::scalePulse ( double leftSF = 1.,
double rightSF = 1. )

Definition at line 138 of file TilePulseShape.cxx.

139{
140
142 if(!m_pulseShape) {
143 ATH_MSG_WARNING("Attempted pulse shape scaling before loading pulse shape");
144 return 1;
145 } else {
146 m_deformedShape = (TGraph*) m_pulseShape->Clone();
147
148 for(int i=0; i<m_deformedShape->GetN(); ++i){
149 double x,y;
150 m_deformedShape->GetPoint(i,x,y);
151 if(x<0.) x*= leftSF;
152 else if(x>0.) x*=rightSF;
153 m_deformedShape->SetPoint(i,x,y);
154 }
155
156 delete m_deformedSpline;
157 m_deformedSpline = new TSpline3("deformedSpline",m_deformedShape);
158 return 0;
159 }
160
161}
#define ATH_MSG_WARNING(x)

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

◆ setPulseShape()

void TilePulseShape::setPulseShape ( const std::vector< double > & shapevec)

Definition at line 60 of file TilePulseShape.cxx.

61{
63 if(m_pulseShape) delete m_pulseShape;
64 m_pulseShape = new TGraph(shapevec.size());
65 for(std::vector<double>::size_type i = 0; i != shapevec.size(); i++) {
66 m_pulseShape->SetPoint(i, -75.5+i*0.5, shapevec.at(i));
67 }
69}

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_deformedShape

TGraph* TilePulseShape::m_deformedShape {nullptr}
private

Definition at line 36 of file TilePulseShape.h.

36{nullptr};

◆ m_deformedSpline

TSpline* TilePulseShape::m_deformedSpline {nullptr}
private

Definition at line 37 of file TilePulseShape.h.

37{nullptr};

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

◆ m_pulseShape

TGraph* TilePulseShape::m_pulseShape {nullptr}
private

Definition at line 35 of file TilePulseShape.h.

35{nullptr};

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