CMS 3D CMS Logo

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

#include <SiGaussianTailNoiseAdder.h>

Inheritance diagram for SiGaussianTailNoiseAdder:
SiNoiseAdder

Public Member Functions

void addBaselineShift (std::vector< float > &, std::vector< bool > &) const override
 
void addCMNoise (std::vector< float > &, float, std::vector< bool > &, CLHEP::HepRandomEngine *) const override
 
void addNoise (std::vector< float > &, size_t &, size_t &, int, float, CLHEP::HepRandomEngine *) const override
 
void addNoiseVR (std::vector< float > &, std::vector< float > &, CLHEP::HepRandomEngine *) const override
 
void addPedestals (std::vector< float > &, std::vector< float > &) const override
 
 SiGaussianTailNoiseAdder (float)
 
 ~SiGaussianTailNoiseAdder () override
 
- Public Member Functions inherited from SiNoiseAdder
virtual ~SiNoiseAdder ()
 

Private Attributes

std::unique_ptr< GaussianTailNoiseGeneratorgenNoise
 
const float threshold
 

Detailed Description

Definition at line 17 of file SiGaussianTailNoiseAdder.h.

Constructor & Destructor Documentation

◆ SiGaussianTailNoiseAdder()

SiGaussianTailNoiseAdder::SiGaussianTailNoiseAdder ( float  th)

◆ ~SiGaussianTailNoiseAdder()

SiGaussianTailNoiseAdder::~SiGaussianTailNoiseAdder ( )
override

Definition at line 7 of file SiGaussianTailNoiseAdder.cc.

7 {}

Member Function Documentation

◆ addBaselineShift()

void SiGaussianTailNoiseAdder::addBaselineShift ( std::vector< float > &  in,
std::vector< bool > &  badChannels 
) const
overridevirtual

Implements SiNoiseAdder.

Definition at line 67 of file SiGaussianTailNoiseAdder.cc.

References recoMuon::in, and createfilelist::int.

Referenced by DigiSimLinkAlgorithm::run().

67  {
68  size_t nAPVs = in.size() / 128;
69  std::vector<float> vShift;
70  double apvCharge, apvMult;
71 
72  size_t iChannel;
73  for (size_t APVn = 0; APVn < nAPVs; ++APVn) {
74  apvMult = 0;
75  apvCharge = 0;
76  for (iChannel = APVn * 128; iChannel != APVn * 128 + 128; ++iChannel) {
77  if (in[iChannel] > 0) {
78  ++apvMult;
79  apvCharge += in[iChannel];
80  }
81  if (apvMult == 0)
82  vShift.push_back(0);
83  else
84  vShift.push_back(apvCharge / apvMult);
85  }
86  }
87 
88  for (iChannel = 0; iChannel != in.size(); ++iChannel) {
89  if (!badChannels[iChannel])
90  in[iChannel] -= vShift[(int)(iChannel / 128)];
91  }
92 }

◆ addCMNoise()

void SiGaussianTailNoiseAdder::addCMNoise ( std::vector< float > &  in,
float  cmnRMS,
std::vector< bool > &  badChannels,
CLHEP::HepRandomEngine *  engine 
) const
overridevirtual

Implements SiNoiseAdder.

Definition at line 52 of file SiGaussianTailNoiseAdder.cc.

References recoMuon::in, and createfilelist::int.

Referenced by DigiSimLinkAlgorithm::run().

55  {
56  int nAPVs = in.size() / 128;
57  std::vector<float> CMNv;
58  CMNv.reserve(nAPVs);
59  for (int APVn = 0; APVn < nAPVs; ++APVn)
60  CMNv.push_back(CLHEP::RandGaussQ::shoot(engine, 0., cmnRMS));
61  for (size_t iChannel = 0; iChannel != in.size(); iChannel++) {
62  if (!badChannels[iChannel])
63  in[iChannel] += CMNv[(int)(iChannel / 128)];
64  }
65 }

◆ addNoise()

void SiGaussianTailNoiseAdder::addNoise ( std::vector< float > &  in,
size_t &  minChannel,
size_t &  maxChannel,
int  numStrips,
float  noiseRMS,
CLHEP::HepRandomEngine *  engine 
) const
overridevirtual

Implements SiNoiseAdder.

Definition at line 9 of file SiGaussianTailNoiseAdder.cc.

References genNoise, recoMuon::in, AlCaHLTBitMon_ParallelJobs::p, and threshold.

Referenced by DigiSimLinkAlgorithm::run().

14  {
15  std::vector<std::pair<int, float> > generatedNoise;
16  genNoise->generate(numStrips, threshold, noiseRMS, generatedNoise, engine);
17 
18  // noise on strips with signal:
19  for (size_t iChannel = minChannel; iChannel < maxChannel; iChannel++) {
20  if (in[iChannel] != 0) {
21  in[iChannel] += CLHEP::RandGaussQ::shoot(engine, 0., noiseRMS);
22  }
23  }
24 
25  // Noise on the other strips
26  typedef std::vector<std::pair<int, float> >::const_iterator VI;
27  for (VI p = generatedNoise.begin(); p != generatedNoise.end(); p++) {
28  if (in[(*p).first] == 0) {
29  in[(*p).first] += (*p).second;
30  }
31  }
32 }
std::unique_ptr< GaussianTailNoiseGenerator > genNoise

◆ addNoiseVR()

void SiGaussianTailNoiseAdder::addNoiseVR ( std::vector< float > &  in,
std::vector< float > &  noiseRMS,
CLHEP::HepRandomEngine *  engine 
) const
overridevirtual

Implements SiNoiseAdder.

Definition at line 34 of file SiGaussianTailNoiseAdder.cc.

References recoMuon::in.

Referenced by DigiSimLinkAlgorithm::run().

36  {
37  // Add noise
38  // Full Gaussian noise is added everywhere
39  for (size_t iChannel = 0; iChannel != in.size(); iChannel++) {
40  if (noiseRMS[iChannel] > 0.)
41  in[iChannel] += CLHEP::RandGaussQ::shoot(engine, 0., noiseRMS[iChannel]);
42  }
43 }

◆ addPedestals()

void SiGaussianTailNoiseAdder::addPedestals ( std::vector< float > &  in,
std::vector< float > &  ped 
) const
overridevirtual

Implements SiNoiseAdder.

Definition at line 45 of file SiGaussianTailNoiseAdder.cc.

References recoMuon::in.

Referenced by DigiSimLinkAlgorithm::run().

45  {
46  for (size_t iChannel = 0; iChannel != in.size(); iChannel++) {
47  if (ped[iChannel] > 0.)
48  in[iChannel] += ped[iChannel];
49  }
50 }

Member Data Documentation

◆ genNoise

std::unique_ptr<GaussianTailNoiseGenerator> SiGaussianTailNoiseAdder::genNoise
private

Definition at line 30 of file SiGaussianTailNoiseAdder.h.

Referenced by addNoise().

◆ threshold

const float SiGaussianTailNoiseAdder::threshold
private

Definition at line 29 of file SiGaussianTailNoiseAdder.h.

Referenced by addNoise(), and utils.StatisticalTest::get_status().