1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
#ifndef FakeTTrig_H
#define FakeTTrig_H
/** \class FakeTTrigDB
*
* Class which produce fake DB of ttrig with the correction of :
* --- 500 ns of delay
* --- time of wire propagation
* --- time of fly
*
* \author Giorgia Mila - INFN Torino
*/
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "Geometry/Records/interface/MuonGeometryRecord.h"
#include "Geometry/DTGeometry/interface/DTGeometry.h"
#include "CondFormats/DataRecord/interface/DTTtrigRcd.h"
#include <string>
class DTGeometry;
class DTSuperLayer;
class DTTtrig;
class FakeTTrig : public edm::one::EDAnalyzer<edm::one::WatchRuns, edm::one::WatchLuminosityBlocks> {
public:
/// Constructor
FakeTTrig(const edm::ParameterSet& pset);
/// Destructor
virtual ~FakeTTrig();
// Operations
virtual void beginRun(const edm::Run& run, const edm::EventSetup& setup) override;
virtual void beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) override;
virtual void analyze(const edm::Event& event, const edm::EventSetup& setup) override {}
virtual void endRun(const edm::Run& run, const edm::EventSetup& setup) override {}
virtual void endLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) override {}
virtual void endJob() override;
// TOF computation
double tofComputation(const DTSuperLayer* superlayer);
// wire propagation delay
double wirePropComputation(const DTSuperLayer* superlayer);
protected:
private:
edm::ESHandle<DTGeometry> muonGeom;
edm::ParameterSet ps;
double smearing;
/// tTrig from the DB
float tTrigRef;
float tTrigRMSRef;
float kFactorRef;
// Get the tTrigMap
edm::ESHandle<DTTtrig> tTrigMapRef;
bool dataBaseWriteWasDone;
edm::ESGetToken<DTTtrig, DTTtrigRcd> ttrigToken_;
edm::ESGetToken<DTGeometry, MuonGeometryRecord> dtGeomToken_;
};
#endif
|