From b9a4b4c799b8f85e81022f2d16ac5ed2b94b29ee Mon Sep 17 00:00:00 2001 From: francescobrivio Date: Tue, 31 Oct 2023 18:51:07 +0100 Subject: [PATCH] Adapt SimBeamSpotObjects to handle both Betafunc and Gauss EvtVtxGenerators --- .../BeamSpotPayloadInspectorHelper.h | 54 +++++++++++++---- .../test/testBeamSpotPayloadInspector.cpp | 6 +- .../interface/SimBeamSpotObjects.h | 51 ++++++++++++---- .../BeamSpotObjects/src/SimBeamSpotObjects.cc | 5 ++ .../BeamSpot/plugins/BeamProfile2DBReader.cc | 18 +++++- .../BeamSpot/plugins/BeamProfile2DBWriter.cc | 22 +++++-- .../test/BeamProfile2DBWriterAll_cfg.py | 12 ++-- .../BeamSpot/test/extractAndUploadAll.py | 2 +- .../interface/BetafuncEvtVtxGenerator.h | 2 +- .../interface/GaussEvtVtxGenerator.h | 14 ++++- .../src/BetafuncEvtVtxGenerator.cc | 4 +- .../src/GaussEvtVtxGenerator.cc | 59 +++++++++++++------ 12 files changed, 184 insertions(+), 65 deletions(-) diff --git a/CondCore/BeamSpotPlugins/interface/BeamSpotPayloadInspectorHelper.h b/CondCore/BeamSpotPlugins/interface/BeamSpotPayloadInspectorHelper.h index 2e03a2cbd1d5f..366129bc65c9b 100644 --- a/CondCore/BeamSpotPlugins/interface/BeamSpotPayloadInspectorHelper.h +++ b/CondCore/BeamSpotPlugins/interface/BeamSpotPayloadInspectorHelper.h @@ -715,17 +715,22 @@ namespace beamSpotPI { namespace simBeamSpotPI { enum parameters { - X = 0, // 0 - Positions - Y = 1, // 1 - Z = 2, // 2 - sigmaZ = 3, // 3 - Widths - betaStar = 4, // 4 - emittance = 5, // 5 - expTransWidth = 6, // 6 - from LPC-like calculation - phi = 7, // 7 - Additional parameters - alpha = 8, // 8 - timeOffset = 9, // 9 - END_OF_TYPES = 10, + X = 0, // 0 - Positions + Y = 1, // 1 + Z = 2, // 2 + meanX = 3, // 3 + meanY = 4, // 4 + meanZ = 5, // 5 + sigmaX = 6, // 6 - Widths + sigmaY = 7, // 7 + sigmaZ = 8, // 8 + betaStar = 9, // 9 + emittance = 10, // 10 + expTransWidth = 11, // 11 - from LPC-like calculation + phi = 12, // 12 - Additional parameters + alpha = 13, // 13 + timeOffset = 14, // 14 + END_OF_TYPES = 15, }; /************************************************/ @@ -737,6 +742,16 @@ namespace simBeamSpotPI { return (addUnits ? "Y [cm]" : "Y"); case Z: return (addUnits ? "Z [cm]" : "Z"); + case meanX: + return (addUnits ? "MeanX [cm]" : "meanX"); + case meanY: + return (addUnits ? "MeanY [cm]" : "meanY"); + case meanZ: + return (addUnits ? "MeanZ [cm]" : "meanZ"); + case sigmaX: + return (addUnits ? "#sigma_{X} [cm]" : "sigmaX"); + case sigmaY: + return (addUnits ? "#sigma_{Y} [cm]" : "sigmaY"); case sigmaZ: return (addUnits ? "#sigma_{Z} [cm]" : "sigmaZ"); case betaStar: @@ -769,8 +784,11 @@ namespace simBeamSpotPI { SimBSParamsHelper(const std::shared_ptr& bs) { // fill in the values m_values[parameters::X] = bs->x(), m_values[parameters::Y] = bs->y(), m_values[parameters::Z] = bs->z(); - m_values[parameters::sigmaZ] = bs->sigmaZ(), m_values[parameters::betaStar] = bs->betaStar(), - m_values[parameters::emittance] = bs->emittance(); + m_values[parameters::meanX] = bs->meanX(), m_values[parameters::meanY] = bs->meanY(), + m_values[parameters::meanZ] = bs->meanZ(); + m_values[parameters::sigmaX] = bs->sigmaX(), m_values[parameters::sigmaY] = bs->sigmaY(), + m_values[parameters::sigmaZ] = bs->sigmaZ(); + m_values[parameters::betaStar] = bs->betaStar(), m_values[parameters::emittance] = bs->emittance(); m_values[parameters::expTransWidth] = (1 / std::sqrt(2)) * std::sqrt(bs->emittance() * bs->betaStar()) * 10000.f; m_values[parameters::phi] = bs->phi(), m_values[parameters::alpha] = bs->alpha(), m_values[parameters::timeOffset] = bs->timeOffset(); @@ -842,6 +860,16 @@ namespace simBeamSpotPI { return m_payload->y(); case Z: return m_payload->z(); + case meanX: + return m_payload->meanX(); + case meanY: + return m_payload->meanY(); + case meanZ: + return m_payload->meanZ(); + case sigmaX: + return m_payload->sigmaX(); + case sigmaY: + return m_payload->sigmaY(); case sigmaZ: return m_payload->sigmaZ(); case betaStar: diff --git a/CondCore/BeamSpotPlugins/test/testBeamSpotPayloadInspector.cpp b/CondCore/BeamSpotPlugins/test/testBeamSpotPayloadInspector.cpp index 79e11c9e3298a..e6aa7eb498d49 100644 --- a/CondCore/BeamSpotPlugins/test/testBeamSpotPayloadInspector.cpp +++ b/CondCore/BeamSpotPlugins/test/testBeamSpotPayloadInspector.cpp @@ -84,7 +84,7 @@ int main(int argc, char** argv) { // SimBeamSpot std::string prepConnectionString("frontier://FrontierPrep/CMS_CONDITIONS"); - tag = "SimBeamSpotObjects_Realistic25ns13p6TeVEOY2022Collision_v0_mc"; + tag = "SimBeamSpot_Realistic25ns13p6TeVEOY2022CollisionVtxSmearingParameters_v1_mc"; start = static_cast(1); end = static_cast(1); @@ -98,8 +98,8 @@ int main(int argc, char** argv) { histoSimParametersDiff.process(prepConnectionString, PI::mk_input(tag, start, end)); edm::LogPrint("testBeamSpotPayloadInspector") << histoSimParametersDiff.data() << std::endl; - tag1 = "SimBeamSpotObjects_Realistic25ns13p6TeVEOY2022Collision_v0_mc"; - tag2 = "SimBeamSpotObjects_Realistic25ns13p6TeVEarly2023Collision_v0_mc"; + tag1 = "SimBeamSpot_Realistic25ns13p6TeVEOY2022CollisionVtxSmearingParameters_v1_mc"; + tag2 = "SimBeamSpot_Realistic25ns13p6TeVEarly2023CollisionVtxSmearingParameters_v1_mc"; start = static_cast(1); SimBeamSpotParametersDiffTwoTags histoSimParametersDiffTwoTags; diff --git a/CondFormats/BeamSpotObjects/interface/SimBeamSpotObjects.h b/CondFormats/BeamSpotObjects/interface/SimBeamSpotObjects.h index b4b1ce5c2f34a..bebe96f5a8c59 100644 --- a/CondFormats/BeamSpotObjects/interface/SimBeamSpotObjects.h +++ b/CondFormats/BeamSpotObjects/interface/SimBeamSpotObjects.h @@ -3,7 +3,21 @@ /** \class SimBeamSpotObjects * - * provide the vertex smearing parameters from DB + * Provide the vertex smearing parameters from DB + * + * This Object contains the parameters needed by the vtx smearing functions used up to Run 3: + * - BetafuncEvtVtxGenerator (realistic Run1/Run2/Run3 conditions) + * Parameters used: + * - fX0, fY0, fZ0 + * - fSigmaZ + * - fbetastar, femittance + * - fPhi, fAlpha + * - fTimeOffset + * - GaussEvtVtxGenerator (design Run1/Run2/Run3 conditions) + * Parameters used: + * - fMeanX, fMeanY, fMeanZ + * - fSigmaX, fSigmaY, fSigmaZ + * - fTimeOffset * */ @@ -18,6 +32,11 @@ class SimBeamSpotObjects { fX0 = 0.0; fY0 = 0.0; fZ0 = 0.0; + fMeanX = 0.0; + fMeanY = 0.0; + fMeanZ = 0.0; + fSigmaX = 0.0; + fSigmaY = 0.0; fSigmaZ = 0.0; fbetastar = 0.0; femittance = 0.0; @@ -32,7 +51,13 @@ class SimBeamSpotObjects { void setX(double val) { fX0 = val; } void setY(double val) { fY0 = val; } void setZ(double val) { fZ0 = val; } - /// set sigmaZ + /// set meanX, meanY, meanZ + void setMeanX(double val) { fMeanX = val; } + void setMeanY(double val) { fMeanY = val; } + void setMeanZ(double val) { fMeanZ = val; } + /// set sigmaX, sigmaY, sigmaZ + void setSigmaX(double val) { fSigmaX = val; } + void setSigmaY(double val) { fSigmaY = val; } void setSigmaZ(double val) { fSigmaZ = val; } /// set BetaStar and Emittance void setBetaStar(double val) { fbetastar = val; } @@ -42,23 +67,24 @@ class SimBeamSpotObjects { void setAlpha(double val) { fAlpha = val; } void setTimeOffset(double val) { fTimeOffset = val; } - /// get X position + /// get X, Y, Z position double x() const { return fX0; } - /// get Y position double y() const { return fY0; } - /// get Z position double z() const { return fZ0; } - /// get sigmaZ + /// get meanX, meanY, meanZ position + double meanX() const { return fMeanX; } + double meanY() const { return fMeanY; } + double meanZ() const { return fMeanZ; } + /// get sigmaX, sigmaY, sigmaZ + double sigmaX() const { return fSigmaX; } + double sigmaY() const { return fSigmaY; } double sigmaZ() const { return fSigmaZ; } - /// get BetaStar + /// get BetaStar and Emittance double betaStar() const { return fbetastar; } - /// get Emittance double emittance() const { return femittance; } - /// get Phi + /// get Phi, Alpha and TimeOffset double phi() const { return fPhi; } - /// get Alpha double alpha() const { return fAlpha; } - /// get TimeOffset double timeOffset() const { return fTimeOffset; } /// print sim beam spot parameters @@ -66,7 +92,8 @@ class SimBeamSpotObjects { private: double fX0, fY0, fZ0; - double fSigmaZ; + double fMeanX, fMeanY, fMeanZ; + double fSigmaX, fSigmaY, fSigmaZ; double fbetastar, femittance; double fPhi, fAlpha; double fTimeOffset; diff --git a/CondFormats/BeamSpotObjects/src/SimBeamSpotObjects.cc b/CondFormats/BeamSpotObjects/src/SimBeamSpotObjects.cc index 2d1973fbcb03b..da9b8f63d9641 100644 --- a/CondFormats/BeamSpotObjects/src/SimBeamSpotObjects.cc +++ b/CondFormats/BeamSpotObjects/src/SimBeamSpotObjects.cc @@ -8,6 +8,11 @@ void SimBeamSpotObjects::print(std::stringstream& ss) const { << " X0 = " << x() << " [cm]\n" << " Y0 = " << y() << " [cm]\n" << " Z0 = " << z() << " [cm]\n" + << " MeanX = " << meanX() << " [cm]\n" + << " MeanY = " << meanY() << " [cm]\n" + << " MeanZ = " << meanZ() << " [cm]\n" + << " Sigma X0 = " << sigmaX() << " [cm]\n" + << " Sigma Y0 = " << sigmaY() << " [cm]\n" << " Sigma Z0 = " << sigmaZ() << " [cm]\n" << " Beta star = " << betaStar() << " [cm]\n" << " Emittance X = " << emittance() << " [cm]\n" diff --git a/CondTools/BeamSpot/plugins/BeamProfile2DBReader.cc b/CondTools/BeamSpot/plugins/BeamProfile2DBReader.cc index c5a875e910212..ac6cc618c87f2 100644 --- a/CondTools/BeamSpot/plugins/BeamProfile2DBReader.cc +++ b/CondTools/BeamSpot/plugins/BeamProfile2DBReader.cc @@ -56,7 +56,8 @@ class BeamProfile2DBReader : public edm::one::EDAnalyzerx(); theBSfromDB_.fY0 = mybeamspot->y(); theBSfromDB_.fZ0 = mybeamspot->z(); + theBSfromDB_.fMeanX = mybeamspot->meanX(); + theBSfromDB_.fMeanY = mybeamspot->meanY(); + theBSfromDB_.fMeanZ = mybeamspot->meanZ(); + theBSfromDB_.fSigmaX = mybeamspot->sigmaX(); + theBSfromDB_.fSigmaY = mybeamspot->sigmaY(); theBSfromDB_.fSigmaZ = mybeamspot->sigmaZ(); theBSfromDB_.fbetastar = mybeamspot->betaStar(); theBSfromDB_.femittance = mybeamspot->emittance(); @@ -157,6 +168,11 @@ void BeamProfile2DBReader::beginJob() { bstree_->Branch("BSx0", &theBSfromDB_.fX0, "BSx0/F"); bstree_->Branch("BSy0", &theBSfromDB_.fY0, "BSy0/F"); bstree_->Branch("BSz0", &theBSfromDB_.fZ0, "BSz0/F"); + bstree_->Branch("BSmeanX", &theBSfromDB_.fMeanX, "BSmeanX/F"); + bstree_->Branch("BSmeanY", &theBSfromDB_.fMeanY, "BSmeanY/F"); + bstree_->Branch("BSmeanZ", &theBSfromDB_.fMeanZ, "BSmeanZ/F"); + bstree_->Branch("Beamsigmax", &theBSfromDB_.fSigmaX, "Beamsigmax/F"); + bstree_->Branch("Beamsigmay", &theBSfromDB_.fSigmaY, "Beamsigmay/F"); bstree_->Branch("Beamsigmaz", &theBSfromDB_.fSigmaZ, "Beamsigmaz/F"); bstree_->Branch("BetaStar", &theBSfromDB_.fbetastar, "BetaStar/F"); bstree_->Branch("Emittance", &theBSfromDB_.femittance, "Emittance/F"); diff --git a/CondTools/BeamSpot/plugins/BeamProfile2DBWriter.cc b/CondTools/BeamSpot/plugins/BeamProfile2DBWriter.cc index ac94559dca741..f3f17fe0f34dd 100644 --- a/CondTools/BeamSpot/plugins/BeamProfile2DBWriter.cc +++ b/CondTools/BeamSpot/plugins/BeamProfile2DBWriter.cc @@ -60,6 +60,11 @@ BeamProfile2DBWriter::BeamProfile2DBWriter(const edm::ParameterSet& iConfig) beamSpot_.setX(iConfig.getParameter("X0")); beamSpot_.setY(iConfig.getParameter("Y0")); beamSpot_.setZ(iConfig.getParameter("Z0")); + beamSpot_.setMeanX(iConfig.getParameter("MeanX")); + beamSpot_.setMeanY(iConfig.getParameter("MeanY")); + beamSpot_.setMeanZ(iConfig.getParameter("MeanZ")); + beamSpot_.setSigmaX(iConfig.getParameter("SigmaX")); + beamSpot_.setSigmaY(iConfig.getParameter("SigmaY")); beamSpot_.setSigmaZ(iConfig.getParameter("SigmaZ")); beamSpot_.setAlpha(iConfig.getParameter("Alpha")); beamSpot_.setPhi(iConfig.getParameter("Phi")); @@ -88,12 +93,17 @@ void BeamProfile2DBWriter::fillDescriptions(edm::ConfigurationDescriptions& desc edm::ParameterSetDescription desc; desc.add("recordName", "SimBeamSpotObjectsRcd") ->setComment("name of the record to use for the PoolDBOutputService"); - desc.add("X0")->setComment("in cm"); - desc.add("Y0")->setComment("in cm"); - desc.add("Z0")->setComment("in cm"); - desc.add("SigmaZ")->setComment("in cm"); - desc.add("BetaStar")->setComment("in cm"); - desc.add("Emittance")->setComment("in cm"); + desc.add("X0", 0.0)->setComment("in cm"); + desc.add("Y0", 0.0)->setComment("in cm"); + desc.add("Z0", 0.0)->setComment("in cm"); + desc.add("MeanX", 0.0)->setComment("in cm"); + desc.add("MeanY", 0.0)->setComment("in cm"); + desc.add("MeanZ", 0.0)->setComment("in cm"); + desc.add("SigmaX", 0.0)->setComment("in cm"); + desc.add("SigmaY", 0.0)->setComment("in cm"); + desc.add("SigmaZ", 0.0)->setComment("in cm"); + desc.add("BetaStar", 0.0)->setComment("in cm"); + desc.add("Emittance", 0.0)->setComment("in cm"); desc.add("Alpha", 0.0)->setComment("in radians"); desc.add("Phi", 0.0)->setComment("in radians"); desc.add("TimeOffset", 0.0)->setComment("in ns"); diff --git a/CondTools/BeamSpot/test/BeamProfile2DBWriterAll_cfg.py b/CondTools/BeamSpot/test/BeamProfile2DBWriterAll_cfg.py index 8fb81dfedc9ef..dfe8592e0bb15 100644 --- a/CondTools/BeamSpot/test/BeamProfile2DBWriterAll_cfg.py +++ b/CondTools/BeamSpot/test/BeamProfile2DBWriterAll_cfg.py @@ -31,20 +31,20 @@ from CondTools.BeamSpot.beamProfile2DBWriter_cfi import beamProfile2DBWriter process.load("IOMC.EventVertexGenerators.VtxSmearedParameters_cfi") -# Get the PSets that have BetaStar as a parameter -psets_with_BetaStar = [] +# Get the PSets that have BetaStar (BetafuncEvtVtxGenerator) or SigmaX (GaussEvtVtxGenerator) as a parameter +psets_SimBeamSpotObjects = [] psets_names = [] for psetName in process.__dict__: pset = getattr(process, psetName) - if isinstance(pset, cms.PSet) and "BetaStar" in pset.parameterNames_(): + if isinstance(pset, cms.PSet) and ("BetaStar" in pset.parameterNames_() or "SigmaX" in pset.parameterNames_()): print(psetName) psets_names.append(psetName) - psets_with_BetaStar.append(pset) + psets_SimBeamSpotObjects.append(pset) # Create a VPSet to store the parameter sets myVPSet = cms.VPSet() -for i, pset in enumerate(psets_with_BetaStar): +for i, pset in enumerate(psets_SimBeamSpotObjects): cloneName = 'BeamProfile2DBWriter_' + str(i+1) # Unique clone name setattr(process, cloneName, beamProfile2DBWriter.clone(pset, recordName = cms.string(psets_names[i]))) @@ -74,7 +74,7 @@ process.end = cms.EndPath() process.schedule = cms.Schedule() -for i, pset in enumerate(psets_with_BetaStar): +for i, pset in enumerate(psets_SimBeamSpotObjects): pathName = 'Path_' + str(i+1) # Unique path name process.schedule.append(getattr(process, pathName)) process.schedule.append(process.end) diff --git a/CondTools/BeamSpot/test/extractAndUploadAll.py b/CondTools/BeamSpot/test/extractAndUploadAll.py index 111cad5e8d6c9..33c7d4ed2f03a 100644 --- a/CondTools/BeamSpot/test/extractAndUploadAll.py +++ b/CondTools/BeamSpot/test/extractAndUploadAll.py @@ -31,7 +31,7 @@ data = { "destinationDatabase": "oracle://cms_orcoff_prep/CMS_CONDITIONS", "destinationTags": { - "SimBeamSpot_" + value + "_v0_mc": {} + "SimBeamSpot_" + value + "_v1_mc": {} }, "inputTag": value, "since": None, diff --git a/IOMC/EventVertexGenerators/interface/BetafuncEvtVtxGenerator.h b/IOMC/EventVertexGenerators/interface/BetafuncEvtVtxGenerator.h index 803a35ff10558..777dd1607393a 100644 --- a/IOMC/EventVertexGenerators/interface/BetafuncEvtVtxGenerator.h +++ b/IOMC/EventVertexGenerators/interface/BetafuncEvtVtxGenerator.h @@ -35,7 +35,7 @@ class BetafuncEvtVtxGenerator : public BaseEvtVtxGenerator { BetafuncEvtVtxGenerator(const BetafuncEvtVtxGenerator& p) = delete; /** Copy assignment operator */ BetafuncEvtVtxGenerator& operator=(const BetafuncEvtVtxGenerator& rhs) = delete; - ~BetafuncEvtVtxGenerator() override; + ~BetafuncEvtVtxGenerator() override = default; void beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) override; diff --git a/IOMC/EventVertexGenerators/interface/GaussEvtVtxGenerator.h b/IOMC/EventVertexGenerators/interface/GaussEvtVtxGenerator.h index b2c18584f7006..6bbea9c0821aa 100644 --- a/IOMC/EventVertexGenerators/interface/GaussEvtVtxGenerator.h +++ b/IOMC/EventVertexGenerators/interface/GaussEvtVtxGenerator.h @@ -8,6 +8,10 @@ */ #include "IOMC/EventVertexGenerators/interface/BaseEvtVtxGenerator.h" +#include "FWCore/Framework/interface/ESWatcher.h" +#include "FWCore/Utilities/interface/ESGetToken.h" +#include "CondFormats/DataRecord/interface/SimBeamSpotObjectsRcd.h" +#include "CondFormats/BeamSpotObjects/interface/SimBeamSpotObjects.h" namespace CLHEP { class HepRandomEngine; @@ -20,7 +24,9 @@ class GaussEvtVtxGenerator : public BaseEvtVtxGenerator { GaussEvtVtxGenerator(const GaussEvtVtxGenerator& p) = delete; /** Copy assignment operator */ GaussEvtVtxGenerator& operator=(const GaussEvtVtxGenerator& rhs) = delete; - ~GaussEvtVtxGenerator() override; + ~GaussEvtVtxGenerator() override = default; + + void beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) override; /// return a new event vertex //virtual CLHEP::Hep3Vector* newVertex(); @@ -43,9 +49,15 @@ class GaussEvtVtxGenerator : public BaseEvtVtxGenerator { void meanZ(double m = 0) { fMeanZ = m; } private: + bool readDB_; + double fSigmaX, fSigmaY, fSigmaZ; double fMeanX, fMeanY, fMeanZ; double fTimeOffset; + + void update(const edm::EventSetup& iEventSetup); + edm::ESWatcher parameterWatcher_; + edm::ESGetToken beamToken_; }; #endif diff --git a/IOMC/EventVertexGenerators/src/BetafuncEvtVtxGenerator.cc b/IOMC/EventVertexGenerators/src/BetafuncEvtVtxGenerator.cc index b7c8bd7789da4..125169fba39a5 100644 --- a/IOMC/EventVertexGenerators/src/BetafuncEvtVtxGenerator.cc +++ b/IOMC/EventVertexGenerators/src/BetafuncEvtVtxGenerator.cc @@ -38,7 +38,7 @@ BetafuncEvtVtxGenerator::BetafuncEvtVtxGenerator(const edm::ParameterSet& p) : B fSigmaZ = p.getParameter("SigmaZ") * cm; fbetastar = p.getParameter("BetaStar") * cm; femittance = p.getParameter("Emittance") * cm; // this is not the normalized emittance - fTimeOffset = p.getParameter("TimeOffset") * ns * c_light; // HepMC distance units are mm + fTimeOffset = p.getParameter("TimeOffset") * ns * c_light; // HepMC distance units are in mm setBoost(p.getParameter("Alpha") * radian, p.getParameter("Phi") * radian); if (fSigmaZ <= 0) { @@ -53,8 +53,6 @@ BetafuncEvtVtxGenerator::BetafuncEvtVtxGenerator(const edm::ParameterSet& p) : B } } -BetafuncEvtVtxGenerator::~BetafuncEvtVtxGenerator() {} - void BetafuncEvtVtxGenerator::beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const& iEventSetup) { update(iEventSetup); } diff --git a/IOMC/EventVertexGenerators/src/GaussEvtVtxGenerator.cc b/IOMC/EventVertexGenerators/src/GaussEvtVtxGenerator.cc index bd77bb4e5221d..a45a096fbfaa4 100644 --- a/IOMC/EventVertexGenerators/src/GaussEvtVtxGenerator.cc +++ b/IOMC/EventVertexGenerators/src/GaussEvtVtxGenerator.cc @@ -12,29 +12,52 @@ #include "HepMC/SimpleVector.h" GaussEvtVtxGenerator::GaussEvtVtxGenerator(const edm::ParameterSet& p) : BaseEvtVtxGenerator(p) { - fMeanX = p.getParameter("MeanX") * cm; - fMeanY = p.getParameter("MeanY") * cm; - fMeanZ = p.getParameter("MeanZ") * cm; - fSigmaX = p.getParameter("SigmaX") * cm; - fSigmaY = p.getParameter("SigmaY") * cm; - fSigmaZ = p.getParameter("SigmaZ") * cm; - fTimeOffset = p.getParameter("TimeOffset") * ns * c_light; + readDB_ = p.getParameter("readDB"); + if (!readDB_) { + fMeanX = p.getParameter("MeanX") * cm; + fMeanY = p.getParameter("MeanY") * cm; + fMeanZ = p.getParameter("MeanZ") * cm; + fSigmaX = p.getParameter("SigmaX") * cm; + fSigmaY = p.getParameter("SigmaY") * cm; + fSigmaZ = p.getParameter("SigmaZ") * cm; + fTimeOffset = p.getParameter("TimeOffset") * ns * c_light; // HepMC distance units are in mm - if (fSigmaX < 0) { - throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " - << "Illegal resolution in X (SigmaX is negative)"; + if (fSigmaX < 0) { + throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " + << "Illegal resolution in X (SigmaX is negative)"; + } + if (fSigmaY < 0) { + throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " + << "Illegal resolution in Y (SigmaY is negative)"; + } + if (fSigmaZ < 0) { + throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " + << "Illegal resolution in Z (SigmaZ is negative)"; + } } - if (fSigmaY < 0) { - throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " - << "Illegal resolution in Y (SigmaY is negative)"; - } - if (fSigmaZ < 0) { - throw cms::Exception("Configuration") << "Error in GaussEvtVtxGenerator: " - << "Illegal resolution in Z (SigmaZ is negative)"; + if (readDB_) { + // NOTE: this is currently watching LS transitions, while it should watch Run transitions, + // even though in reality there is no Run Dependent MC (yet) in CMS + beamToken_ = esConsumes(); } } -GaussEvtVtxGenerator::~GaussEvtVtxGenerator() {} +void GaussEvtVtxGenerator::beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const& iEventSetup) { + update(iEventSetup); +} + +void GaussEvtVtxGenerator::update(const edm::EventSetup& iEventSetup) { + if (readDB_ && parameterWatcher_.check(iEventSetup)) { + edm::ESHandle beamhandle = iEventSetup.getHandle(beamToken_); + fMeanX = beamhandle->meanX() * cm; + fMeanY = beamhandle->meanY() * cm; + fMeanZ = beamhandle->meanZ() * cm; + fSigmaX = beamhandle->sigmaX() * cm; + fSigmaY = beamhandle->sigmaY() * cm; + fSigmaZ = beamhandle->sigmaZ() * cm; + fTimeOffset = beamhandle->timeOffset() * ns * c_light; // HepMC distance units are in mm + } +} HepMC::FourVector GaussEvtVtxGenerator::newVertex(CLHEP::HepRandomEngine* engine) const { double X, Y, Z, T;