CMS 3D CMS Logo

HPDIonFeedbackSim.h
Go to the documentation of this file.
1 
2 // --------------------------------------------------------
3 // A class to simulated HPD ion feedback noise.
4 // The deliverable of the class is the ion feedback noise
5 // for an HcalDetId units of fC or GeV
6 //
7 // Project: HPD ion feedback
8 // Author: T.Yetkin University of Iowa, Feb. 16, 2010
9 // --------------------------------------------------------
10 
11 #ifndef HcalSimAlgos_HPDIonFeedbackSim_h
12 #define HcalSimAlgos_HPDIonFeedbackSim_h
13 
20 
21 class CaloShapes;
22 
23 namespace CLHEP {
24  class HepRandomEngine;
25 }
26 
28 public:
30  HPDIonFeedbackSim(const edm::ParameterSet&, const CaloShapes* shapes);
31  ~HPDIonFeedbackSim() override;
32 
33  //copied from HFSimParameters.h
34  void setDbService(const HcalDbService* service) { theDbService = service; }
35 
36  // in units of fC
37  double correctPE(const DetId& detId, double npe, CLHEP::HepRandomEngine*) const override;
38  double getIonFeedback(
39  DetId detId, double signal, double pedWidth, bool doThermal, bool isInGeV, CLHEP::HepRandomEngine*);
40 
41  void addThermalNoise(CaloSamples& samples, CLHEP::HepRandomEngine*);
42 
43 private:
44  double fCtoGeV(const DetId& detId) const;
47 };
48 #endif
const HcalDbService * theDbService
Definition: DetId.h:17
const CaloShapes * theShapes
void setDbService(const HcalDbService *service)