CMS 3D CMS Logo

AlignmentPrescaler.cc
Go to the documentation of this file.
2 
12 
15 
23 
24 // #include "Riostream.h"
25 
26 using namespace std;
27 
29  : src_(iConfig.getParameter<edm::InputTag>("src")),
30  srcQualityMap_(iConfig.getParameter<edm::InputTag>("assomap")),
31  prescfilename_(iConfig.getParameter<std::string>("PrescFileName")),
32  presctreename_(iConfig.getParameter<std::string>("PrescTreeName")) {
33  // issue the produce<>
34  produces<AliClusterValueMap>();
35  produces<AliTrackTakenClusterValueMap>();
36 }
37 
39  //
40 }
41 
43  //
44  std::cout << "in AlignmentPrescaler::beginJob" << std::flush;
45  fpresc_ = new TFile(prescfilename_.c_str(), "READ");
46  tpresc_ = (TTree*)fpresc_->Get(presctreename_.c_str());
47  tpresc_->BuildIndex("DetId");
48  tpresc_->SetBranchStatus("*", false);
49  tpresc_->SetBranchStatus("DetId", true);
50  tpresc_->SetBranchStatus("PrescaleFactor", true);
51  tpresc_->SetBranchStatus("PrescaleFactorOverlap", true);
52  cout << " Branches activated " << std::flush;
53  detid_ = 0;
54  hitPrescFactor_ = 99.0;
55  overlapPrescFactor_ = 88.0;
56 
57  tpresc_->SetBranchAddress("DetId", &detid_);
58  tpresc_->SetBranchAddress("PrescaleFactor", &hitPrescFactor_);
59  tpresc_->SetBranchAddress("PrescaleFactorOverlap", &overlapPrescFactor_);
60  cout << " addressed " << std::flush;
61  myrand_ = new TRandom3();
62  // myrand_->SetSeed();
63  cout << " ok " << std::endl;
64 }
65 
67  delete tpresc_;
68  fpresc_->Close();
69  delete fpresc_;
70  delete myrand_;
71 }
72 
74  // std::cout<<"\n\n#################\n### Starting the AlignmentPrescaler::produce ; Event: "<<iEvent.id().run() <<", "<<iEvent.id().event()<<std::endl;
76  iEvent.getByLabel(src_, Tracks);
77 
78  //take HitAssomap
80  iEvent.getByLabel(srcQualityMap_, hMap);
81  AliClusterValueMap InValMap = *hMap;
82 
83  //prepare the output of the ValueMap flagging tracks
84  std::vector<int> trackflags(Tracks->size(), 0);
85 
86  //int npxlhits=0;
87 
88  //loop on tracks
89  for (std::vector<reco::Track>::const_iterator ittrk = Tracks->begin(), edtrk = Tracks->end(); ittrk != edtrk;
90  ++ittrk) {
91  //loop on tracking rechits
92  // std::cout << "Loop on hits of track #" << (ittrk - Tracks->begin()) << std::endl;
93  int nhit = 0;
94  int ntakenhits = 0;
95  bool firstTakenHit = false;
96 
97  for (auto const& hit : ittrk->recHits()) {
98  if (!hit->isValid()) {
99  nhit++;
100  continue;
101  }
102  uint32_t tmpdetid = hit->geographicalId().rawId();
103  tpresc_->GetEntryWithIndex(tmpdetid);
104 
105  //-------------
106  //decide whether to take this hit or not
107  bool takeit = false;
108  int subdetId = hit->geographicalId().subdetId();
109 
110  //check first if the cluster is also in the overlap asso map
111  bool isOverlapHit = false;
112  // bool first=true;
113  //ugly...
114  const SiPixelRecHit* pixelhit = dynamic_cast<const SiPixelRecHit*>(hit);
115  const SiStripRecHit1D* stripHit1D = dynamic_cast<const SiStripRecHit1D*>(hit);
116  const SiStripRecHit2D* stripHit2D = dynamic_cast<const SiStripRecHit2D*>(hit);
117 
118  AlignmentClusterFlag tmpflag(hit->geographicalId());
119  int stripType = 0;
120  if (subdetId > 2) { // SST case
121  const std::type_info& type = typeid(*hit);
122  if (type == typeid(SiStripRecHit1D))
123  stripType = 1;
124  else if (type == typeid(SiStripRecHit2D))
125  stripType = 2;
126  else
127  stripType = 3;
128 
129  if (stripType == 1) {
130  // const SiStripRecHit1D* stripHit1D = dynamic_cast<const SiStripRecHit1D*>(hit);
131 
132  if (stripHit1D != nullptr) {
133  SiStripRecHit1D::ClusterRef stripclust(stripHit1D->cluster());
134  tmpflag = InValMap[stripclust];
135  tmpflag.SetDetId(hit->geographicalId());
136  if (tmpflag.isOverlap())
137  isOverlapHit = true;
138  // std::cout<<"~*~*~* Prescale (1D) for module "<<tmpflag.detId().rawId()<<"("<<InValMap[stripclust].detId().rawId() <<") is "<<hitPrescFactor_<<std::flush;
139  // if(tmpflag.isOverlap())cout<<" (it is Overlap)"<<endl;
140  // else cout<<endl;
141 
142  } //end if striphit1D!=0
143  } else if (stripType == 2) {
144  //const SiStripRecHit2D* stripHit2D = dynamic_cast<const SiStripRecHit2D*>(hit);
145  if (stripHit2D != nullptr) {
146  SiStripRecHit2D::ClusterRef stripclust(stripHit2D->cluster());
147  tmpflag = InValMap[stripclust];
148  tmpflag.SetDetId(hit->geographicalId());
149  if (tmpflag.isOverlap())
150  isOverlapHit = true;
151  // std::cout<<"~*~*~* Prescale (2D) for module "<<tmpflag.detId().rawId()<<"("<<InValMap[stripclust].detId().rawId() <<") is "<<hitPrescFactor_<<std::flush;
152  // if(tmpflag.isOverlap())cout<<" (it is Overlap)"<<endl;
153  // else cout<<endl;
154 
155  } //end if striphit2D!=0
156  }
157  } //end if is a strip hit
158  else {
159  // const SiPixelRecHit* pixelhit= dynamic_cast<const SiPixelRecHit*>(hit);
160  if (pixelhit != nullptr) {
161  //npxlhits++;
162  SiPixelClusterRefNew pixclust(pixelhit->cluster());
163  tmpflag = InValMap[pixclust];
164  tmpflag.SetDetId(hit->geographicalId());
165  if (tmpflag.isOverlap())
166  isOverlapHit = true;
167  }
168  } //end else is a pixel hit
169  // tmpflag.SetDetId(hit->geographicalId());
170 
171  if (isOverlapHit) {
172  //cout<<" DetId="<<tmpdetid<<" is Overlap! "<<flush;
173  takeit = (float(myrand_->Rndm()) <= overlapPrescFactor_);
174  }
175  if (!takeit) {
176  float rr = float(myrand_->Rndm());
177  takeit = (rr <= hitPrescFactor_);
178  }
179  if (takeit) { //HIT TAKEN !
180  //cout<<" DetId="<<tmpdetid<<" taken!"<<flush;
181  tmpflag.SetTakenFlag();
182 
183  if (subdetId > 2) {
184  if (stripType == 1) {
185  SiStripRecHit1D::ClusterRef stripclust(stripHit1D->cluster());
186  InValMap[stripclust] = tmpflag; //.SetTakenFlag();
187  } else if (stripType == 2) {
188  SiStripRecHit1D::ClusterRef stripclust(stripHit2D->cluster());
189  InValMap[stripclust] = tmpflag; //.SetTakenFlag();
190  } else
191  std::cout << "Unknown type of strip hit" << std::endl;
192  } else {
193  SiPixelClusterRefNew pixclust(pixelhit->cluster());
194  InValMap[pixclust] = tmpflag; //.SetTakenFlag();
195  }
196 
197  if (!firstTakenHit) {
198  firstTakenHit = true;
199  //std::cout<<"Index of the track iterator is "<< ittrk-Tracks->begin() <<endl;
200  }
201  ntakenhits++;
202  } //end if take this hit
203  //cout<<endl;
204 
205  nhit++;
206  //cout<<endl;
207  } //end loop on RecHits
208  trackflags[ittrk - Tracks->begin()] = ntakenhits;
209 
210  } //end loop on tracks
211 
212  // totnhitspxl_+=ntakenhits;
213  //cout<<"AlignmentPrescaler::produce says that in this event "<<ntakenhits<<" pixel clusters were taken (out of "<<npxlhits<<" total pixel hits."<<endl;
214 
215  //save the asso map, tracks...
216  // prepare output
217  auto OutVM = std::make_unique<AliClusterValueMap>();
218  *OutVM = InValMap;
219 
220  iEvent.put(std::move(OutVM));
221 
222  auto trkVM = std::make_unique<AliTrackTakenClusterValueMap>();
223  AliTrackTakenClusterValueMap::Filler trkmapfiller(*trkVM);
224  trkmapfiller.insert(Tracks, trackflags.begin(), trackflags.end());
225  trkmapfiller.fill();
226  iEvent.put(std::move(trkVM));
227 
228 } //end produce
229 
230 int AlignmentPrescaler::layerFromId(const DetId& id, const TrackerTopology* tTopo) const {
231  if (uint32_t(id.subdetId()) == PixelSubdetector::PixelBarrel) {
232  return tTopo->pxbLayer(id);
233  } else if (uint32_t(id.subdetId()) == PixelSubdetector::PixelEndcap) {
234  return tTopo->pxfDisk(id) + (3 * (tTopo->pxfSide(id) - 1));
235  } else if (id.subdetId() == StripSubdetector::TIB) {
236  return tTopo->tibLayer(id);
237  } else if (id.subdetId() == StripSubdetector::TOB) {
238  return tTopo->tobLayer(id);
239  } else if (id.subdetId() == StripSubdetector::TEC) {
240  return tTopo->tecWheel(id) + (9 * (tTopo->pxfSide(id) - 1));
241  } else if (id.subdetId() == StripSubdetector::TID) {
242  return tTopo->tidWheel(id) + (3 * (tTopo->tidSide(id) - 1));
243  }
244  return -1;
245 
246 } //end layerfromId
247 
248 // ========= MODULE DEF ==============
SiStripRecHit2D::cluster
ClusterRef cluster() const
Definition: SiStripRecHit2D.h:22
AlignmentPrescaler::fpresc_
TFile * fpresc_
Definition: AlignmentPrescaler.h:38
edm::helper::Filler::insert
void insert(const H &h, I begin, I end)
Definition: ValueMap.h:53
AlignmentPrescaler::produce
void produce(edm::Event &iEvent, const edm::EventSetup &iSetup) override
Definition: AlignmentPrescaler.cc:73
MessageLogger.h
dqmMemoryStats.float
float
Definition: dqmMemoryStats.py:127
PixelSubdetector::PixelEndcap
Definition: PixelSubdetector.h:11
TrackerGeometry.h
PixelSubdetector::PixelBarrel
Definition: PixelSubdetector.h:11
TrackInfo.h
TrackerTopology::pxfSide
unsigned int pxfSide(const DetId &id) const
Definition: TrackerTopology.h:192
AlignmentPrescaler::myrand_
TRandom3 * myrand_
Definition: AlignmentPrescaler.h:40
findQualityFiles.rr
string rr
Definition: findQualityFiles.py:185
edm
HLT enums.
Definition: AlignableModifier.h:19
AlignmentPrescaler::presctreename_
std::string presctreename_
Definition: AlignmentPrescaler.h:36
TrackerTopology
Definition: TrackerTopology.h:16
gather_cfg.cout
cout
Definition: gather_cfg.py:144
HLT_FULL_cff.InputTag
InputTag
Definition: HLT_FULL_cff.py:89281
AlignmentPrescaler::beginJob
void beginJob() override
Definition: AlignmentPrescaler.cc:42
edm::helper::Filler::fill
void fill()
Definition: ValueMap.h:65
AlignmentPrescaler::~AlignmentPrescaler
~AlignmentPrescaler() override
Definition: AlignmentPrescaler.cc:38
SiStripRecHit2D
Definition: SiStripRecHit2D.h:7
AlignmentPrescaler::prescfilename_
std::string prescfilename_
Definition: AlignmentPrescaler.h:35
edm::Handle< reco::TrackCollection >
SiPixelRecHit
Our base class.
Definition: SiPixelRecHit.h:23
edm::Ref
Definition: AssociativeIterator.h:58
TSiStripRecHit2DLocalPos.h
TrackerTopology::tidWheel
unsigned int tidWheel(const DetId &id) const
Definition: TrackerTopology.h:201
AlignmentPrescaler::AlignmentPrescaler
AlignmentPrescaler(const edm::ParameterSet &iConfig)
Definition: AlignmentPrescaler.cc:28
TrackerTopology::pxbLayer
unsigned int pxbLayer(const DetId &id) const
Definition: TrackerTopology.h:144
DetId
Definition: DetId.h:17
MakerMacros.h
TrackerTopology.h
pixelClusterTagInfos_cfi.pixelhit
pixelhit
Definition: pixelClusterTagInfos_cfi.py:6
Track.h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
StripSubdetector::TIB
static constexpr auto TIB
Definition: StripSubdetector.h:16
SiPixelRecHit.h
AlignmentPrescaler::tpresc_
TTree * tpresc_
Definition: AlignmentPrescaler.h:39
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
edm::ParameterSet
Definition: ParameterSet.h:47
TSiPixelRecHit.h
AlignmentPrescaler::layerFromId
int layerFromId(const DetId &id, const TrackerTopology *tTopo) const
Definition: AlignmentPrescaler.cc:230
AlignmentPrescaler::srcQualityMap_
edm::InputTag srcQualityMap_
Definition: AlignmentPrescaler.h:33
type
type
Definition: SiPixelVCal_PayloadInspector.cc:37
AlignmentPrescaler
Definition: AlignmentPrescaler.h:23
TrackerTopology::tidSide
unsigned int tidSide(const DetId &id) const
Definition: TrackerTopology.h:190
ModuleDef.h
iEvent
int iEvent
Definition: GenABIO.cc:224
gather_cfg.Tracks
Tracks
Definition: gather_cfg.py:251
AlignmentClusterFlag.h
TrackerTopology::pxfDisk
unsigned int pxfDisk(const DetId &id) const
Definition: TrackerTopology.h:446
Utilities.h
SiStripRecHit1D::cluster
ClusterRef cluster() const
Definition: SiStripRecHit1D.h:18
IdealGeometryRecord.h
edm::EventSetup
Definition: EventSetup.h:58
AlignmentPrescaler.h
AlignmentPrescaler::src_
edm::InputTag src_
Definition: AlignmentPrescaler.h:32
SiStripRecHit1D
Definition: SiStripRecHit1D.h:8
SiStripRecHit1D.h
TrackerTopology::tobLayer
unsigned int tobLayer(const DetId &id) const
Definition: TrackerTopology.h:147
eostools.move
def move(src, dest)
Definition: eostools.py:511
std
Definition: JetResolutionObject.h:76
StripSubdetector::TEC
static constexpr auto TEC
Definition: StripSubdetector.h:19
edm::ValueMap
Definition: ValueMap.h:107
AlignmentPrescaler::detid_
unsigned int detid_
Definition: AlignmentPrescaler.h:44
ClassName.h
Alignable.h
StripSubdetector::TOB
static constexpr auto TOB
Definition: StripSubdetector.h:18
AlignmentPrescaler::hitPrescFactor_
float hitPrescFactor_
Definition: AlignmentPrescaler.h:45
AliClusterValueMap.h
AlignmentPrescaler::overlapPrescFactor_
float overlapPrescFactor_
Definition: AlignmentPrescaler.h:45
AlignableTracker.h
edm::helper::Filler
Definition: ValueMap.h:22
View.h
edm::Event
Definition: Event.h:73
TrackerTopology::tecWheel
unsigned int tecWheel(const DetId &id) const
Definition: TrackerTopology.h:198
SiStripRecHit2D.h
AlignmentClusterFlag
Definition: AlignmentClusterFlag.h:15
StripSubdetector::TID
static constexpr auto TID
Definition: StripSubdetector.h:17
hit
Definition: SiStripHitEffFromCalibTree.cc:88
TrackerTopology::tibLayer
unsigned int tibLayer(const DetId &id) const
Definition: TrackerTopology.h:150
AlignmentPrescaler::endJob
void endJob() override
Definition: AlignmentPrescaler.cc:66