47 trackerHitAssociatorConfig_(ps, consumesCollector()),
438 edm::LogInfo(
"SiStripRecHitsValid") <<
"SiStripRecHitsValid::beginRun: " 439 <<
" Creating MEs for new Cabling ";
464 int isrechitrphi = 0;
466 int isrechitmatched = 0;
485 tracker2 = &(*estracker);
501 edm::LogVerbatim(
"TrajectoryAnalyzer") <<
"trackColl->size(): " << trackCollectionHandle->size();
502 auto const &
tracks = *trackCollectionHandle;
505 if (
track.pt()<0.5)
continue;
508 auto const & trajParams =
track.extra()->trajParams();
509 assert(trajParams.size()==
track.recHitsSize());
510 auto hb =
track.recHitsBegin();
511 for(
unsigned int h=0;
h<
track.recHitsSize();
h++){
513 if(!
recHit->isValid())
continue;
514 auto ldir = trajParams[
h].direction();
515 auto gmom =
recHit->surface()->toGlobal(trajParams[
h].momentum());
516 if (gmom.perp() < 0.5)
continue;
520 DetId detid2 = thit2->geographicalId();
527 detid = (thit)->geographicalId();
528 myid = detid.
rawId();
552 std::map<std::string, StereoAndMatchedMEs>::iterator iStereoAndMatchedME =
StereoAndMatchedMEsMap.find(label);
556 if (isrechitmatched) {
578 if (gmom.transverse() != 0) {
585 auto hm = matchedhit->
monoHit();
614 if (StripSubdet.
stereo()) {
640 if (StripSubdet.
stereo()) {
649 rechitanalysis(ldir, thit2, stripdet, stripcpe, associate,
false);
659 rechitanalysis(ldir, thit2, stripdet, stripcpe, associate,
false);
669 std::map<std::string, LayerMEs>::iterator iLayerME =
LayerMEsMap.find(label);
801 if (isrechitsas > 0) {
895 LocalPoint localHit = plane.toLocal(globalpos);
902 float scale = -localHit.
z() / dir.
z();
914 return std::pair < LocalPoint, LocalVector > (projectedPos, localStripDir);
934 auto hm = matchedhit->
monoHit();
962 position = monohit->localPosition();
963 error = monohit->localPositionError();
970 clust = monohit->cluster();
976 if (stereotkdir.
z()) {
987 float tanalphaL = drift.
x() / drift.
z();
994 const auto & amplitudes=clust->amplitudes();
997 for(
size_t ia=0; ia<amplitudes.size();++ia){
998 totcharge+=amplitudes[ia];
1029 std::pair<LocalPoint,LocalVector> closestPair;
1033 std::pair<LocalPoint,LocalVector> hitPair;
1039 distx = fabs(
rechitpro.
x - hitPair.first.x());
1040 disty = fabs(
rechitpro.
y - hitPair.first.y());
1041 dist =
sqrt(distx*distx+disty*disty);
1044 closestPair = hitPair;
1048 float closestX = closestPair.first.x();
1049 float closestY = closestPair.first.y();
1057 dist =
abs((monohit)->localPosition().
x() -
m.localPosition().x());
1060 closestPair = hitPair;
1072 dist =
abs((stereohit)->localPosition().
x() -
m.localPosition().x());
1075 closestPair = hitPair;
1110 float pitch = topol.localPitch(position);
1112 float tanalphaL = drift.
x() / drift.
z();
1122 clust1d = hit1d->cluster();
1123 const auto & amplitudes1d = clust1d->amplitudes();
1125 for(
size_t ia=0; ia<amplitudes1d.size();++ia){
1126 totcharge+=amplitudes1d[ia];
1131 const auto & amplitudes2d = clust2d->amplitudes();
1133 for(
size_t ia=0; ia<amplitudes2d.size();++ia){
1134 totcharge+=amplitudes2d[ia];
1166 dist =
abs((hit1d)->localPosition().
x() -
m.localPosition().x());
1182 dist =
abs((hit2d)->localPosition().
x() -
m.localPosition().x());
1208 std::vector<uint32_t> activeDets;
1224 edm::LogInfo(
"SiStripTrackingRecHitsValid|SiStripTrackingRecHitsValid")<<
"nr. of activeDets: "<<activeDets.size();
1225 const std::string& tec =
"TEC", tid =
"TID", tob =
"TOB", tib =
"TIB";
1226 for(std::vector<uint32_t>::iterator detid_iterator = activeDets.begin(), detid_end = activeDets.end(); detid_iterator!=detid_end; ++detid_iterator){
1227 uint32_t detid = (*detid_iterator);
1230 activeDets.erase(detid_iterator);
1235 std::pair<std::string,int32_t> det_layer_pair = folder_organizer.
GetSubDetAndLayer(detid,tTopo,
true);
1240 std::map<std::string, LayerMEs>::iterator iLayerME =
LayerMEsMap.find(label);
1245 int32_t lnumber = det_layer_pair.second;
1247 std::vector<uint32_t> layerDetIds;
1248 if (lname.compare(tec) == 0) {
1251 }
else if (lnumber < 0) {
1254 }
else if (lname.compare(tid) == 0) {
1257 }
else if (lnumber < 0) {
1260 }
else if (lname.compare(tob) == 0) {
1262 }
else if (lname.compare(tib) == 0) {
1268 folder_organizer.
setLayerFolder(detid,tTopo,det_layer_pair.second,
true);
1276 std::map<std::string, StereoAndMatchedMEs>::iterator iStereoAndMatchedME =
StereoAndMatchedMEsMap.find(label);
1280 bool isStereo =
false;
1282 std::vector<uint32_t> stereoandmatchedDetIds;
1283 int32_t stereolnumber = det_layer_pair.second;
1284 const std::string& stereolname = det_layer_pair.first;
1285 if ( stereolname.compare(tec) == 0 && (tTopo->
tecIsStereo(detid)) ) {
1286 if ( stereolnumber > 0 ) {
1287 substructure.
getTECDetectors(activeDets,stereoandmatchedDetIds,2,0,0,0,
abs(stereolnumber),1);
1289 }
else if ( stereolnumber < 0 ) {
1290 substructure.
getTECDetectors(activeDets,stereoandmatchedDetIds,1,0,0,0,
abs(stereolnumber),1);
1293 }
else if ( stereolname.compare(tid) == 0 && (tTopo->
tidIsStereo(detid)) ) {
1294 if ( stereolnumber > 0 ) {
1295 substructure.
getTIDDetectors(activeDets,stereoandmatchedDetIds,2,0,
abs(stereolnumber),1);
1297 }
else if ( stereolnumber < 0 ) {
1298 substructure.
getTIDDetectors(activeDets,stereoandmatchedDetIds,1,0,
abs(stereolnumber),1);
1301 }
else if ( stereolname.compare(tob) == 0 && (tTopo->
tobIsStereo(detid)) ) {
1302 substructure.
getTOBDetectors(activeDets,stereoandmatchedDetIds,stereolnumber,0,0);
1304 }
else if ( stereolname.compare(tib) == 0 && (tTopo->
tibIsStereo(detid)) ) {
1305 substructure.
getTIBDetectors(activeDets,stereoandmatchedDetIds,stereolnumber,0,0,0);
1313 folder_organizer.
setLayerFolder(detid,tTopo,det_layer_pair.second,
true);
1574 layerMEs.
meWclusRphi =
bookME1D(ibooker,
"TH1WclusRphi", hidmanager.
createHistoLayer(
"Wclus_rphi",
"layer",label,
"").c_str() ,
"Cluster Width - Number of strips that belong to the RecHit cluster");
1904 stereoandmatchedMEs.
meWclusSas =
bookME1D(ibooker,
"TH1WclusSas", hidmanager.
createHistoLayer(
"Wclus_sas",
"layer",label,
"").c_str() ,
"Cluster Width - Number of strips that belong to the RecHit cluster");
1910 stereoandmatchedMEs.
meAdcSas->
setAxisTitle((
"cluster charge [ADC] (stereo) in " + label).c_str());
1920 stereoandmatchedMEs.
meResolxMFSas->
setAxisTitle((
"resol(x) RecHit coord. (measurement frame) (stereo) in " + label).c_str());
1924 stereoandmatchedMEs.
meResLFSas =
bookME1D(ibooker,
"TH1ResLFSas", hidmanager.
createHistoLayer(
"Res_LF_sas",
"layer",label,
"").c_str() ,
"Residual of the hit x coordinate");
1925 stereoandmatchedMEs.
meResLFSas->
setAxisTitle((
"Hit Residuals(x) (local frame) (stereo) in " + label).c_str());
1929 stereoandmatchedMEs.
meResMFSas =
bookME1D(ibooker,
"TH1ResMFSas", hidmanager.
createHistoLayer(
"Res_MF_sas",
"layer",label,
"").c_str() ,
"Residual of the hit x coordinate");
1935 stereoandmatchedMEs.
mePullLFSas->
setAxisTitle((
"Pull distribution (local frame) (stereo) in " + label).c_str());
1940 stereoandmatchedMEs.
mePullMFSas->
setAxisTitle((
"Pull distribution (measurement frame) (stereo) in " + label).c_str());
2070 return ibooker.
book1D(HistoName,HistoTitle,
MonitorElement * mePullTrackwidthProfileRphiwclus3
bool layerswitchPullTrackwidthProfileCategory1Sas
GlobalPoint toGlobal(const Point2DBase< Scalar, LocalTag > lp) const
MonitorElement * meResMFTrackwidthProfileWClus23
bool layerswitchResolxMFRphiwclus1
bool layerswitchResyMatched
T getParameter(std::string const &) const
SiStripTrackingRecHitsValid(const edm::ParameterSet &conf)
EventNumber_t event() const
MonitorElement * meResolxLFRphi
const TrackerGeomDet * idToDetUnit(DetId) const
Return the pointer to the GeomDetUnit corresponding to a given DetId.
MonitorElement * meResolxMFClusterwidthProfileCategory1Sas
edm::ESHandle< SiStripDetCabling > SiStripDetCabling_
~SiStripTrackingRecHitsValid()
void rechitanalysis_matched(LocalVector ldir, const TrackingRecHit *rechit, const GluedGeomDet *gluedDet, TrackerHitAssociator &associate, edm::ESHandle< StripClusterParameterEstimator > stripcpe, const MatchStatus matchedmonorstereo)
MonitorElement * meResMFTrackwidthProfileWclus1Rphi
bool layerswitchResMFTrackwidthProfileWclus4Rphi
bool layerswitchrapidityResProfilewclus2
MonitorElement * mePullTrackwidthProfileRphiwclus1
MonitorElement * meAdcRphi
bool layerswitchResolxMFTrackwidthProfileCategory3Rphi
MonitorElement * meResolxMFTrackwidthProfile
bool layerswitchPullyMatched
MonitorElement * meResMFTrackwidthProfileWClus2
MonitorElement * meResMFTrackwidthProfileWClus4
void addActiveDetectorsRawIds(std::vector< uint32_t > &) const
void setSiStripFolderName(std::string name)
MonitorElement * meResolxMFTrackwidthProfileWClus3
bool layerswitchResolxMFTrackwidthProfileCategory3Sas
bool layerswitchResolxMFTrackwidthProfileWclus3Rphi
bool layerswitchPullMFRphiwclus2
bool layerswitchResolxMFTrackwidthProfile
bool layerswitchClusterwidth
const GeomDetUnit * monoDet() const
FWCore Framework interface EventSetupRecordImplementation h
Helper function to determine trigger accepts.
MonitorElement * mePullMFRphi
std::map< std::string, StereoAndMatchedMEs > StereoAndMatchedMEsMap
bool layerswitchResolxMatched
bool tobIsStereo(const DetId &id) const
MonitorElement * meResolxMFSas
MonitorElement * meResolxMFRphiwclus4
MonitorElement * bookME1D(DQMStore::IBooker &ibooker, const char *ParameterSetLabel, const char *HistoName, const char *HistoTitle)
MonitorElement * bookProfile(Args &&...args)
bool layerswitchResMFTrackwidthProfile_WClus22
MonitorElement * meResolxMFTrackwidthProfileCategory1
MonitorElement * meResolxMFTrackwidthProfileWclus2Rphi
bool getByToken(EDGetToken token, Handle< PROD > &result) const
bool layerswitchResMFRphiwclus4
MonitorElement * meTrackwidthRphi
bool layerswitchResolxMFTrackwidthProfileWclus1Rphi
void fillME(MonitorElement *ME, float value1)
MonitorElement * meResolxMFTrackwidthProfileWclus3Rphi
MonitorElement * merapidityResProfilewclus1
MonitorElement * meResolxMFRphiwclus2
bool layerswitchPullTrackwidthProfileRphi
bool layerswitchPullTrackwidthProfileCategory2Sas
bool layerswitchResolxMFRphi
bool layerswitchResolxMFSas
bool layerswitchPullMFSas
bool layerswitchPullTrackwidthProfileCategory2Rphi
GlobalPoint toGlobal(const Local2DPoint &lp) const
Conversion to the global R.F. from the R.F. of the GeomDet.
bool layerswitchResolxLFRphi
MonitorElement * mePullMFRphiwclus4
Sin< T >::type sin(const T &t)
MonitorElement * meResMFRphiwclus4
bool layerswitchPullTrackwidthProfileRphiwclus3
RecHitProperties rechitpro
bool layerswitchResolxMFTrackwidthProfileWclus2Rphi
MonitorElement * meResyMatched
LocalVector drift(const StripGeomDetUnit *, const MagneticField &, const SiStripLorentzAngle &)
MonitorElement * meResMFRphiwclus3
bool layerswitchPullTrackangle2DRphi
MonitorElement * meTrackwidthSas
bool layerswitchExpectedwidthSas
bool layerswitchCategoryRphi
std::map< std::string, LayerMEs > LayerMEsMap
bool layerswitchResolxMFClusterwidthProfileCategory1Rphi
MonitorElement * meCategory
virtual float strip(const LocalPoint &) const =0
bool layerswitchExpectedwidth
LocalPoint toLocal(const GlobalPoint &gp) const
Conversion to the R.F. of the GeomDet.
bool layerswitchResolxMFAngleProfile
MonitorElement * mePullTrackwidthProfileCategory1Sas
std::pair< std::string, int32_t > GetSubDetAndLayer(const uint32_t &detid, const TrackerTopology *tTopo, bool ring_flag=0)
bool layerswitchResMFTrackwidthProfileWclus3Rphi
const Bounds & bounds() const
MonitorElement * meTrackanglebetaRphi
MonitorElement * mePullLFRphi
MonitorElement * mePullTrackwidthProfileSas
bool layerswitchrapidityResProfilewclus4
bool layerswitchWclusRphi
bool layerswitchPullTrackwidthProfileSas
void createLayerMEs(DQMStore::IBooker &ibooker, std::string label)
MonitorElement * meExpectedwidthSas
bool layerswitchResxMatched
bool layerswitchPullMFRphiwclus3
bool layerswitchResolxMFTrackwidthProfileSas
bool layerswitchResLFRphi
MonitorElement * meResolxMFTrackwidthProfileCategory3Sas
virtual const StripTopology & specificTopology() const
Returns a reference to the strip proxy topology.
MonitorElement * mePullLFSas
bool layerswitchResolxMFTrackwidthProfile_WClus2
MonitorElement * meResolxMFAngleProfileRphi
bool layerswitchPosyMatched
MonitorElement * meResolxMFAngleProfile
bool layerswitchPullLFRphi
const Plane & surface() const
The nominal surface of the GeomDet.
bool layerswitchResMFTrackwidthProfileWclus2Rphi
bool layerswitchResolxMFTrackwidthProfile_Category3
bool layerswitchResolxMFTrackwidthProfileWclus4Rphi
MonitorElement * mePullTrackwidthProfileCategory2Rphi
unsigned long long m_cacheID_
bool tidIsStereo(const DetId &id) const
MonitorElement * meResolxMFTrackwidthProfileCategory2
bool layerswitchResolxMFClusterwidthProfileCategory1Sas
MonitorElement * meResolxMFAngleProfileSas
MonitorElement * meResMFSas
uint32_t rawId() const
get the raw id
MonitorElement * meExpectedwidthRphi
MonitorElement * mePullMFSas
bool layerswitchTrackanglebeta
MonitorElement * meResMFTrackwidthProfileWclus4Rphi
MonitorElement * meWclusSas
bool tecIsStereo(const DetId &id) const
MonitorElement * meResMFTrackwidthProfileWClus3
bool layerswitchResMFTrackwidthProfile_WClus4
const MagneticField * magfield2_
MonitorElement * meClusterwidth
bool layerswitchTrackangleRphi
bool layerswitchTrackangleSas
void createSimpleHitsMEs(DQMStore::IBooker &ibooker)
bool layerswitchResMFRphiwclus2
MonitorElement * merapidityResProfilewclus3
MonitorElement * mePullTrackwidthProfileCategory2Sas
bool layerswitchResolxMFTrackwidthProfile_WClus3
vector< ParameterSet > Parameters
MonitorElement * meResolxMFTrackwidthProfileWclus1Rphi
bool layerswitchResolxMFTrackwidthProfile_Category2
MonitorElement * meResolxMFTrackwidthProfileWclus4Rphi
bool layerswitchResolxMFTrackwidthProfileCategory1Rphi
bool layerswitchResMFTrackwidthProfile_WClus1
void getTOBDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tobDetRawIds, uint32_t layer=0, uint32_t bkw_frw=0, uint32_t rod=0) const
Local3DPoint localPosition() const
bool layerswitchResolxMFRphiwclus2
MonitorElement * meTrackwidth
virtual float stripAngle(float strip) const =0
bool layerswitchResolyMatched
MonitorElement * meResolxMFRphi
MonitorElement * meCategoryRphi
void bookHistograms(DQMStore::IBooker &ibooker, const edm::Run &run, const edm::EventSetup &es)
SimpleHitsMEs simplehitsMEs
MonitorElement * meResolxMFTrackwidthProfileCategory2Rphi
MonitorElement * mePullMFRphiwclus1
Cos< T >::type cos(const T &t)
bool layerswitchClusterwidthSas
bool layerswitchCategorySas
virtual MeasurementPoint measurementPosition(const LocalPoint &) const =0
bool layerswitchPullTrackwidthProfileCategory1Rphi
MonitorElement * meResolxMatched
bool layerswitchPullMFRphiwclus1
MonitorElement * mePullTrackwidthProfileRphiwclus2
MonitorElement * book1D(Args &&...args)
std::string outputFileName
bool layerswitchResolxMFAngleProfileSas
Tan< T >::type tan(const T &t)
TrackerHitAssociator::Config trackerHitAssociatorConfig_
Abs< T >::type abs(const T &t)
MonitorElement * meAdcSas
bool layerswitchExpectedwidthRphi
MonitorElement * meResMFTrackwidthProfileWClus1
MonitorElement * meResolxMFTrackwidthProfileCategory1Sas
edm::EDGetTokenT< std::vector< reco::Track > > tracksInputToken_
bool layerswitchResolxMFClusterwidthProfile_Category1
bool layerswitchTrackangle2Rphi
ClusterRef cluster() const
MonitorElement * meResMFTrackwidthProfileWClus22
MonitorElement * meResolxMF
bool layerswitchResolxMFTrackwidthProfile_Category4
MonitorElement * meTrackangleSas
virtual LocalPoint localPosition() const final
MonitorElement * meResMFRphiwclus2
virtual void analyze(const edm::Event &e, const edm::EventSetup &c)
bool layerswitchTrackwidth
std::string getSubdetid(uint32_t id, const TrackerTopology *tTopo, bool flag_ring)
virtual LocalPoint localPosition() const =0
MonitorElement * mePullTrackwidthProfileCategory1Rphi
int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum) ...
MonitorElement * mePullTrackwidthProfileCategory4Rphi
MonitorElement * meResolxMFTrackwidthProfileWClus2
bool layerswitchrapidityResProfilewclus3
std::string topFolderName_
MonitorElement * meResLFSas
void createMEs(DQMStore::IBooker &ibooker, const edm::EventSetup &es)
bool layerswitchPullTrackwidthProfileCategory3Sas
MonitorElement * mePullxMatched
std::pair< LocalPoint, LocalVector > projectHit(const PSimHit &hit, const StripGeomDetUnit *stripDet, const BoundPlane &plane)
std::vector< PSimHit > matched
MonitorElement * meResMFTrackwidthProfileWclus2Rphi
MonitorElement * bookMEProfile(DQMStore::IBooker &ibooker, const char *ParameterSetLabel, const char *HistoName, const char *HistoTitle)
MonitorElement * meResolxLF
MonitorElement * meResolxMFTrackwidthProfileCategory4
MonitorElement * meWclusRphi
bool layerswitchPullLFSas
bool layerswitchPullTrackwidthProfileRphiwclus4
LocalVector localDirection() const
Obsolete. Same as momentumAtEntry().unit(), for backward compatibility.
bool layerswitchClusterwidthRphi
MonitorElement * meTrackanglealpha
bool layerswitchTrackwidthRphi
bool layerswitchResolxMFTrackwidthProfileCategory2Sas
virtual const Topology & topology() const override
Returns a reference to the strip proxy topology.
MonitorElement * mePullTrackwidthProfileCategory3Sas
unsigned int stereo() const
stereo
MonitorElement * meTrackanglebetaSas
MonitorElement * mePullMF
bool layerswitchPullTrackwidthProfileCategory4Sas
void setLayerFolder(uint32_t rawdetid, const TrackerTopology *tTopo, int32_t layer=0, bool ring_flag=0)
SiStripRecHit2D stereoHit() const
MonitorElement * meResolxMFTrackwidthProfileCategory2Sas
MonitorElement * mePosxMatched
bool layerswitchPullMFRphiwclus4
MonitorElement * meClusterwidthRphi
virtual float thickness() const =0
MonitorElement * meResxMatched
MonitorElement * meResolxMFTrackwidthProfileRphi
bool layerswitchResolxMFTrackwidthProfile_WClus4
MonitorElement * meResolyMatched
bool layerswitchResolxMFRphiwclus3
bool layerswitchPullxMatched
MonitorElement * mePullTrackangle2DRphi
MonitorElement * meResolxMFTrackwidthProfileCategory3Rphi
bool layerswitchPullTrackangleProfileRphi
MonitorElement * mePullTrackwidthProfileCategory4Sas
MonitorElement * mePullMFRphiwclus3
bool tibIsStereo(const DetId &id) const
MonitorElement * meResLFRphi
bool layerswitchResolxMFTrackwidthProfileCategory4Rphi
bool layerswitchPullTrackwidthProfileCategory4Rphi
void createStereoAndMatchedMEs(DQMStore::IBooker &ibooker, std::string label)
MonitorElement * meResolxMFTrackwidthProfileWClus1
bool layerswitchResMFRphiwclus1
bool layerswitchPullTrackwidthProfileRphiwclus1
MonitorElement * meResolxMFTrackwidthProfileCategory4Sas
bool layerswitchResolxMFTrackwidthProfileCategory2Rphi
MonitorElement * mePullyMatched
MonitorElement * mePullTrackangleProfileRphi
virtual float localPitch(const LocalPoint &) const =0
MonitorElement * meCategorySas
bool layerswitchResolxMFTrackwidthProfileCategory4Sas
MonitorElement * mePullTrackwidthProfileCategory3Rphi
void getTECDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tecDetRawIds, uint32_t side=0, uint32_t wheel=0, uint32_t petal_bkw_frw=0, uint32_t petal=0, uint32_t ring=0, uint32_t ster=0) const
MonitorElement * meResMFRphiwclus1
SiStripRecHit2D monoHit() const
bool layerswitchResMFTrackwidthProfile_WClus23
void rechitanalysis(LocalVector ldir, const TrackingRecHit *rechit, const StripGeomDetUnit *stripdet, edm::ESHandle< StripClusterParameterEstimator > stripcpe, TrackerHitAssociator &associate, bool simplehit1or2D)
bool layerswitchResMFTrackwidthProfile_WClus3
bool layerswitchResMFTrackwidthProfile_WClus2
MonitorElement * meExpectedwidth
bool layerswitchResMFRphi
MonitorElement * meResMFTrackwidthProfileWclus3Rphi
MonitorElement * mePullTrackwidthProfileRphi
MonitorElement * meResolxMFTrackwidthProfileCategory3
bool layerswitchResolxMFTrackwidthProfileRphi
MonitorElement * meResolxMFRphiwclus1
static int position[264][3]
MonitorElement * merapidityResProfilewclus2
void getTIBDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tibDetRawIds, uint32_t layer=0, uint32_t bkw_frw=0, uint32_t int_ext=0, uint32_t string=0) const
MonitorElement * meResolxMFTrackwidthProfileWClus4
bool layerswitchResolx_LF
MonitorElement * meResolxMFTrackwidthProfileSas
bool layerswitchResolx_MF
std::vector< PSimHit > associateHit(const TrackingRecHit &thit) const
MonitorElement * meTrackangleRphi
virtual LocalVector driftDirection(const StripGeomDetUnit *) const =0
std::map< std::string, std::vector< uint32_t > > StereoAndMatchedDetMap
bool layerswitchTrackanglealpha
void getTIDDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tidDetRawIds, uint32_t side=0, uint32_t wheel=0, uint32_t ring=0, uint32_t ster=0) const
bool layerswitchrapidityResProfilewclus1
MonitorElement * merapidityResProfilewclus4
DetId geographicalId() const
bool layerswitchPullTrackangleProfileSas
MonitorElement * meResolxMFTrackwidthProfileCategory1Rphi
virtual LocalError localPositionError() const =0
std::string createHistoLayer(std::string description, std::string id_type, std::string path, std::string flag)
bool layerswitchResolxMFTrackwidthProfile_Category1
virtual MeasurementError measurementError(const LocalPoint &, const LocalError &) const =0
bool layerswitchResolxMFAngleProfileRphi
MonitorElement * meResMFRphi
virtual LocalError localPositionError() const final
MonitorElement * mePullTrackwidthProfileRphiwclus4
MonitorElement * meResolxMFClusterwidthProfileCategory1
std::map< std::string, std::vector< uint32_t > > LayerDetMap
MonitorElement * meTrackangle2Rphi
bool layerswitchPosxMatched
MonitorElement * meResMFTrackwidthProfileWClus21
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
bool layerswitchResMFRphiwclus3
MonitorElement * meClusterwidthSas
bool layerswitchResMFTrackwidthProfileWclus1Rphi
bool layerswitchPullMFRphi
T const * product() const
MonitorElement * mePullLF
bool layerswitchResolxMFTrackwidthProfileCategory1Sas
MonitorElement * mePullTrackangleProfileSas
MonitorElement * meResolxMFRphiwclus3
MonitorElement * mePullMFRphiwclus2
MonitorElement * meResolxMFTrackwidthProfileCategory4Rphi
bool layerswitchResolxLFSas
bool layerswitchPullTrackwidthProfileCategory3Rphi
bool layerswitchPullTrackwidthProfileRphiwclus2
bool layerswitchTrackanglebetaRphi
bool layerswitchTrackanglebetaSas
bool layerswitchResolxMFRphiwclus4
MonitorElement * meTrackanglebeta
MonitorElement * meResolxMFClusterwidthProfileCategory1Rphi
const GeomDetUnit * stereoDet() const
void beginJob(const edm::EventSetup &es)
bool layerswitchResMFTrackwidthProfile_WClus21
const TrackerGeomDet * idToDet(DetId) const
bool layerswitchResolxMFTrackwidthProfile_WClus1
MonitorElement * meResolxLFSas
MonitorElement * mePosyMatched
bool layerswitchTrackwidthSas