Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:00:04

0001 // -*- C++ -*-
0002 //
0003 // Package:    EcalPulseShapeGrapher
0004 // Class:      EcalPulseShapeGrapher
0005 //
0006 /**\class EcalPulseShapeGrapher EcalPulseShapeGrapher.cc EcalPulseShapeGrapher.h
0007 
0008  Description: <one line class summary>
0009 
0010  Implementation:
0011      <Notes on implementation>
0012 */
0013 //
0014 // Original Author:  Seth Cooper
0015 //         Created:  Tue Feb  5 11:35:45 CST 2008
0016 //
0017 //
0018 
0019 // system include files
0020 #include <memory>
0021 
0022 // user include files
0023 #include "FWCore/Framework/interface/Frameworkfwd.h"
0024 #include "FWCore/Framework/interface/one/EDAnalyzer.h"
0025 
0026 #include "FWCore/Framework/interface/Event.h"
0027 #include "FWCore/Framework/interface/MakerMacros.h"
0028 
0029 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0030 #include "TFile.h"
0031 #include "TGraph.h"
0032 #include "TH2F.h"
0033 #include "TProfile.h"
0034 #include "TH1F.h"
0035 #include <vector>
0036 #include "DataFormats/EcalRecHit/interface/EcalRecHitCollections.h"
0037 #include "DataFormats/EcalDetId/interface/EBDetId.h"
0038 #include "DataFormats/EcalDigi/interface/EcalDigiCollections.h"
0039 #include "CaloOnlineTools/EcalTools/interface/EcalFedMap.h"
0040 #include "Geometry/EcalMapping/interface/EcalElectronicsMapping.h"
0041 
0042 //
0043 // class decleration
0044 //
0045 
0046 class EcalPulseShapeGrapher : public edm::one::EDAnalyzer<> {
0047 public:
0048   explicit EcalPulseShapeGrapher(const edm::ParameterSet&);
0049   ~EcalPulseShapeGrapher() override = default;
0050 
0051 private:
0052   void analyze(const edm::Event&, const edm::EventSetup&) override;
0053   void endJob() override;
0054 
0055   std::string intToString(int);
0056 
0057   const edm::EDGetTokenT<EcalUncalibratedRecHitCollection> EBUncalibratedRecHitCollection_;
0058   const edm::EDGetTokenT<EBDigiCollection> EBDigis_;
0059   const edm::EDGetTokenT<EcalUncalibratedRecHitCollection> EEUncalibratedRecHitCollection_;
0060   const edm::EDGetTokenT<EEDigiCollection> EEDigis_;
0061 
0062   int abscissa[10];
0063   int ordinate[10];
0064   std::vector<int> listChannels_;
0065   std::map<int, TH1F*> ampHistMap_;
0066   std::map<int, TH2F*> pulseShapeHistMap_;
0067   std::map<int, TH1F*> firstSampleHistMap_;
0068   std::map<int, TH2F*> rawPulseShapeHistMap_;
0069   std::map<int, TH1F*> cutAmpHistMap_;
0070 
0071   int ampCut_;
0072   std::string rootFilename_;
0073 
0074   TFile* file_;
0075 
0076   EcalFedMap* fedMap_;
0077   // ----------member data ---------------------------
0078 };