#include <DTHitAssociator.h>
Definition at line 21 of file DTHitAssociator.h.
typedef std::map<DTWireId, std::vector<DTDigi> > DTHitAssociator::DigiMap |
Definition at line 28 of file DTHitAssociator.h.
typedef std::map<DTWireId, std::vector<DTDigiSimLink> > DTHitAssociator::LinksMap |
Definition at line 29 of file DTHitAssociator.h.
typedef std::pair<PSimHit,bool> DTHitAssociator::PSimHit_withFlag |
Definition at line 25 of file DTHitAssociator.h.
typedef std::map<DTWireId, std::vector<DTRecHit1DPair> > DTHitAssociator::RecHitMap |
Definition at line 27 of file DTHitAssociator.h.
typedef std::pair<uint32_t, EncodedEventId> DTHitAssociator::SimHitIdpr |
Definition at line 24 of file DTHitAssociator.h.
typedef std::map<DTWireId, std::vector<PSimHit_withFlag> > DTHitAssociator::SimHitMap |
Definition at line 26 of file DTHitAssociator.h.
DTHitAssociator::DTHitAssociator | ( | const edm::Event & | iEvent, |
const edm::EventSetup & | iSetup, | ||
const edm::ParameterSet & | conf, | ||
bool | printRtS | ||
) |
Definition at line 17 of file DTHitAssociator.cc.
References associatorByWire, MixCollection< T >::begin(), begin, EncodedEventId::bunchCrossing(), crossingframe, DTdigisimlinkTag, DTdigiTag, DTrechitTag, DTsimhitsTag, DTsimhitsXFTag, dumpDT, MixCollection< T >::end(), EncodedEventId::event(), PSimHit::eventId(), edm::EventSetup::get(), edm::Event::getByLabel(), edm::HandleBase::isValid(), edm::InputTag::label(), link(), links_exist, LogTrace, mapOfDigi, mapOfLinks, mapOfRecHit, mapOfSimHit, PSimHit::particleType(), PSimHit::processType(), edm::Handle< T >::product(), SimHitOK(), and PSimHit::trackId().
: // input collection labels DTsimhitsTag(conf.getParameter<edm::InputTag>("DTsimhitsTag")), DTsimhitsXFTag(conf.getParameter<edm::InputTag>("DTsimhitsXFTag")), DTdigiTag(conf.getParameter<edm::InputTag>("DTdigiTag")), DTdigisimlinkTag(conf.getParameter<edm::InputTag>("DTdigisimlinkTag")), DTrechitTag(conf.getParameter<edm::InputTag>("DTrechitTag")), // nice printout of DT hits dumpDT(conf.getParameter<bool>("dumpDT")), // CrossingFrame used or not ? crossingframe(conf.getParameter<bool>("crossingframe")), // Event contain the DTDigiSimLink collection ? links_exist(conf.getParameter<bool>("links_exist")), // associatorByWire links to a RecHit all the "valid" SimHits on the same DT wire associatorByWire(conf.getParameter<bool>("associatorByWire")), printRtS(true) { LogTrace("DTHitAssociator") <<"DTHitAssociator constructor: dumpDT = "<<dumpDT <<", crossingframe = "<<crossingframe<<", links_exist = "<<links_exist <<", associatorByWire = "<<associatorByWire; if (!links_exist && !associatorByWire) { edm::LogWarning("DTHitAssociator")<<"*** WARNING in DTHitAssociator::DTHitAssociator: associatorByWire reset to TRUE !" <<" \t (missing DTDigiSimLinkCollection ?)"; associatorByWire = true; } // need DT Geometry to discard hits for which the drift time parametrisation is not applicable edm::ESHandle<DTGeometry> muonGeom; iSetup.get<MuonGeometryRecord>().get(muonGeom); // Get the DT SimHits from the event and map PSimHit by DTWireId mapOfSimHit.clear(); bool takeHit(true); if (crossingframe) { edm::Handle<CrossingFrame<PSimHit> > xFrame; LogTrace("DTHitAssociator") <<"getting CrossingFrame<PSimHit> collection - "<<DTsimhitsXFTag; iEvent.getByLabel(DTsimhitsXFTag,xFrame); auto_ptr<MixCollection<PSimHit> > DTsimhits( new MixCollection<PSimHit>(xFrame.product()) ); LogTrace("DTHitAssociator") <<"... size = "<<DTsimhits->size(); MixCollection<PSimHit>::MixItr isimhit; for (isimhit=DTsimhits->begin(); isimhit!= DTsimhits->end(); isimhit++) { DTWireId wireid((*isimhit).detUnitId()); takeHit = SimHitOK(muonGeom, *isimhit); mapOfSimHit[wireid].push_back(make_pair(*isimhit,takeHit)); } } else if (!DTsimhitsTag.label().empty()) { edm::Handle<edm::PSimHitContainer> DTsimhits; LogTrace("DTHitAssociator") <<"getting PSimHit collection - "<<DTsimhitsTag; iEvent.getByLabel(DTsimhitsTag,DTsimhits); LogTrace("DTHitAssociator") <<"... size = "<<DTsimhits->size(); edm::PSimHitContainer::const_iterator isimhit; for (isimhit=DTsimhits->begin(); isimhit!= DTsimhits->end(); isimhit++) { DTWireId wireid((*isimhit).detUnitId()); takeHit = SimHitOK(muonGeom, *isimhit); mapOfSimHit[wireid].push_back(make_pair(*isimhit,takeHit)); } } // Get the DT Digi collection from the event mapOfDigi.clear(); edm::Handle<DTDigiCollection> digis; LogTrace("DTHitAssociator") <<"getting DTDigi collection - "<<DTdigiTag; iEvent.getByLabel(DTdigiTag,digis); if (digis.isValid()) { // Map DTDigi by DTWireId for (DTDigiCollection::DigiRangeIterator detUnit=digis->begin(); detUnit !=digis->end(); ++detUnit) { const DTLayerId& layerid = (*detUnit).first; const DTDigiCollection::Range& range = (*detUnit).second; DTDigiCollection::const_iterator digi; for (digi = range.first; digi != range.second; ++digi){ DTWireId wireid(layerid,(*digi).wire()); mapOfDigi[wireid].push_back(*digi); } } } else { LogTrace("DTHitAssociator") <<"... NO DTDigi collection found !"; } mapOfLinks.clear(); if (links_exist) { // Get the DT DigiSimLink collection from the event and map DTDigiSimLink by DTWireId edm::Handle<DTDigiSimLinkCollection> digisimlinks; LogTrace("DTHitAssociator") <<"getting DTDigiSimLink collection - "<<DTdigisimlinkTag; iEvent.getByLabel(DTdigisimlinkTag,digisimlinks); for (DTDigiSimLinkCollection::DigiRangeIterator detUnit=digisimlinks->begin(); detUnit !=digisimlinks->end(); ++detUnit) { const DTLayerId& layerid = (*detUnit).first; const DTDigiSimLinkCollection::Range& range = (*detUnit).second; DTDigiSimLinkCollection::const_iterator link; for (link=range.first; link!=range.second; ++link){ DTWireId wireid(layerid,(*link).wire()); mapOfLinks[wireid].push_back(*link); } } } if(dumpDT && printRtS) { // Get the DT rechits from the event edm::Handle<DTRecHitCollection> DTrechits; LogTrace("DTHitAssociator") <<"getting DTRecHit1DPair collection - "<<DTrechitTag; iEvent.getByLabel(DTrechitTag,DTrechits); LogTrace("DTHitAssociator") <<"... size = "<<DTrechits->size(); // map DTRecHit1DPair by DTWireId mapOfRecHit.clear(); DTRecHitCollection::const_iterator rechit; for(rechit=DTrechits->begin(); rechit!=DTrechits->end(); ++rechit) { DTWireId wireid = (*rechit).wireId(); mapOfRecHit[wireid].push_back(*rechit); } if (mapOfSimHit.end() != mapOfSimHit.begin()) { edm::LogVerbatim("DTHitAssociator")<<"\n *** Dump DT PSimHit's ***"; int jwire = 0; int ihit = 0; for(SimHitMap::const_iterator mapIT=mapOfSimHit.begin(); mapIT!=mapOfSimHit.end(); ++mapIT , jwire++) { DTWireId wireid = (*mapIT).first; for (vector<PSimHit_withFlag>::const_iterator hitIT = mapOfSimHit[wireid].begin(); hitIT != mapOfSimHit[wireid].end(); hitIT++ , ihit++) { PSimHit hit = hitIT->first; edm::LogVerbatim("DTHitAssociator") <<"PSimHit "<<ihit <<", wire "<<wireid //<<", detID = "<<hit.detUnitId() <<", SimTrack Id:"<<hit.trackId()<<"/Evt:(" <<hit.eventId().event()<<","<<hit.eventId().bunchCrossing()<<") " <<", pdg = "<<hit.particleType()<<", procs = "<<hit.processType(); } } } else { edm::LogVerbatim("DTHitAssociator")<<"\n *** There are NO DT PSimHit's ***"; } if(mapOfDigi.end() != mapOfDigi.begin()) { int jwire = 0; int ihit = 0; for(DigiMap::const_iterator mapIT=mapOfDigi.begin(); mapIT!=mapOfDigi.end(); ++mapIT , jwire++) { edm::LogVerbatim("DTHitAssociator")<<"\n *** Dump DT digis ***"; DTWireId wireid = (*mapIT).first; for (vector<DTDigi>::const_iterator hitIT = mapOfDigi[wireid].begin(); hitIT != mapOfDigi[wireid].end(); hitIT++ , ihit++) { edm::LogVerbatim("DTHitAssociator") <<"DTDigi "<<ihit<<", wire "<<wireid<<", number = "<<hitIT->number()<<", TDC counts = "<<hitIT->countsTDC(); } } } else { LogTrace("DTHitAssociator")<<"\n *** There are NO DTDigi's ***"; } if (mapOfRecHit.end() != mapOfRecHit.begin()) edm::LogVerbatim("DTHitAssociator")<<"\n *** Analyze DTRecHitCollection by DTWireId ***"; int iwire = 0; for(RecHitMap::const_iterator mapIT=mapOfRecHit.begin(); mapIT!=mapOfRecHit.end(); ++mapIT , iwire++) { DTWireId wireid = (*mapIT).first; edm::LogVerbatim("DTHitAssociator")<<"\n==================================================================="; edm::LogVerbatim("DTHitAssociator")<<"wire index = "<<iwire<<" *** DTWireId = "<<" ("<<wireid<<")"; if(mapOfSimHit.find(wireid) != mapOfSimHit.end()) { edm::LogVerbatim("DTHitAssociator")<<"\n"<<mapOfSimHit[wireid].size()<<" SimHits (PSimHit):"; for (vector<PSimHit_withFlag>::const_iterator hitIT = mapOfSimHit[wireid].begin(); hitIT != mapOfSimHit[wireid].end(); ++hitIT) { stringstream tId; tId << (hitIT->first).trackId(); string simhitlog = "\t SimTrack Id = "+tId.str(); if (hitIT->second) simhitlog = simhitlog + "\t -VALID HIT-"; else simhitlog = simhitlog + "\t -not valid hit-"; edm::LogVerbatim("DTHitAssociator")<<simhitlog; } } if(mapOfLinks.find(wireid) != mapOfLinks.end()) { edm::LogVerbatim("DTHitAssociator")<<"\n"<<mapOfLinks[wireid].size()<<" Links (DTDigiSimLink):"; for (vector<DTDigiSimLink>::const_iterator hitIT = mapOfLinks[wireid].begin(); hitIT != mapOfLinks[wireid].end(); ++hitIT) { edm::LogVerbatim("DTHitAssociator") <<"\t digi number = "<<hitIT->number()<<", time = "<<hitIT->time()<<", SimTrackId = "<<hitIT->SimTrackId(); } } if(mapOfDigi.find(wireid) != mapOfDigi.end()) { edm::LogVerbatim("DTHitAssociator")<<"\n"<<mapOfDigi[wireid].size()<<" Digis (DTDigi):"; for (vector<DTDigi>::const_iterator hitIT = mapOfDigi[wireid].begin(); hitIT != mapOfDigi[wireid].end(); ++hitIT) { edm::LogVerbatim("DTHitAssociator")<<"\t digi number = "<<hitIT->number()<<", time = "<<hitIT->time(); } } edm::LogVerbatim("DTHitAssociator")<<"\n"<<(*mapIT).second.size()<<" RecHits (DTRecHit1DPair):"; for(vector<DTRecHit1DPair>::const_iterator vIT =(*mapIT).second.begin(); vIT !=(*mapIT).second.end(); ++vIT) { edm::LogVerbatim("DTHitAssociator")<<"\t digi time = "<<vIT->digiTime(); } } } }
virtual DTHitAssociator::~DTHitAssociator | ( | ) | [inline, virtual] |
Definition at line 32 of file DTHitAssociator.h.
{}
std::vector< DTHitAssociator::SimHitIdpr > DTHitAssociator::associateDTHitId | ( | const DTRecHit1D * | dtrechit | ) |
Definition at line 259 of file DTHitAssociator.cc.
References associatorByWire, begin, DTRecHit1D::digiTime(), PSimHit::eventId(), mapOfLinks, mapOfSimHit, PSimHit::trackId(), and DTRecHit1D::wireId().
Referenced by associateHit(), associateHitId(), and MuonAssociatorByHits::getMatchedIds().
{ std::vector<SimHitIdpr> matched; DTWireId wireid = dtrechit->wireId(); if(associatorByWire) { // matching based on DTWireId : take only "valid" SimHits on that wire if(mapOfSimHit.find(wireid) != mapOfSimHit.end()) { for (vector<PSimHit_withFlag>::const_iterator hitIT = mapOfSimHit[wireid].begin(); hitIT != mapOfSimHit[wireid].end(); ++hitIT) { bool valid_hit = hitIT->second; PSimHit this_hit = hitIT->first; if (valid_hit) { SimHitIdpr currentId(this_hit.trackId(), this_hit.eventId()); matched.push_back(currentId); } } } } else { // matching based on DTDigiSimLink float theTime = dtrechit->digiTime(); int theNumber(-1); if (mapOfLinks.find(wireid) != mapOfLinks.end()) { // DTDigiSimLink::time() is set equal to DTDigi::time() only for the DTDigiSimLink corresponding to the digitizied PSimHit // other DTDigiSimLinks associated to the same DTDigi are identified by having the same DTDigiSimLink::number() // first find the associated digi Number for (vector<DTDigiSimLink>::const_iterator linkIT = mapOfLinks[wireid].begin(); linkIT != mapOfLinks[wireid].end(); ++linkIT ) { float digitime = linkIT->time(); if (fabs(digitime-theTime)<0.1) { theNumber = linkIT->number(); } } // then get all the DTDigiSimLinks with that digi Number (corresponding to valid SimHits // within a time window of the order of the time resolution, specified in the DTDigitizer) for (vector<DTDigiSimLink>::const_iterator linkIT = mapOfLinks[wireid].begin(); linkIT != mapOfLinks[wireid].end(); ++linkIT ) { int digiNr = linkIT->number(); if (digiNr == theNumber) { SimHitIdpr currentId(linkIT->SimTrackId(), linkIT->eventId()); matched.push_back(currentId); } } } else { edm::LogError("DTHitAssociator")<<"*** ERROR in DTHitAssociator::associateDTHitId - DTRecHit1D: " <<*dtrechit<<" has no associated DTDigiSimLink !"<<endl; return matched; } } return matched; }
std::vector< PSimHit > DTHitAssociator::associateHit | ( | const TrackingRecHit & | hit | ) |
Definition at line 327 of file DTHitAssociator.cc.
References associateDTHitId(), associatorByWire, begin, mapOfSimHit, and DTRecHit1D::wireId().
Referenced by MuonAssociatorByHits::getMatchedIds().
{ std::vector<PSimHit> simhits; std::vector<SimHitIdpr> simtrackids; const TrackingRecHit * hitp = &hit; const DTRecHit1D * dtrechit = dynamic_cast<const DTRecHit1D *>(hitp); if (dtrechit) { DTWireId wireid = dtrechit->wireId(); if (associatorByWire) { // matching based on DTWireId : take only "valid" SimHits on that wire if(mapOfSimHit.find(wireid) != mapOfSimHit.end()) { for (vector<PSimHit_withFlag>::const_iterator hitIT = mapOfSimHit[wireid].begin(); hitIT != mapOfSimHit[wireid].end(); ++hitIT) { bool valid_hit = hitIT->second; if (valid_hit) simhits.push_back(hitIT->first); } } } else { // matching based on DTDigiSimLink simtrackids = associateDTHitId(dtrechit); for (vector<SimHitIdpr>::const_iterator idIT = simtrackids.begin(); idIT != simtrackids.end(); ++idIT) { uint32_t trId = idIT->first; EncodedEventId evId = idIT->second; if(mapOfSimHit.find(wireid) != mapOfSimHit.end()) { for (vector<PSimHit_withFlag>::const_iterator hitIT = mapOfSimHit[wireid].begin(); hitIT != mapOfSimHit[wireid].end(); ++hitIT) { if (hitIT->first.trackId() == trId && hitIT->first.eventId() == evId) simhits.push_back(hitIT->first); } } } } } else { edm::LogWarning("DTHitAssociator")<<"*** WARNING in DTHitAssociator::associateHit, null dynamic_cast !"; } return simhits; }
std::vector< DTHitAssociator::SimHitIdpr > DTHitAssociator::associateHitId | ( | const TrackingRecHit & | hit | ) |
Definition at line 245 of file DTHitAssociator.cc.
References associateDTHitId().
{ std::vector<SimHitIdpr> simtrackids; const TrackingRecHit * hitp = &hit; const DTRecHit1D * dtrechit = dynamic_cast<const DTRecHit1D *>(hitp); if (dtrechit) { simtrackids = associateDTHitId(dtrechit); } else { edm::LogWarning("DTHitAssociator")<<"*** WARNING in DTHitAssociator::associateHitId, null dynamic_cast !"; } return simtrackids; }
bool DTHitAssociator::SimHitOK | ( | const edm::ESHandle< DTGeometry > & | muongeom, |
const PSimHit & | simhit | ||
) | [private] |
Definition at line 379 of file DTHitAssociator.cc.
References PSimHit::detUnitId(), PSimHit::entryPoint(), PSimHit::exitPoint(), PSimHit::localPosition(), none, DTTopology::none, DTTopology::onWhichBorder(), query::result, DTTopology::wirePosition(), PV3DBase< T, PVType, FrameType >::x(), x, DTTopology::xMax, DTTopology::xMin, PV3DBase< T, PVType, FrameType >::y(), and PV3DBase< T, PVType, FrameType >::z().
Referenced by DTHitAssociator().
{ bool result = true; DTWireId wireid(simhit.detUnitId()); const DTLayer* dtlayer = muongeom->layer(wireid.layerId()); LocalPoint entryP = simhit.entryPoint(); LocalPoint exitP = simhit.exitPoint(); const DTTopology &topo = dtlayer->specificTopology(); float xwire = topo.wirePosition(wireid.wire()); float xEntry = entryP.x() - xwire; float xExit = exitP.x() - xwire; DTTopology::Side entrySide = topo.onWhichBorder(xEntry,entryP.y(),entryP.z()); DTTopology::Side exitSide = topo.onWhichBorder(xExit,exitP.y(),exitP.z()); bool noParametrisation = (( entrySide == DTTopology::none || exitSide == DTTopology::none ) || (entrySide == exitSide) || ((entrySide == DTTopology::xMin && exitSide == DTTopology::xMax) || (entrySide == DTTopology::xMax && exitSide == DTTopology::xMin)) ); // discard hits where parametrization can not be used if (noParametrisation) { result = false; return result; } float x; LocalPoint hitPos = simhit.localPosition(); if(fabs(hitPos.z()) < 0.002) { // hit center within 20 um from z=0, no need to extrapolate. x = hitPos.x() - xwire; } else { x = xEntry - (entryP.z()*(xExit-xEntry))/(exitP.z()-entryP.z()); } // discard hits where x is out of range of the parametrization (|x|>2.1 cm) x *= 10.; //cm -> mm if (fabs(x) > 21.) result = false; return result; }
bool DTHitAssociator::associatorByWire [private] |
Definition at line 54 of file DTHitAssociator.h.
Referenced by associateDTHitId(), associateHit(), and DTHitAssociator().
bool DTHitAssociator::crossingframe [private] |
Definition at line 52 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
Definition at line 48 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
edm::InputTag DTHitAssociator::DTdigiTag [private] |
Definition at line 47 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
edm::InputTag DTHitAssociator::DTrechitTag [private] |
Definition at line 49 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
edm::InputTag DTHitAssociator::DTsimhitsTag [private] |
Definition at line 45 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
edm::InputTag DTHitAssociator::DTsimhitsXFTag [private] |
Definition at line 46 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
bool DTHitAssociator::dumpDT [private] |
Definition at line 51 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
bool DTHitAssociator::links_exist [private] |
Definition at line 53 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
Definition at line 41 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
Definition at line 42 of file DTHitAssociator.h.
Referenced by associateDTHitId(), and DTHitAssociator().
Definition at line 40 of file DTHitAssociator.h.
Referenced by DTHitAssociator().
Definition at line 39 of file DTHitAssociator.h.
Referenced by associateDTHitId(), associateHit(), and DTHitAssociator().
bool DTHitAssociator::printRtS [private] |
Definition at line 57 of file DTHitAssociator.h.