CMS 3D CMS Logo

Shell.cc
Go to the documentation of this file.
2 
4 
5 // #include "RecoTracker/MkFitCore/src/Matriplex/MatriplexCommon.h"
6 
8 
14 
17 
19 
20 #ifndef NO_ROOT
21 #include "TROOT.h"
22 #include "TRint.h"
23 #endif
24 
25 #include "oneapi/tbb/task_arena.h"
26 
27 #include <vector>
28 
29 // clang-format off
30 
31 namespace {
32  constexpr int algos[] = {4, 22, 23, 5, 24, 7, 8, 9, 10, 6}; // 10 iterations
33  constexpr int n_algos = sizeof(algos) / sizeof(int);
34 
35  const char* b2a(bool b) { return b ? "true" : "false"; }
36 }
37 
38 namespace mkfit {
39 
40  Shell::Shell(std::vector<DeadVec> &dv, const std::string &in_file, int start_ev)
41  : m_deadvectors(dv)
42  {
45 
47 
48  m_data_file = new DataFile;
50 
51  m_event = new Event(0, Config::TrkInfo.n_layers());
52  GoToEvent(start_ev);
53  }
54 
55  void Shell::Run() {
56 #ifndef NO_ROOT
57  std::vector<const char *> argv = { "mkFit", "-l" };
58  int argc = argv.size();
59  TRint rint("mkFit-shell", &argc, const_cast<char**>(argv.data()));
60 
61  char buf[256];
62  sprintf(buf, "mkfit::Shell &s = * (mkfit::Shell*) %p;", this);
63  gROOT->ProcessLine(buf);
64  printf("Shell &s variable is set\n");
65 
66  rint.Run(true);
67  printf("Shell::Run finished\n");
68 #else
69  printf("Shell::Run() no root, we rot -- erroring out. Recompile with WITH_ROOT=1\n");
70  exit(1);
71 #endif
72  }
73 
74  void Shell::Status() {
75  printf("On event %d, selected iteration index %d, algo %d - %s\n"
76  " debug = %s, use_dead_modules = %s\n"
77  " clean_seeds = %s, backward_fit = %s, remove_duplicates = %s\n",
81  }
82 
83  //===========================================================================
84  // Event navigation / processing
85  //===========================================================================
86 
87  void Shell::GoToEvent(int eid) {
88  if (eid < 1) {
89  fprintf(stderr, "Requested event %d is less than 1 -- 1 is the first event, %d is total number of events in file\n",
91  throw std::runtime_error("event out of range");
92  }
93  if (eid > m_evs_in_file) {
94  fprintf(stderr, "Requested event %d is grater than total number of events in file %d\n",
96  throw std::runtime_error("event out of range");
97  }
98 
99  int pos = m_event->evtID();
100  if (eid > pos) {
101  m_data_file->skipNEvents(eid - pos - 1);
102  } else {
103  m_data_file->rewind();
105  }
106  m_event->reset(eid);
111  }
112 
113  printf("At event %d\n", eid);
114  }
115 
116  void Shell::NextEvent(int skip) {
117  GoToEvent(m_event->evtID() + skip);
118  }
119 
120  void Shell::ProcessEvent(SeedSelect_e seed_select, int selected_seed, int count) {
121  // count is only used for SS_IndexPreCleaning and SS_IndexPostCleaning.
122  // There are no checks for upper bounds, ie, if requested seeds beyond the first one exist.
123 
124  const IterationConfig &itconf = Config::ItrInfo[m_it_index];
125  IterationMaskIfc mask_ifc;
127 
128  m_seeds.clear();
129  m_tracks.clear();
130 
131  {
132  int n_algo = 0; // seeds are grouped by algo
133  for (auto &s : m_event->seedTracks_) {
134  if (s.algoint() == itconf.m_track_algorithm) {
135  if (seed_select == SS_UseAll || seed_select == SS_IndexPostCleaning) {
136  m_seeds.push_back(s);
137  } else if (seed_select == SS_Label && s.label() == selected_seed) {
138  m_seeds.push_back(s);
139  break;
140  } else if (seed_select == SS_IndexPreCleaning && n_algo >= selected_seed) {
141  m_seeds.push_back(s);
142  if (--count <= 0)
143  break;
144  }
145  ++n_algo;
146  } else if (n_algo > 0)
147  break;
148  }
149  }
150 
151  printf("Shell::ProcessEvent running over %d seeds\n", (int) m_seeds.size());
152 
153  // Equivalent to run_OneIteration(...) without MkBuilder::release_memory().
154  // If seed_select == SS_IndexPostCleaning the given seed is picked after cleaning.
155  {
156  const TrackerInfo &trackerInfo = Config::TrkInfo;
157  const EventOfHits &eoh = *m_eoh;
158  const IterationMaskIfcBase &it_mask_ifc = mask_ifc;
161  TrackVec &out_tracks = m_tracks;
162  bool do_seed_clean = m_clean_seeds;
163  bool do_backward_fit = m_backward_fit;
164  bool do_remove_duplicates = m_remove_duplicates;
165 
166  MkJob job({trackerInfo, itconf, eoh, eoh.refBeamSpot(), &it_mask_ifc});
167 
168  builder.begin_event(&job, m_event, __func__);
169 
170  // Seed cleaning not done on all iterations.
171  do_seed_clean = m_clean_seeds && itconf.m_seed_cleaner;
172 
173  if (do_seed_clean)
174  itconf.m_seed_cleaner(seeds, itconf, eoh.refBeamSpot());
175 
176  // Check nans in seeds -- this should not be needed when Slava fixes
177  // the track parameter coordinate transformation.
179 
180  if (seed_select == SS_IndexPostCleaning) {
181  if (selected_seed >= 0 && selected_seed < (int)seeds.size()) {
182  for (int i = 0; i < count; ++i)
183  seeds[i] = seeds[selected_seed + i];
184  seeds.resize(count);
185  } else {
186  seeds.clear();
187  }
188  }
189 
190  if (seeds.empty()) {
191  if (seed_select != SS_UseAll)
192  printf("Shell::ProcessEvent requested seed not found among seeds of the selected iteration.\n");
193  else
194  printf("Shell::ProcessEvent no seeds found.\n");
195  return;
196  }
197 
198  if (itconf.m_requires_seed_hit_sorting) {
199  for (auto &s : seeds)
200  s.sortHitsByLayer(); // sort seed hits for the matched hits (I hope it works here)
201  }
202 
203  builder.find_tracks_load_seeds(seeds, do_seed_clean);
204 
206 
207  printf("Shell::ProcessEvent post fwd search: %d comb-cands\n", builder.ref_eocc().size());
208 
209  // Pre backward-fit filtering.
210  filter_candidates_func pre_filter;
211  if (do_backward_fit && itconf.m_pre_bkfit_filter)
212  pre_filter = [&](const TrackCand &tc, const MkJob &jb) -> bool {
213  return itconf.m_pre_bkfit_filter(tc, jb) && StdSeq::qfilter_nan_n_silly<TrackCand>(tc, jb);
214  };
215  else if (itconf.m_pre_bkfit_filter)
216  pre_filter = itconf.m_pre_bkfit_filter;
217  else if (do_backward_fit)
218  pre_filter = StdSeq::qfilter_nan_n_silly<TrackCand>;
219  // pre_filter can be null if we are not doing backward fit as nan_n_silly will be run below.
220  if (pre_filter)
221  builder.filter_comb_cands(pre_filter, true);
222 
223  printf("Shell::ProcessEvent post pre-bkf-filter (%s) and nan-filter (%s) filter: %d comb-cands\n",
224  b2a(bool(itconf.m_pre_bkfit_filter)), b2a(do_backward_fit), builder.ref_eocc().size());
225 
226  job.switch_to_backward();
227 
228  if (do_backward_fit) {
229  if (itconf.m_backward_search) {
231  }
232 
234 
235  if (itconf.m_backward_search) {
238  }
239 
240  printf("Shell::ProcessEvent post backward fit / search: %d comb-cands\n", builder.ref_eocc().size());
241  }
242 
243  // Post backward-fit filtering.
244  filter_candidates_func post_filter;
245  if (do_backward_fit && itconf.m_post_bkfit_filter)
246  post_filter = [&](const TrackCand &tc, const MkJob &jb) -> bool {
247  return itconf.m_post_bkfit_filter(tc, jb) && StdSeq::qfilter_nan_n_silly<TrackCand>(tc, jb);
248  };
249  else
250  post_filter = StdSeq::qfilter_nan_n_silly<TrackCand>;
251  // post_filter is always at least doing nan_n_silly filter.
252  builder.filter_comb_cands(post_filter, true);
253 
254  printf("Shell::ProcessEvent post post-bkf-filter (%s) and nan-filter (true): %d comb-cands\n",
255  b2a(do_backward_fit && itconf.m_post_bkfit_filter), builder.ref_eocc().size());
256 
257  if (do_backward_fit && itconf.m_backward_search)
259 
260  builder.export_best_comb_cands(out_tracks, true);
261 
262  if (do_remove_duplicates && itconf.m_duplicate_cleaner) {
263  itconf.m_duplicate_cleaner(out_tracks, itconf);
264  }
265 
266  printf("Shell::ProcessEvent post remove-duplicates: %d comb-cands\n", (int) out_tracks.size());
267 
268  builder.end_event();
269  }
270 
271  printf("Shell::ProcessEvent found %d tracks, number of seeds at end %d\n",
272  (int) m_tracks.size(), (int) m_seeds.size());
273  }
274 
275  //===========================================================================
276  // Iteration selection
277  //===========================================================================
278 
279  void Shell::SelectIterationIndex(int itidx) {
280  if (itidx < 0 || itidx >= n_algos) {
281  fprintf(stderr, "Requested iteration index out of range [%d, %d)", 0, n_algos);
282  throw std::runtime_error("iteration index out of range");
283  }
284  m_it_index = itidx;
285  }
286 
288  for (int i = 0; i < n_algos; ++i) {
289  if (algos[i] == algo) {
290  m_it_index = i;
291  return;
292  }
293  }
294  fprintf(stderr, "Requested algo %d not found", algo);
295  throw std::runtime_error("algo not found");
296  }
297 
299  printf("Shell::PrintIterations selected index = %d, %d iterations hardcoded as\n",
300  m_it_index, n_algos);
301  for (int i = 0; i < n_algos; ++i)
302  printf("%d %2d %s\n", i, algos[i], TrackBase::algoint_to_cstr(algos[i]));
303  }
304 
305  //===========================================================================
306  // Flags / status setters
307  //===========================================================================
308 
309  void Shell::SetDebug(bool b) { g_debug = b; }
314 
315  //===========================================================================
316  // Analysis helpers
317  //===========================================================================
318 
319  /*
320  sim tracks are written to .bin files with a label equal to its own index.
321  reco tracks labels are seed indices.
322  seed labels are sim track indices
323  --
324  mkfit labels are seed indices in given iteration after cleaning (at seed load-time)
325  */
326 
327  int Shell::LabelFromHits(Track &t, bool replace, float good_frac) {
328  std::map<int, int> lab_cnt;
329  for (int hi = 0; hi < t.nTotalHits(); ++hi) {
330  auto hot = t.getHitOnTrack(hi);
331  if (hot.index < 0)
332  continue;
333  const Hit &h = m_event->layerHits_[hot.layer][hot.index];
334  int hl = m_event->simHitsInfo_[h.mcHitID()].mcTrackID_;
335  if (hl >= 0)
336  ++lab_cnt[hl];
337  }
338  int max_c = -1, max_l = -1;
339  for (auto& x : lab_cnt) {
340  if (x.second > max_c) {
341  max_l = x.first;
342  max_c = x.second;
343  }
344  }
345  bool success = max_c >= good_frac * t.nFoundHits();
346  int relabel = success ? max_l : -1;
347  // printf("found_hits=%d, best_lab %d (%d hits), existing label=%d (replace flag=%s)\n",
348  // t.nFoundHits(), max_l, max_c, t.label(), b2a(replace));
349  if (replace)
350  t.setLabel(relabel);
351  return relabel;
352  }
353 
355  Event &ev = *m_event;
356  const int track_algo = Config::ItrInfo[m_it_index].m_track_algorithm;
357 
358  m_ckf_map.clear();
359  m_sim_map.clear();
360  m_seed_map.clear();
361  m_mkf_map.clear();
362 
363  // Pick ckf tracks with right algo and a good label.
364  int rec_algo_match = 0;
365  for (auto &t : ev.cmsswTracks_) {
366  if (t.algoint() != track_algo)
367  continue;
368  ++rec_algo_match;
369  int label = LabelFromHits(t, false, 0.5);
370  if (label >= 0) {
371  m_ckf_map.insert(std::make_pair(label, &t));
372  }
373  }
374 
375  // Pick sim tracks with labels found by ckf.
376  for (auto &t : ev.simTracks_) {
377  if (t.label() >= 0 && m_ckf_map.find(t.label()) != m_ckf_map.end()) {
378  m_sim_map.insert(std::make_pair(t.label(), &t));
379  }
380  }
381 
382  // Pick seeds with right algo and a label found by ckf.
383  for (auto &t : ev.seedTracks_) {
384  if (t.algoint() == track_algo && t.label() >= 0 && m_ckf_map.find(t.label()) != m_ckf_map.end()) {
385  m_seed_map.insert(std::make_pair(t.label(), &t));
386  }
387  }
388  // Some seeds seem to be labeled -1, try fixing when not otherwise found.
389  for (auto &t : ev.seedTracks_) {
390  if (t.algoint() == track_algo && t.label() == -1) {
391  int lab = LabelFromHits(t, true, 0.5);
392  if (lab >= 0 && m_seed_map.find(lab) == m_seed_map.end()) {
393  if (m_ckf_map.find(lab) != m_ckf_map.end()) {
394  m_seed_map.insert(std::make_pair(t.label(), &t));
395  printf("Saved seed with label -1 -> %d\n", lab);
396  }
397  }
398  }
399  }
400 
401  // Pick mkfit tracks, label by
402  for (auto &t : m_tracks) {
403  int label = LabelFromHits(t, false, 0.5);
404  if (label >= 0) {
405  m_mkf_map.insert(std::make_pair(label, &t));
406  }
407  }
408 
409  printf("Shell::FillByLabelMaps reporting tracks with label >= 0, algo=%d (%s): "
410  "ckf: %d of %d (same algo=%d)), sim: %d of %d, seed: %d of %d, mkfit: %d w/label of %d\n",
411  track_algo, TrackBase::algoint_to_cstr(track_algo),
412  (int) m_ckf_map.size(), (int) ev.cmsswTracks_.size(), rec_algo_match,
413  (int) m_sim_map.size(), (int) ev.simTracks_.size(),
414  (int) m_seed_map.size(), (int) m_seeds.size(),
415  (int) m_mkf_map.size(), (int) m_tracks.size()
416  );
417  }
418 
419  bool Shell::CheckMkFitLayerPlanVsReferenceHits(const Track &mkft, const Track &reft, const std::string &name) {
420  // Check if all hit-layers of a reference track reft are in the mkfit layer plan.
421  // Returns true if all layers are in the plan.
422  // String name is printed in front of label, expected to be SIMK or CKF.
423  const IterationConfig &itconf = Config::ItrInfo[m_it_index];
424  auto lp = itconf.m_steering_params[ mkft.getEtaRegion() ].m_layer_plan;
425  bool ret = true;
426  for (int hi = 0; hi < reft.nTotalHits(); ++hi) {
427  auto hot = reft.getHitOnTrack(hi);
428  if (std::find_if(lp.begin(), lp.end(), [=](auto &x){ return x.m_layer == hot.layer; }) == lp.end())
429  {
430  printf("CheckMkfLayerPlanVsCkfHits: layer %d not in layer plan for region %d, %s label=%d\n",
431  hot.layer, mkft.getEtaRegion(), name.c_str(), reft.label());
432  ret = false;
433  }
434  }
435  return ret;
436  }
437 
438  //===========================================================================
439  // Analysis drivers / main functions / Comparators
440  //===========================================================================
441 
442  void Shell::Compare() {
443  Event &ev = *m_event;
444  const IterationConfig &itconf = Config::ItrInfo[m_it_index];
445 
447 
448  printf("------------------------------------------------------\n");
449 
450  const bool print_all_def = false;
451  int mkf_cnt=0, less_hits=0, more_hits=0;
452 
453  // TOBTEC: look for rec-seeds with hits in tob1 and 2 only.
454  int tot_cnt = 0, no_mkf_cnt = 0;
455 
456  for (auto& [l, simt_ptr]: m_sim_map)
457  {
458  auto &simt = * simt_ptr;
459  auto &ckft = * m_ckf_map[l];
460  auto mi = m_mkf_map.find(l);
461 
462  bool print_all = print_all_def;
463 
464  // TOBTEC: look for rec-seeds with hits in tob1 and 2 only.
465  bool select = true;
466  {
467  auto &ckf_seed = ev.seedTracks_[ckft.label()];
468  for (int hi = 0; hi < ckf_seed.nTotalHits(); ++hi) {
469  const HitOnTrack hot = ckf_seed.getHitOnTrack(hi);
470  if (hot.index >= 0 && (hot.layer < 10 || hot.layer > 13)) {
471  select = false;
472  break;
473  }
474  }
475  }
476  if ( ! select) continue;
477 
478  ++tot_cnt;
479  //print_all = true;
480 
481  if (mi != m_mkf_map.end())
482  {
483  auto &mkft = * mi->second;
484  mkf_cnt++;
485  if (mkft.nFoundHits() < ckft.nFoundHits()) ++less_hits;
486  if (mkft.nFoundHits() > ckft.nFoundHits()) ++more_hits;
487 
488  CheckMkFitLayerPlanVsReferenceHits(mkft, ckft, "CKF");
489  // CheckMkFitLayerPlanVsReferenceHits(mkft, simt, "SIM");
490 
491  (void) print_all;
492  if (/* itconf.m_track_algorithm == 10 ||*/ print_all) {
493  // ckf label is wrong when validation is on (even quality val) for mixedTriplet, pixelless and tobtec
494  // as seed tracks get removed for non-mkfit iterations and indices from rec-tracks are no longer valid.
495  auto &ckf_seed = ev.seedTracks_[ckft.label()];
496  auto &mkf_seed = m_seeds[mkft.label()];
497  print("ckf ", 0, ckft, ev);
498  print("mkfit", 0, mkft, ev);
499  print("sim ", 0, simt, ev);
500  print("ckf seed", 0, ckf_seed, ev);
501  print("mkf seed", 0, mkf_seed, ev);
502  printf("------------------------------------------------------\n");
503 
504  TrackVec ssss;
505  ssss.push_back(mkf_seed);
506 
507  IterationSeedPartition pppp(1);
508  IterationConfig::get_seed_partitioner("phase1:1:debug")(Config::TrkInfo, ssss, *m_eoh, pppp);
509 
510  printf("------------------------------------------------------\n");
511  printf("\n");
512  }
513  }
514  else
515  {
516  printf("\n!!!!! No mkfit track with this label.\n\n");
517  ++no_mkf_cnt;
518 
519  auto &ckf_seed = ev.seedTracks_[ckft.label()];
520  print("ckf ", 0, ckft, ev);
521  print("sim ", 0, simt, ev);
522  print("ckf seed", 0, ckf_seed, ev);
523  auto smi = m_seed_map.find(l);
524  if (smi != m_seed_map.end())
525  print("seed with matching label", 0, *smi->second, ev);
526  printf("------------------------------------------------------\n");
527  }
528  }
529 
530  printf("mkFit found %d, matching_label=%d, less_hits=%d, more_hits=%d [algo=%d (%s)]\n",
531  (int) ev.fitTracks_.size(), mkf_cnt, less_hits, more_hits,
533 
534  if (tot_cnt > 0) {
535  printf("\ntobtec tob1/2 tot=%d no_mkf=%d (%f%%)\n",
536  tot_cnt, no_mkf_cnt, 100.0 * no_mkf_cnt / tot_cnt);
537  } else {
538  printf("\nNo CKF tracks with seed hits in TOB1/2 found (need iteration idx 8, TobTec?)\n");
539  }
540 
541  printf("-------------------------------------------------------------------------------------------\n");
542  printf("-------------------------------------------------------------------------------------------\n");
543  printf("\n");
544  }
545 
546 }
std::map< int, Track * > m_sim_map
Definition: Shell.h:74
void ProcessEvent(SeedSelect_e seed_select=SS_UseAll, int selected_seed=-1, int count=1)
Definition: Shell.cc:120
const EventOfCombCandidates & ref_eocc() const
Definition: MkBuilder.h:73
Shell(std::vector< DeadVec > &dv, const std::string &in_file, int start_ev)
Definition: Shell.cc:40
TrackVec m_seeds
Definition: Shell.h:68
void rewind()
Definition: Event.cc:940
int openRead(const std::string &fname, int expected_n_layers)
Definition: Event.cc:852
const BeamSpot & refBeamSpot() const
void reset(int evtID)
Definition: Event.cc:33
void PrintIterations()
Definition: Shell.cc:298
ret
prodAgent to be discontinued
bool m_remove_duplicates
Definition: Shell.h:66
DataFile * m_data_file
Definition: Shell.h:58
void compactifyHitStorageForBestCand(bool remove_seed_hits, int backward_fit_min_hits)
Definition: MkBuilder.h:62
def replace(string, replacements)
int label() const
Definition: Track.h:188
TrackVec seedTracks_
Definition: Event.h:61
void findTracksCloneEngine(SteeringParams::IterationType_e iteration_dir=SteeringParams::IT_FwdSearch)
Definition: MkBuilder.cc:923
int evtID() const
Definition: Event.h:23
std::map< int, Track * > m_mkf_map
Definition: Shell.h:74
bool CheckMkFitLayerPlanVsReferenceHits(const Track &mkft, const Track &reft, const std::string &name)
Definition: Shell.cc:419
bool m_clean_seeds
Definition: Shell.h:64
void SetDebug(bool b)
Definition: Shell.cc:309
void begin_event(MkJob *job, Event *ev, const char *build_type)
Definition: MkBuilder.cc:194
void Status()
Definition: Shell.cc:74
clean_seeds_func m_seed_cleaner
void SelectIterationIndex(int itidx)
Definition: Shell.cc:279
TEMPL(T2) struct Divides void
Definition: Factorize.h:24
EventOfHits * eoh()
Definition: Shell.h:40
void Run()
Definition: Shell.cc:55
char const * label
MkBuilder * m_builder
Definition: Shell.h:61
std::vector< DeadVec > & m_deadvectors
Definition: Shell.h:57
void loadHitsAndBeamSpot(Event &ev, EventOfHits &eoh)
void FillByLabelMaps_CkfBase()
Definition: Shell.cc:354
void skipNEvents(int n_to_skip)
Definition: Event.cc:967
std::function< filter_candidates_cf > filter_candidates_func
Definition: FunctionTypes.h:28
EventOfHits * m_eoh
Definition: Shell.h:60
bool g_debug
Definition: Debug.cc:2
void find_tracks_load_seeds(const TrackVec &in_seeds, const bool seeds_sorted)
Definition: MkBuilder.cc:606
Definition: EPCuts.h:4
static partition_seeds_func get_seed_partitioner(const std::string &name)
void SetCleanSeeds(bool b)
Definition: Shell.cc:310
void GoToEvent(int eid)
Definition: Shell.cc:87
bool m_backward_fit
Definition: Shell.h:65
TrackerInfo TrkInfo
void loadDeads(EventOfHits &eoh, const std::vector< DeadVec > &deadvectors)
Definition: MkStdSeqs.cc:21
void seed_post_cleaning(TrackVec &tv)
Definition: MkBuilder.cc:407
void SetRemoveDuplicates(bool b)
Definition: Shell.cc:312
void fill_hitmask_bool_vectors(int track_algo, std::vector< std::vector< bool >> &layer_masks)
Definition: Event.cc:806
MCHitInfoVec simHitsInfo_
Definition: Event.h:59
IterationsInfo ItrInfo
MkBuilder * builder()
Definition: Shell.h:41
int filter_comb_cands(filter_candidates_func filter, bool attempt_all_cands)
Definition: MkBuilder.cc:301
void NextEvent(int skip=1)
Definition: Shell.cc:116
std::vector< HitVec > layerHits_
Definition: Event.h:57
static const char * algoint_to_cstr(int algo)
Definition: Track.cc:204
TrackVec m_tracks
Definition: Shell.h:69
filter_candidates_func m_post_bkfit_filter
std::vector< Track > TrackVec
int getEtaRegion() const
Definition: Track.h:268
clean_duplicates_func m_duplicate_cleaner
void beginBkwSearch()
Definition: MkBuilder.h:66
void print(std::string_view label, const MeasurementState &s)
Definition: Hit.cc:8
double b
Definition: hdecay.h:120
int nTotalHits() const
Definition: Track.h:519
void export_best_comb_cands(TrackVec &out_vec, bool remove_missing_hits=false)
Definition: MkBuilder.cc:384
Event * m_event
Definition: Shell.h:59
void SetBackwardFit(bool b)
Definition: Shell.cc:311
int m_it_index
Definition: Shell.h:63
float x
int LabelFromHits(Track &t, bool replace, float good_frac)
Definition: Shell.cc:327
void endBkwSearch()
Definition: MkBuilder.h:67
void Compare()
Definition: Shell.cc:442
void SetUseDeadModules(bool b)
Definition: Shell.cc:313
std::vector< std::vector< bool > > m_mask_vector
void SelectIterationAlgo(int algo)
Definition: Shell.cc:287
filter_candidates_func m_pre_bkfit_filter
The Signals That Services Can Subscribe To This is based on ActivityRegistry h
Helper function to determine trigger accepts.
Definition: Activities.doc:4
std::map< int, Track * > m_ckf_map
Definition: Shell.h:74
std::vector< SteeringParams > m_steering_params
int m_evs_in_file
Definition: Shell.h:62
SeedSelect_e
Definition: Shell.h:18
std::map< int, Track * > m_seed_map
Definition: Shell.h:74
void read_in(DataFile &data_file, FILE *in_fp=0)
Definition: Event.cc:207
def exit(msg="")
HitOnTrack getHitOnTrack(int posHitIdx) const
Definition: Track.h:455