CMS 3D CMS Logo

TotemRPUVPatternFinder.cc
Go to the documentation of this file.
1 /****************************************************************************
2 *
3 * This is a part of TOTEM offline software.
4 * Authors:
5 * Jan Kašpar (jan.kaspar@gmail.com)
6 *
7 ****************************************************************************/
8 
17 
23 
26 
28 
29 //----------------------------------------------------------------------------------------------------
30 
38 public:
40 
41  ~TotemRPUVPatternFinder() override;
42 
43  void produce(edm::Event &e, const edm::EventSetup &c) override;
45 
46 private:
49 
52 
53  unsigned int verbosity;
54 
57 
59  unsigned char minPlanesPerProjectionToFit;
60 
62  unsigned int maxHitsPerPlaneToSearch;
63 
66 
68  double threshold;
69 
71  double max_a_toFit;
72 
74  struct RPSettings {
77  };
78 
80  std::map<unsigned int, RPSettings> exceptionalSettings;
81 
84  double z0,
85  double threshold,
86  unsigned int planes_required,
89 };
90 
91 //----------------------------------------------------------------------------------------------------
92 
93 using namespace std;
94 using namespace edm;
95 
96 //----------------------------------------------------------------------------------------------------
97 
99  : tagRecHit(conf.getParameter<edm::InputTag>("tagRecHit")),
100  ctppsGeometryToken(esConsumes()),
101  verbosity(conf.getUntrackedParameter<unsigned int>("verbosity", 0)),
102  minPlanesPerProjectionToSearch(conf.getParameter<unsigned int>("minPlanesPerProjectionToSearch")),
103  minPlanesPerProjectionToFit(conf.getParameter<unsigned int>("minPlanesPerProjectionToFit")),
104  maxHitsPerPlaneToSearch(conf.getParameter<unsigned int>("maxHitsPerPlaneToSearch")),
105  lrcgn(new FastLineRecognition(conf.getParameter<double>("clusterSize_a"),
106  conf.getParameter<double>("clusterSize_b"))),
107  threshold(conf.getParameter<double>("threshold")),
108  max_a_toFit(conf.getParameter<double>("max_a_toFit")) {
109  for (const auto &ps : conf.getParameter<vector<ParameterSet>>("exceptionalSettings")) {
110  unsigned int rpId = ps.getParameter<unsigned int>("rpId");
111 
112  RPSettings settings;
113  settings.minPlanesPerProjectionToFit_U = ps.getParameter<unsigned int>("minPlanesPerProjectionToFit_U");
114  settings.minPlanesPerProjectionToFit_V = ps.getParameter<unsigned int>("minPlanesPerProjectionToFit_V");
115  settings.threshold_U = ps.getParameter<double>("threshold_U");
116  settings.threshold_V = ps.getParameter<double>("threshold_V");
117 
118  exceptionalSettings[rpId] = settings;
119  }
120 
121  detSetVectorTotemRPRecHitToken = consumes<edm::DetSetVector<TotemRPRecHit>>(tagRecHit);
122 
123  produces<DetSetVector<TotemRPUVPattern>>();
124 }
125 
126 //----------------------------------------------------------------------------------------------------
127 
129 
130 //----------------------------------------------------------------------------------------------------
131 
133  double z0,
134  double threshold_loc,
135  unsigned int planes_required,
137  DetSet<TotemRPUVPattern> &patterns) {
138  // run recognition
139  DetSet<TotemRPUVPattern> newPatterns;
140  lrcgn->getPatterns(hits, z0, threshold_loc, newPatterns);
141 
142  // set pattern properties and copy to the global pattern collection
143  for (auto &p : newPatterns) {
144  p.setProjection(proj);
145 
146  p.setFittable(true);
147 
148  set<unsigned int> planes;
149  for (const auto &ds : p.hits())
150  planes.insert(TotemRPDetId(ds.detId()).plane());
151 
152  if (planes.size() < planes_required)
153  p.setFittable(false);
154 
155  if (fabs(p.a()) > max_a_toFit)
156  p.setFittable(false);
157 
158  patterns.push_back(p);
159  }
160 }
161 
162 //----------------------------------------------------------------------------------------------------
163 
165  if (verbosity > 5)
166  LogVerbatim("TotemRPUVPatternFinder")
167  << ">> TotemRPUVPatternFinder::produce " << event.id().run() << ":" << event.id().event();
168 
169  // geometry
170  const auto &geometry = es.getData(ctppsGeometryToken);
171  if (geometryWatcher.check(es))
173 
174  // get input
176  event.getByToken(detSetVectorTotemRPRecHitToken, input);
177 
178  // prepare output
179  DetSetVector<TotemRPUVPattern> patternsVector;
180 
181  // split input per RP and per U/V projection
182  struct RPData {
183  DetSetVector<TotemRPRecHit> hits_U, hits_V;
184  map<uint8_t, uint16_t> planeOccupancy_U, planeOccupancy_V;
185  };
186  map<unsigned int, RPData> rpData;
187 
188  for (auto &ids : *input) {
189  TotemRPDetId detId(ids.detId());
190  unsigned int plane = detId.plane();
191  bool uDir = detId.isStripsCoordinateUDirection();
192 
193  CTPPSDetId rpId = detId.rpId();
194 
195  RPData &data = rpData[rpId];
196 
197  for (auto &h : ids) {
198  if (uDir) {
199  auto &ods = data.hits_U.find_or_insert(ids.detId());
200  ods.push_back(h);
201  data.planeOccupancy_U[plane]++;
202  } else {
203  auto &ods = data.hits_V.find_or_insert(ids.detId());
204  ods.push_back(h);
205  data.planeOccupancy_V[plane]++;
206  }
207  }
208  }
209 
210  // track recognition pot by pot
211  for (auto const &it : rpData) {
212  CTPPSDetId rpId(it.first);
213  RPData const &data = it.second;
214 
215  // merge default and exceptional settings (if available)
216  unsigned int minPlanesPerProjectionToFit_U = minPlanesPerProjectionToFit;
217  unsigned int minPlanesPerProjectionToFit_V = minPlanesPerProjectionToFit;
218  double threshold_U = threshold;
219  double threshold_V = threshold;
220 
221  auto setIt = exceptionalSettings.find(rpId);
222  if (setIt != exceptionalSettings.end()) {
223  minPlanesPerProjectionToFit_U = setIt->second.minPlanesPerProjectionToFit_U;
224  minPlanesPerProjectionToFit_V = setIt->second.minPlanesPerProjectionToFit_V;
225  threshold_U = setIt->second.threshold_U;
226  threshold_V = setIt->second.threshold_V;
227  }
228 
229  auto &uColl = data.planeOccupancy_U;
230  auto &vColl = data.planeOccupancy_V;
231 
232  if (verbosity > 5) {
233  LogVerbatim("TotemRPUVPatternFinder")
234  << "\tRP " << rpId << "\n\t\tall planes: u = " << uColl.size() << ", v = " << vColl.size();
235  }
236 
237  // count planes with clean data (no showers, noise, ...)
238  unsigned int uPlanes = 0, vPlanes = 0;
239  for (auto pit : uColl)
240  if (pit.second <= maxHitsPerPlaneToSearch)
241  uPlanes++;
242 
243  for (auto pit : vColl)
244  if (pit.second <= maxHitsPerPlaneToSearch)
245  vPlanes++;
246 
247  if (verbosity > 5)
248  LogVerbatim("TotemRPUVPatternFinder") << "\t\tplanes with clean data: u = " << uPlanes << ", v = " << vPlanes;
249 
250  // discard RPs with too few reasonable planes
252  continue;
253 
254  // prepare data containers
255  DetSet<TotemRPUVPattern> &patterns = patternsVector.find_or_insert(rpId);
256 
257  // "typical" z0 for the RP
258  double z0 = geometry.rp(rpId)->translation().z();
259 
260  // u then v recognition
261  recognizeAndSelect(TotemRPUVPattern::projU, z0, threshold_U, minPlanesPerProjectionToFit_U, data.hits_U, patterns);
262 
263  recognizeAndSelect(TotemRPUVPattern::projV, z0, threshold_V, minPlanesPerProjectionToFit_V, data.hits_V, patterns);
264 
265  if (verbosity > 5) {
266  LogVerbatim("TotemRPUVPatternFinder") << "\t\tpatterns:";
267  for (const auto &p : patterns) {
268  unsigned int n_hits = 0;
269  for (auto &hds : p.hits())
270  n_hits += hds.size();
271 
272  LogVerbatim("TotemRPUVPatternFinder")
273  << "\t\t\tproj = " << ((p.projection() == TotemRPUVPattern::projU) ? "U" : "V") << ", a = " << p.a()
274  << ", b = " << p.b() << ", w = " << p.w() << ", fittable = " << p.fittable() << ", hits = " << n_hits;
275  }
276  }
277  }
278 
279  // save output
280  event.put(make_unique<DetSetVector<TotemRPUVPattern>>(patternsVector));
281 }
282 
283 //----------------------------------------------------------------------------------------------------
284 
287 
288  desc.add<edm::InputTag>("tagRecHit", edm::InputTag("totemRPRecHitProducer"))
289  ->setComment("input rechits collection to retrieve");
290  desc.addUntracked<unsigned int>("verbosity", 0);
291  desc.add<unsigned int>("maxHitsPerPlaneToSearch", 5)
292  ->setComment("minimum threshold of hits multiplicity to flag the pattern as dirty");
293  desc.add<unsigned int>("minPlanesPerProjectionToSearch", 3)
294  ->setComment(
295  "minimal number of reasonable (= not empty and not dirty) planes per projection and per RP, to start the "
296  "pattern search");
297  desc.add<double>("clusterSize_a", 0.02 /* rad */)
298  ->setComment("(full) cluster size (in rad) in slope-intercept space");
299  desc.add<double>("clusterSize_b", 0.3 /* mm */);
300 
301  desc.add<double>("threshold", 2.99)
302  ->setComment(
303  "minimal weight of (Hough) cluster to accept it as candidate\n"
304  " weight of cluster = sum of weights of contributing points\n"
305  " weight of point = sigma0 / sigma_of_point\n"
306  "most often: weight of point ~ 1, thus cluster weight is roughly number of contributing points");
307 
308  desc.add<unsigned int>("minPlanesPerProjectionToFit", 3)
309  ->setComment(
310  "minimal number of planes (in the recognised patterns) per projection and per RP, to tag the candidate as "
311  "fittable");
312 
313  desc.add<bool>("allowAmbiguousCombination", false)
314  ->setComment(
315  "whether to allow combination of most significant U and V pattern, in case there several of them.\n"
316  "don't set it to True, unless you have reason");
317 
318  desc.add<double>("max_a_toFit", 10.0)
319  ->setComment(
320  "maximal angle (in any projection) to mark the candidate as fittable -> controls track parallelity with "
321  "beam\n"
322  "huge value -> no constraint");
323 
324  edm::ParameterSetDescription exceptions_validator;
325  exceptions_validator.add<unsigned int>("rpId")->setComment("RP id according to CTPPSDetId");
326  exceptions_validator.add<unsigned int>("minPlanesPerProjectionToFit_U");
327  exceptions_validator.add<unsigned int>("minPlanesPerProjectionToFit_V");
328  exceptions_validator.add<double>("threshold_U");
329  exceptions_validator.add<double>("threshold_V");
330 
331  std::vector<edm::ParameterSet> exceptions_default;
332  desc.addVPSet("exceptionalSettings", exceptions_validator, exceptions_default);
333 
334  descr.add("totemRPUVPatternFinder", desc);
335 }
336 
337 //----------------------------------------------------------------------------------------------------
338 
TotemRPUVPattern::projV
Definition: TotemRPUVPattern.h:34
elasticPlotDQMSource_cfi.tagRecHit
tagRecHit
Definition: elasticPlotDQMSource_cfi.py:5
edm::ESWatcher::check
bool check(const edm::EventSetup &iSetup)
Definition: ESWatcher.h:57
edm::DetSet::push_back
void push_back(const T &t)
Definition: DetSet.h:66
edm::DetSetVector< TotemRPRecHit >
TotemRPUVPatternFinder::RPSettings
block of (exceptional) settings for 1 RP
Definition: TotemRPUVPatternFinder.cc:79
ctppsCommonDQMSource_cfi.verbosity
verbosity
Definition: ctppsCommonDQMSource_cfi.py:14
TotemRPUVPatternFinder
Class to recognize straight line tracks, based on optimized Hough trasform.
Definition: TotemRPUVPatternFinder.cc:37
edm::ParameterSetDescription::add
ParameterDescriptionBase * add(U const &iLabel, T const &value)
Definition: ParameterSetDescription.h:95
input
static const std::string input
Definition: EdmProvDump.cc:48
hfClusterShapes_cfi.hits
hits
Definition: hfClusterShapes_cfi.py:5
edm::ESWatcher< VeryForwardRealGeometryRecord >
ESHandle.h
edm::DetSet
Definition: DetSet.h:23
edm::EDGetTokenT
Definition: EDGetToken.h:33
FastLineRecognition::resetGeometry
void resetGeometry(const CTPPSGeometry *_g)
Definition: FastLineRecognition.h:34
edm
HLT enums.
Definition: AlignableModifier.h:19
geometry
Definition: geometry.py:1
HLT_FULL_cff.InputTag
InputTag
Definition: HLT_FULL_cff.py:89301
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
EDProducer.h
TotemRPRecHit.h
TotemRPDetId::plane
uint32_t plane() const
Definition: TotemRPDetId.h:51
TotemRPUVPatternFinder::tagRecHit
edm::InputTag tagRecHit
Definition: TotemRPUVPatternFinder.cc:52
edm::Handle
Definition: AssociativeIterator.h:50
ESGetToken.h
TotemRPUVPatternFinder::threshold
double threshold
minimal weight of (Hough) cluster to accept it as candidate
Definition: TotemRPUVPatternFinder.cc:73
TotemRPUVPatternFinder::RPSettings::minPlanesPerProjectionToFit_U
unsigned char minPlanesPerProjectionToFit_U
Definition: TotemRPUVPatternFinder.cc:80
CTPPSGeometry.h
MakerMacros.h
h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
edm::ConfigurationDescriptions::add
void add(std::string const &label, ParameterSetDescription const &psetDescription)
Definition: ConfigurationDescriptions.cc:57
HLTMuonOfflineAnalyzer_cfi.z0
z0
Definition: HLTMuonOfflineAnalyzer_cfi.py:98
edm::ConfigurationDescriptions
Definition: ConfigurationDescriptions.h:28
TotemRPUVPatternFinder::detSetVectorTotemRPRecHitToken
edm::EDGetTokenT< edm::DetSetVector< TotemRPRecHit > > detSetVectorTotemRPRecHitToken
Definition: TotemRPUVPatternFinder.cc:53
amptDefault_cfi.proj
proj
Definition: amptDefault_cfi.py:13
edm::ParameterSet
Definition: ParameterSet.h:47
AlCaHLTBitMon_ParallelJobs.p
def p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
Event.h
CTPPSDetId
Base class for CTPPS detector IDs.
Definition: CTPPSDetId.h:31
TotemRPUVPatternFinder::max_a_toFit
double max_a_toFit
maximal angle (in any projection) to mark candidate as fittable - controls track parallelity
Definition: TotemRPUVPatternFinder.cc:76
createfilelist.int
int
Definition: createfilelist.py:10
FastLineRecognition
Class performing optimized hough transform to recognize lines.
Definition: FastLineRecognition.h:23
TotemRPUVPatternFinder::verbosity
unsigned int verbosity
Definition: TotemRPUVPatternFinder.cc:58
FastLineRecognition::getPatterns
void getPatterns(const edm::DetSetVector< TotemRPRecHit > &input, double _z0, double threshold, edm::DetSet< TotemRPUVPattern > &patterns)
Definition: FastLineRecognition.cc:86
TotemRPUVPatternFinder::produce
void produce(edm::Event &e, const edm::EventSetup &c) override
Definition: TotemRPUVPatternFinder.cc:164
TotemRPUVPatternFinder::geometryWatcher
edm::ESWatcher< VeryForwardRealGeometryRecord > geometryWatcher
Definition: TotemRPUVPatternFinder.cc:56
edm::stream::EDProducer
Definition: EDProducer.h:36
edm::EventSetup
Definition: EventSetup.h:58
TotemRPUVPatternFinder::RPSettings::threshold_V
double threshold_V
Definition: TotemRPUVPatternFinder.cc:81
DetSetVector.h
TotemRPUVPatternFinder::fillDescriptions
static void fillDescriptions(edm::ConfigurationDescriptions &)
Definition: TotemRPUVPatternFinder.cc:285
TotemRPUVPatternFinder::RPSettings::minPlanesPerProjectionToFit_V
unsigned char minPlanesPerProjectionToFit_V
Definition: TotemRPUVPatternFinder.cc:80
TotemRPUVPatternFinder::ctppsGeometryToken
edm::ESGetToken< CTPPSGeometry, VeryForwardRealGeometryRecord > ctppsGeometryToken
Definition: TotemRPUVPatternFinder.cc:55
VeryForwardRealGeometryRecord.h
edm::ESGetToken< CTPPSGeometry, VeryForwardRealGeometryRecord >
FastLineRecognition.h
edm::EventSetup::getData
bool getData(T &iHolder) const
Definition: EventSetup.h:127
profile_2016_postTS2_cff.rpId
rpId
Definition: profile_2016_postTS2_cff.py:21
TotemRPUVPatternFinder::lrcgn
FastLineRecognition * lrcgn
the line recognition algorithm
Definition: TotemRPUVPatternFinder.cc:70
TotemRPUVPatternFinder::recognizeAndSelect
void recognizeAndSelect(TotemRPUVPattern::ProjectionType proj, double z0, double threshold, unsigned int planes_required, const edm::DetSetVector< TotemRPRecHit > &hits, edm::DetSet< TotemRPUVPattern > &patterns)
executes line recognition in a projection
Definition: TotemRPUVPatternFinder.cc:132
TotemRPUVPatternFinder::maxHitsPerPlaneToSearch
unsigned int maxHitsPerPlaneToSearch
above this limit, planes are considered noisy
Definition: TotemRPUVPatternFinder.cc:67
TotemRPUVPatternFinder::minPlanesPerProjectionToSearch
unsigned char minPlanesPerProjectionToSearch
minimal required number of active planes per projection to even start track recognition
Definition: TotemRPUVPatternFinder.cc:61
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
std
Definition: JetResolutionObject.h:76
TotemRPUVPatternFinder::minPlanesPerProjectionToFit
unsigned char minPlanesPerProjectionToFit
minimal required number of active planes per projection to mark track candidate as fittable
Definition: TotemRPUVPatternFinder.cc:64
TotemRPUVPatternFinder::exceptionalSettings
std::map< unsigned int, RPSettings > exceptionalSettings
exceptional settings: RP Id --> settings
Definition: TotemRPUVPatternFinder.cc:85
TotemRPUVPatternFinder::TotemRPUVPatternFinder
TotemRPUVPatternFinder(const edm::ParameterSet &conf)
Definition: TotemRPUVPatternFinder.cc:98
ESWatcher.h
edm::LogVerbatim
Log< level::Info, true > LogVerbatim
Definition: MessageLogger.h:128
TotemRPUVPattern::ProjectionType
ProjectionType
Definition: TotemRPUVPattern.h:29
TotemRPDetId.h
EventSetup.h
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
TotemRPUVPattern::projU
Definition: TotemRPUVPattern.h:34
data
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:79
edm::DetSetVector::find_or_insert
reference find_or_insert(det_id_type id)
Definition: DetSetVector.h:234
TotemRPUVPattern.h
DetSet.h
TotemRPUVPatternFinder::RPSettings::threshold_U
double threshold_U
Definition: TotemRPUVPatternFinder.cc:81
ParameterSet.h
c
auto & c
Definition: CAHitNtupletGeneratorKernelsImpl.h:56
event
Definition: event.py:1
remoteMonitoring_LED_IterMethod_cfg.threshold
threshold
Definition: remoteMonitoring_LED_IterMethod_cfg.py:430
DeDxTools::esConsumes
ESGetTokenH3DDVariant esConsumes(std::string const &Reccord, edm::ConsumesCollector &)
Definition: DeDxTools.cc:283
edm::Event
Definition: Event.h:73
TotemRPUVPatternFinder::~TotemRPUVPatternFinder
~TotemRPUVPatternFinder() override
Definition: TotemRPUVPatternFinder.cc:128
TotemRPDetId
Detector ID class for TOTEM Si strip detectors.
Definition: TotemRPDetId.h:29
edm::InputTag
Definition: InputTag.h:15
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37