CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
FlatEvtVtxGenerator Class Reference

#include <FlatEvtVtxGenerator.h>

Inheritance diagram for FlatEvtVtxGenerator:
BaseEvtVtxGenerator edm::stream::EDProducer<>

Public Member Functions

 FlatEvtVtxGenerator (const edm::ParameterSet &p)
 
 FlatEvtVtxGenerator (const FlatEvtVtxGenerator &p)=delete
 
const TMatrixD * GetInvLorentzBoost () const override
 
void maxX (double m=0)
 set max in X in cm More...
 
void maxY (double m=0)
 set max in Y in cm More...
 
void maxZ (double m=0)
 set max in Z in cm More...
 
void minX (double m=0.0)
 set min in X in cm More...
 
void minY (double m=0.0)
 set min in Y in cm More...
 
void minZ (double m=0.0)
 set min in Z in cm More...
 
HepMC::FourVector newVertex (CLHEP::HepRandomEngine *) const override
 return a new event vertex More...
 
FlatEvtVtxGeneratoroperator= (const FlatEvtVtxGenerator &rhs)=delete
 
 ~FlatEvtVtxGenerator () override
 
- Public Member Functions inherited from BaseEvtVtxGenerator
 BaseEvtVtxGenerator (const edm::ParameterSet &)
 
void produce (edm::Event &, const edm::EventSetup &) override
 
 ~BaseEvtVtxGenerator () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
 EDProducer (const EDProducer &)=delete
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginProcessBlocks () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndProcessBlocks () const final
 
bool hasAbilityToProduceInEndRuns () const final
 
const EDProduceroperator= (const EDProducer &)=delete
 

Private Attributes

double fMaxT
 
double fMaxX
 
double fMaxY
 
double fMaxZ
 
double fMinT
 
double fMinX
 
double fMinY
 
double fMinZ
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDProducer<>
using CacheTypes = CacheContexts< T... >
 
using GlobalCache = typename CacheTypes::GlobalCache
 
using HasAbility = AbilityChecker< T... >
 
using InputProcessBlockCache = typename CacheTypes::InputProcessBlockCache
 
using LuminosityBlockCache = typename CacheTypes::LuminosityBlockCache
 
using LuminosityBlockContext = LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCache >
 
using LuminosityBlockSummaryCache = typename CacheTypes::LuminosityBlockSummaryCache
 
using RunCache = typename CacheTypes::RunCache
 
using RunContext = RunContextT< RunCache, GlobalCache >
 
using RunSummaryCache = typename CacheTypes::RunSummaryCache
 

Detailed Description

Definition at line 22 of file FlatEvtVtxGenerator.h.

Constructor & Destructor Documentation

◆ FlatEvtVtxGenerator() [1/2]

FlatEvtVtxGenerator::FlatEvtVtxGenerator ( const edm::ParameterSet p)

Definition at line 15 of file FlatEvtVtxGenerator.cc.

References Exception, fMaxT, fMaxX, fMaxY, fMaxZ, fMinT, fMinX, fMinY, fMinZ, and AlCaHLTBitMon_ParallelJobs::p.

16  fMinX = p.getParameter<double>("MinX") * cm;
17  fMinY = p.getParameter<double>("MinY") * cm;
18  fMinZ = p.getParameter<double>("MinZ") * cm;
19  fMaxX = p.getParameter<double>("MaxX") * cm;
20  fMaxY = p.getParameter<double>("MaxY") * cm;
21  fMaxZ = p.getParameter<double>("MaxZ") * cm;
22  fMinT = p.getParameter<double>("MinT") * ns * c_light;
23  fMaxT = p.getParameter<double>("MaxT") * ns * c_light;
24 
25  if (fMinX > fMaxX) {
26  throw cms::Exception("Configuration") << "Error in FlatEvtVtxGenerator: "
27  << "MinX is greater than MaxX";
28  }
29  if (fMinY > fMaxY) {
30  throw cms::Exception("Configuration") << "Error in FlatEvtVtxGenerator: "
31  << "MinY is greater than MaxY";
32  }
33  if (fMinZ > fMaxZ) {
34  throw cms::Exception("Configuration") << "Error in FlatEvtVtxGenerator: "
35  << "MinZ is greater than MaxZ";
36  }
37  if (fMinT > fMaxT) {
38  throw cms::Exception("Configuration") << "Error in FlatEvtVtxGenerator: "
39  << "MinT is greater than MaxT";
40  }
41  edm::LogVerbatim("FlatEvtVtx") << "FlatEvtVtxGenerator Initialized with x[" << fMinX << ":" << fMaxX << "] cm; y["
42  << fMinY << ":" << fMaxY << "] cm; z[" << fMinZ << ":" << fMaxZ << "] cm; t[" << fMinT
43  << ":" << fMaxT << "]";
44 }
Log< level::Info, true > LogVerbatim
BaseEvtVtxGenerator(const edm::ParameterSet &)

◆ FlatEvtVtxGenerator() [2/2]

FlatEvtVtxGenerator::FlatEvtVtxGenerator ( const FlatEvtVtxGenerator p)
delete

Copy constructor

◆ ~FlatEvtVtxGenerator()

FlatEvtVtxGenerator::~FlatEvtVtxGenerator ( )
override

Definition at line 46 of file FlatEvtVtxGenerator.cc.

46 {}

Member Function Documentation

◆ GetInvLorentzBoost()

const TMatrixD* FlatEvtVtxGenerator::GetInvLorentzBoost ( ) const
inlineoverridevirtual

This method - and the comment - is a left-over from COBRA-OSCAR time : return the last generated event vertex. If no vertex has been generated yet, a NULL pointer is returned.

Implements BaseEvtVtxGenerator.

Definition at line 35 of file FlatEvtVtxGenerator.h.

35 { return nullptr; }

◆ maxX()

void FlatEvtVtxGenerator::maxX ( double  m = 0)

set max in X in cm

Definition at line 68 of file FlatEvtVtxGenerator.cc.

References fMaxX, and SiStripPI::max.

◆ maxY()

void FlatEvtVtxGenerator::maxY ( double  m = 0)

set max in Y in cm

Definition at line 70 of file FlatEvtVtxGenerator.cc.

References fMaxY, and SiStripPI::max.

◆ maxZ()

void FlatEvtVtxGenerator::maxZ ( double  m = 0)

set max in Z in cm

Definition at line 72 of file FlatEvtVtxGenerator.cc.

References fMaxZ, and SiStripPI::max.

◆ minX()

void FlatEvtVtxGenerator::minX ( double  m = 0.0)

set min in X in cm

Definition at line 62 of file FlatEvtVtxGenerator.cc.

References fMinX, and SiStripPI::min.

◆ minY()

void FlatEvtVtxGenerator::minY ( double  m = 0.0)

set min in Y in cm

Definition at line 64 of file FlatEvtVtxGenerator.cc.

References fMinY, and SiStripPI::min.

◆ minZ()

void FlatEvtVtxGenerator::minZ ( double  m = 0.0)

set min in Z in cm

Definition at line 66 of file FlatEvtVtxGenerator.cc.

References fMinZ, and SiStripPI::min.

◆ newVertex()

HepMC::FourVector FlatEvtVtxGenerator::newVertex ( CLHEP::HepRandomEngine *  engine) const
overridevirtual

return a new event vertex

Implements BaseEvtVtxGenerator.

Definition at line 49 of file FlatEvtVtxGenerator.cc.

References fMaxT, fMaxX, fMaxY, fMaxZ, fMinT, fMinX, fMinY, and fMinZ.

49  {
50  double aX, aY, aZ, aT;
51  aX = CLHEP::RandFlat::shoot(engine, fMinX, fMaxX);
52  aY = CLHEP::RandFlat::shoot(engine, fMinY, fMaxY);
53  aZ = CLHEP::RandFlat::shoot(engine, fMinZ, fMaxZ);
54  aT = CLHEP::RandFlat::shoot(engine, fMinT, fMaxT);
55 
56  edm::LogVerbatim("FlatEvtVtx") << "FlatEvtVtxGenerator Vertex at [" << aX << ", " << aY << ", " << aZ << ", " << aT
57  << "]";
58 
59  return HepMC::FourVector(aX, aY, aZ, aT);
60 }
Log< level::Info, true > LogVerbatim

◆ operator=()

FlatEvtVtxGenerator& FlatEvtVtxGenerator::operator= ( const FlatEvtVtxGenerator rhs)
delete

Copy assignment operator

Member Data Documentation

◆ fMaxT

double FlatEvtVtxGenerator::fMaxT
private

Definition at line 53 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), and newVertex().

◆ fMaxX

double FlatEvtVtxGenerator::fMaxX
private

Definition at line 53 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), maxX(), and newVertex().

◆ fMaxY

double FlatEvtVtxGenerator::fMaxY
private

Definition at line 53 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), maxY(), and newVertex().

◆ fMaxZ

double FlatEvtVtxGenerator::fMaxZ
private

Definition at line 53 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), maxZ(), and newVertex().

◆ fMinT

double FlatEvtVtxGenerator::fMinT
private

Definition at line 52 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), and newVertex().

◆ fMinX

double FlatEvtVtxGenerator::fMinX
private

Definition at line 52 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), minX(), and newVertex().

◆ fMinY

double FlatEvtVtxGenerator::fMinY
private

Definition at line 52 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), minY(), and newVertex().

◆ fMinZ

double FlatEvtVtxGenerator::fMinZ
private

Definition at line 52 of file FlatEvtVtxGenerator.h.

Referenced by FlatEvtVtxGenerator(), minZ(), and newVertex().