CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
dtCalibration::DTVDriftMeanTimer Class Reference

#include <DTVDriftMeanTimer.h>

Inheritance diagram for dtCalibration::DTVDriftMeanTimer:
dtCalibration::DTVDriftBaseAlgo

Public Member Functions

virtual DTVDriftData compute (const DTSuperLayerId &)
 
 DTVDriftMeanTimer (edm::ParameterSet const &)
 
virtual void setES (const edm::EventSetup &setup)
 
virtual ~DTVDriftMeanTimer ()
 
- Public Member Functions inherited from dtCalibration::DTVDriftBaseAlgo
 DTVDriftBaseAlgo ()
 
virtual ~DTVDriftBaseAlgo ()
 

Private Attributes

DTMeanTimerFitterfitter_
 
TFile * rootFile_
 

Detailed Description

Definition at line 20 of file DTVDriftMeanTimer.h.

Constructor & Destructor Documentation

DTVDriftMeanTimer::DTVDriftMeanTimer ( edm::ParameterSet const &  pset)

Definition at line 34 of file DTVDriftMeanTimer.cc.

References debug, edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), and dtT0Analyzer_cfg::rootFileName.

34  {
35  string rootFileName = pset.getParameter<string>("rootFileName");
36  rootFile_ = new TFile(rootFileName.c_str(), "READ");
37  fitter_ = new DTMeanTimerFitter(rootFile_);
38  bool debug = pset.getUntrackedParameter<bool>("debug", false);
39  if(debug) fitter_->setVerbosity(1);
40 }
#define debug
Definition: MEtoEDMFormat.h:34
DTVDriftMeanTimer::~DTVDriftMeanTimer ( )
virtual

Definition at line 42 of file DTVDriftMeanTimer.cc.

42  {
43  rootFile_->Close();
44  delete fitter_;
45 }

Member Function Documentation

DTVDriftData DTVDriftMeanTimer::compute ( const DTSuperLayerId slId)
virtual

Implements dtCalibration::DTVDriftBaseAlgo.

Definition at line 49 of file DTVDriftMeanTimer.cc.

References N, DTChamberId::sector(), DTChamberId::station(), DTSuperLayerId::superLayer(), and DTChamberId::wheel().

49  {
50 
51  // Evaluate v_drift and sigma from the TMax histograms
52  DTWireId wireId(slId, 0, 0);
53  TString N = ( ( ( ( (TString)"TMax" + (long)wireId.wheel() )
54  + (long)wireId.station() )
55  + (long)wireId.sector() ) + (long)wireId.superLayer() );
56  vector<float> vDriftAndReso = fitter_->evaluateVDriftAndReso(N);
57 
58  // Don't write the constants for the SL if the vdrift was not computed
59  if(vDriftAndReso.front() == -1)
60  throw cms::Exception("DTCalibration") << "Could not compute valid vDrift value for SL " << slId << endl;
61 
62  return DTVDriftData(vDriftAndReso[0],vDriftAndReso[1]);
63 }
#define N
Definition: blowfish.cc:9
std::vector< float > evaluateVDriftAndReso(const TString &N)
Fit the TMax histos and evaluate VDrift and resolution.
void DTVDriftMeanTimer::setES ( const edm::EventSetup setup)
virtual

Implements dtCalibration::DTVDriftBaseAlgo.

Definition at line 47 of file DTVDriftMeanTimer.cc.

47 {}

Member Data Documentation

DTMeanTimerFitter* dtCalibration::DTVDriftMeanTimer::fitter_
private

Definition at line 29 of file DTVDriftMeanTimer.h.

TFile* dtCalibration::DTVDriftMeanTimer::rootFile_
private

Definition at line 28 of file DTVDriftMeanTimer.h.