CMS 3D CMS Logo

BeamSpotProducer.cc
Go to the documentation of this file.
1 
4 
10 
13 
14 //
15 // constructors and destructor
16 //
18  edm::LogInfo("RecoVertex/BeamSpotProducer") << "Initializing Beam Spot producer "
19  << "\n";
20 
21  //fVerbose=conf.getUntrackedParameter<bool>("verbose", false);
22  m_beamToken = esConsumes<BeamSpotObjects, BeamSpotObjectsRcd>();
23 
24  produces<reco::BeamSpot>();
25 }
26 
28 
29 //
30 // member functions
31 //
32 
33 // ------------ method called to produce the data ------------
35  using namespace edm;
36 
37  auto result = std::make_unique<reco::BeamSpot>();
38 
39  reco::BeamSpot aSpot;
40 
41  //typedef math::XYZPoint Point;
42  //enum { dimension = 7 };
43  //typedef math::Error<dimension>::type CovarianceMatrix;
44 
45  //try {
46  edm::LogInfo("RecoVertex/BeamSpotProducer") << "Reconstructing event number: " << iEvent.id() << "\n";
47 
49  const BeamSpotObjects* spotDB = beamhandle.product();
50 
51  // translate from BeamSpotObjects to reco::BeamSpot
52  reco::BeamSpot::Point apoint(spotDB->GetX(), spotDB->GetY(), spotDB->GetZ());
53 
55  for (int i = 0; i < 7; ++i) {
56  for (int j = 0; j < 7; ++j) {
57  matrix(i, j) = spotDB->GetCovariance(i, j);
58  }
59  }
60 
61  // this assume beam width same in x and y
62  aSpot = reco::BeamSpot(
63  apoint, spotDB->GetSigmaZ(), spotDB->Getdxdz(), spotDB->Getdydz(), spotDB->GetBeamWidthX(), matrix);
64  aSpot.setBeamWidthY(spotDB->GetBeamWidthY());
65  aSpot.setEmittanceX(spotDB->GetEmittanceX());
66  aSpot.setEmittanceY(spotDB->GetEmittanceY());
67  aSpot.setbetaStar(spotDB->GetBetaStar());
68 
69  //}
70  //
71  //catch (std::exception & err) {
72  // edm::LogInfo("RecoVertex/BeamSpotProducer")
73  // << "Exception during event number: " << iEvent.id()
74  // << "\n" << err.what() << "\n";
75  //}
76 
77  *result = aSpot;
78 
79  iEvent.put(std::move(result));
80 }
81 
82 //define this as a plug-in
edm::ESHandle::product
T const * product() const
Definition: ESHandle.h:86
BeamSpotObjects::GetBeamWidthY
double GetBeamWidthY() const
get average transverse beam width
Definition: BeamSpotObjects.h:77
BeamSpotObjects::Getdxdz
double Getdxdz() const
get dxdz slope, crossing angle in XZ
Definition: BeamSpotObjects.h:79
mps_fire.i
i
Definition: mps_fire.py:428
reco::BeamSpot::setBeamWidthY
void setBeamWidthY(double v)
Definition: BeamSpot.h:105
MessageLogger.h
makeMuonMisalignmentScenario.matrix
list matrix
Definition: makeMuonMisalignmentScenario.py:141
reco::BeamSpot::setEmittanceY
void setEmittanceY(double v)
Definition: BeamSpot.h:137
ESHandle.h
align::BeamSpot
Definition: StructureType.h:95
BeamSpotProducer::m_beamToken
edm::ESGetToken< BeamSpotObjects, BeamSpotObjectsRcd > m_beamToken
Definition: BeamSpotProducer.h:38
BeamSpotProducer::BeamSpotProducer
BeamSpotProducer(const edm::ParameterSet &iConf)
constructor
Definition: BeamSpotProducer.cc:17
BeamSpotObjects::GetSigmaZ
double GetSigmaZ() const
get sigma Z, RMS bunch length
Definition: BeamSpotObjects.h:73
edm
HLT enums.
Definition: AlignableModifier.h:19
BeamSpotObjects::GetZ
double GetZ() const
get Z beam position
Definition: BeamSpotObjects.h:71
BeamSpotProducer
Definition: BeamSpotProducer.h:25
BeamSpotProducer::produce
void produce(edm::Event &iEvent, const edm::EventSetup &iSetup) override
produce a beam spot class
Definition: BeamSpotProducer.cc:34
edm::LogInfo
Log< level::Info, false > LogInfo
Definition: MessageLogger.h:125
MakerMacros.h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
BeamSpot.h
reco::BeamSpot
Definition: BeamSpot.h:21
BeamSpotProducer.h
edm::ESHandle
Definition: DTSurvey.h:22
BeamSpotObjects::GetCovariance
double GetCovariance(int i, int j) const
get i,j element of the full covariance matrix 7x7
Definition: BeamSpotObjects.h:83
reco::BeamSpot::setEmittanceX
void setEmittanceX(double v)
Definition: BeamSpot.h:136
BeamSpotProducer::~BeamSpotProducer
~BeamSpotProducer() override
destructor
Definition: BeamSpotProducer.cc:27
BeamSpotObjects::GetBetaStar
double GetBetaStar() const
get beta star
Definition: BeamSpotObjects.h:107
Error.h
BeamSpotObjects::GetEmittanceX
double GetEmittanceX() const
get emittance
Definition: BeamSpotObjects.h:103
edm::ParameterSet
Definition: ParameterSet.h:47
BeamSpotObjects::GetY
double GetY() const
get Y beam position
Definition: BeamSpotObjects.h:69
reco::BeamSpot::setbetaStar
void setbetaStar(double v)
Definition: BeamSpot.h:138
iEvent
int iEvent
Definition: GenABIO.cc:224
edm::EventSetup::getHandle
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
Definition: EventSetup.h:155
BeamSpotObjects
Definition: BeamSpotObjects.h:20
edm::EventSetup
Definition: EventSetup.h:58
reco::BeamSpot::CovarianceMatrix
math::Error< dimension >::type CovarianceMatrix
Definition: BeamSpot.h:29
BeamSpotObjects::GetBeamWidthX
double GetBeamWidthX() const
get average transverse beam width
Definition: BeamSpotObjects.h:75
eostools.move
def move(src, dest)
Definition: eostools.py:511
BeamSpotObjects::GetEmittanceY
double GetEmittanceY() const
get emittance
Definition: BeamSpotObjects.h:105
BeamSpotObjects::Getdydz
double Getdydz() const
get dydz slope, crossing angle in YZ
Definition: BeamSpotObjects.h:81
Point3D.h
EventSetup.h
mps_fire.result
result
Definition: mps_fire.py:311
reco::BeamSpot::Point
math::XYZPoint Point
point in the space
Definition: BeamSpot.h:27
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
edm::Event
Definition: Event.h:73
IOVSyncValue.h
BeamSpotObjects::GetX
double GetX() const
get X beam position
Definition: BeamSpotObjects.h:67