27 #include "oneapi/tbb/task_arena.h" 28 #include "oneapi/tbb/parallel_for.h" 29 #include <oneapi/tbb/global_control.h> 31 #if defined(USE_VTUNE_PAUSE) 32 #include "ittnotify.h" 41 using namespace mkfit;
88 "mkFit.cc/%s--JSON-Load read %d JSON entities from %d files, replaced %d parameters.\n" 89 " NOTE that these changes were NOT APPLIED to actual configuration that is going to be used.\n",
101 printf(
"mkFit.cc/%s--JOSN-Patch read %d JSON entities from %d files, replaced %d parameters.\n",
128 int g_start_event = 1;
130 bool g_run_fit_std =
false;
132 bool g_run_build_all =
true;
133 bool g_run_build_cmssw =
false;
134 bool g_run_build_bh =
false;
135 bool g_run_build_std =
false;
136 bool g_run_build_ce =
false;
137 bool g_run_build_mimi =
false;
145 void init_seed_opts() {
146 g_seed_opts[
"sim"] = {
simSeeds,
"Use simtracks for seeds"};
147 g_seed_opts[
"cmssw"] = {
cmsswSeeds,
"Use external CMSSW seeds"};
148 g_seed_opts[
"find"] = {
findSeeds,
"Use mplex seed finder for seeds"};
152 void init_clean_opts() {
153 g_clean_opts[
"none"] = {
noCleaning,
"No cleaning applied to external CMSSW seeds"};
154 g_clean_opts[
"n2"] = {
cleanSeedsN2,
"Apply N^2 cleaning by Mario to external CMSSW seeds"};
155 g_clean_opts[
"pure"] = {
157 "Only use external CMSSW seeds that have produced a CMSSW track \n must enable: --read-cmssw-tracks"};
158 g_clean_opts[
"badlabel"] = {
cleanSeedsBadLabel,
"Remove seeds with label()<0 in external CMSSW seeds"};
162 void init_match_opts() {
164 "Use track parameter-based matching for validating against CMSSW tracks"};
165 g_match_opts[
"hits"] = {
hitBased,
"Use hit-based matching for validating against CMSSW tracks"};
166 g_match_opts[
"label"] = {
labelBased,
"Only allowed with pure seeds: stricter hit-based matching"};
169 const char* b2a(
bool b) {
return b ?
"true" :
"false"; }
177 template <
typename T,
typename U>
181 for (
const auto& g_opt_pair : g_opt_map) {
182 if (g_opt_pair.second.first == c_opt)
183 return g_opt_pair.first;
185 std::cerr <<
"No match for option " << c_opt << std::endl;
189 template <
typename T,
typename U>
191 if (g_opt_map.count(cmd_ln_str))
192 c_opt = g_opt_map.at(cmd_ln_str).first;
194 std::cerr << cmd_ln_str <<
" is not a valid " << ex_txt <<
" option!! Exiting..." << std::endl;
199 template <
typename U>
201 for (
const auto& g_opt_pair : g_opt_map) {
202 std::cout <<
" " << g_opt_pair.first.c_str() <<
" : " << g_opt_pair.second.second.c_str() << std::endl;
209 printf(
"Running test_standard(), operation=\"%s\", best_out_of=%d\n",
214 printf(
"- reading seeds from file\n");
223 if (g_operation ==
"read") {
225 int evs_available = evs_in_file - g_start_event + 1;
229 printf(
"Requested number of events %d, only %d available.\n",
Config::nEvents, evs_available);
233 if (g_start_event > 1) {
238 constexpr
int NT = 5;
239 double t_sum[NT] = {0};
240 double t_skip[NT] = {0};
245 std::atomic<int>
nevt{g_start_event};
246 std::atomic<int> seedstot{0}, simtrackstot{0}, candstot{0};
247 std::atomic<int> maxHits_all{0}, maxLayer_all{0};
255 std::vector<std::shared_ptr<FILE>> fps;
261 std::ostringstream serial;
269 if (g_operation ==
"read") {
270 fps.emplace_back(fopen(g_input_file.c_str(),
"r"), [](FILE*
fp) {
285 arena.execute([&]() {
288 [&](
const tbb::blocked_range<int>& threads) {
289 int thisthread = threads.begin();
294 auto&
ev = *evs[thisthread].get();
295 auto& mkb = *mkbs[thisthread].get();
296 auto& eoh = *eohs[thisthread].get();
297 auto fp = fps[thisthread].get();
299 int evstart = thisthread * events_per_thread;
302 dprint(
"thisthread " << thisthread <<
" events " <<
Config::nEvents <<
" events/thread " << events_per_thread
303 <<
" range " << evstart <<
":" << evend);
305 for (
int evt = evstart; evt < evend; ++evt) {
311 printf(
"Processing event %d\n",
ev.evtID());
314 ev.read_in(data_file,
fp);
317 if (
ev.seedTracks_.empty())
328 double t_best[NT] = {0}, t_cur[NT] = {0};
329 std::vector<double> t_cur_iter;
330 simtrackstot +=
ev.simTracks_.size();
331 seedstot +=
ev.seedTracks_.size();
333 int ncands_thisthread = 0;
334 int maxHits_thisthread = 0;
335 int maxLayer_thisthread = 0;
340 if (g_run_build_all || g_run_build_mimi)
343 if (g_run_build_all || g_run_build_cmssw)
346 if (g_run_build_ce || g_run_build_mimi) {
347 ncands_thisthread = mkb.total_cands();
348 auto const& ln = mkb.max_hits_layer(eoh);
349 maxHits_thisthread = ln.first;
350 maxLayer_thisthread = ln.second;
352 for (
int i = 0;
i < NT; ++
i)
353 t_best[
i] = (
b == 0) ? t_cur[
i] :
std::min(t_cur[
i], t_best[
i]);
358 printf(
"----------------------------------------------------------------\n");
359 printf(
"Best-of-times:");
360 for (
int i = 0;
i < NT; ++
i)
361 printf(
" %.5f/%.5f", t_cur[
i], t_best[
i]);
364 printf(
"----------------------------------------------------------------\n");
368 candstot += ncands_thisthread;
369 if (maxHits_thisthread > maxHits_all) {
370 maxHits_all = maxHits_thisthread;
371 maxLayer_all = maxLayer_thisthread;
375 printf(
"Matriplex fit = %.5f --- Build BHMX = %.5f STDMX = %.5f CEMX = %.5f MIMI = %.5f\n",
385 std::lock_guard<std::mutex> locker(sum_up_lock);
387 for (
int i = 0;
i < NT; ++
i)
388 t_sum[
i] += t_best[
i];
390 for (
int i = 0;
i < NT; ++
i)
391 t_skip[
i] += t_best[
i];
392 if (g_run_build_all || g_run_build_mimi) {
394 t_sum_iter[
i] += t_cur_iter[
i];
397 t_skip_iter[
i] += t_cur_iter[
i];
402 tbb::simple_partitioner());
408 printf(
"================================================================\n");
410 printf(
"================================================================\n");
412 printf(
"Total Matriplex fit = %.5f --- Build BHMX = %.5f STDMX = %.5f CEMX = %.5f MIMI = %.5f\n",
418 printf(
"Total event > 1 fit = %.5f --- Build BHMX = %.5f STDMX = %.5f CEMX = %.5f MIMI = %.5f\n",
424 printf(
"Total event loop time %.5f simtracks %d seedtracks %d builtcands %d maxhits %d on lay %d\n",
430 maxLayer_all.load());
432 if (g_run_build_all || g_run_build_mimi) {
433 printf(
"================================================================\n");
435 std::cout <<
" Iteration " <<
i <<
" build time = " << t_sum_iter[
i] <<
" \n";
436 printf(
"================================================================\n");
438 std::cout <<
" Iteration " <<
i <<
" build time (event > 1) = " << t_skip_iter[
i] <<
" \n";
439 printf(
"================================================================\n");
441 if (g_operation ==
"read") {
445 for (
auto&
val : vals) {
446 val->fillConfigTree();
464 if (++
j ==
args.end() ||
has_suffix(*
j,
".C") || ((*j)[0] ==
'-' && !(*
j ==
"-" && allow_single_minus))) {
465 std::cerr <<
"Error: option " << *
i <<
" requires an argument.\n";
480 feenableexcept(FE_DIVBYZERO | FE_INVALID | FE_OVERFLOW);
484 #ifdef USE_VTUNE_PAUSE 489 "To make sure this is true for icc and gcc<6 when mixing bools/ints in bitfields.");
497 for (
int i = 1;
i <
argc; ++
i) {
498 mArgs.push_back(
argv[
i]);
500 bool run_shell =
false;
503 while (
i != mArgs.end()) {
506 if (*
i ==
"-h" || *
i ==
"-help" || *
i ==
"--help") {
509 "Usage: %s [options]\n" 510 "Options: defaults defined as (def: DEFAULT VALUE)\n" 511 "\n----------------------------------------------------------------------------------------------------------" 513 "Generic options\n\n" 514 " --geom <str> geometry plugin to use (def: %s)\n" 515 " --silent suppress printouts inside event loop (def: %s)\n" 516 " --best-out-of <int> run test num times, report best time (def: %d)\n" 517 " --input-file file name for reading (def: %s)\n" 518 " --output-file file name for writitng (def: %s)\n" 519 " --read-cmssw-tracks read external cmssw reco tracks if available (def: %s)\n" 520 " --read-simtrack-states read in simTrackStates for pulls in validation (def: %s)\n" 521 " --num-events <int> number of events to run over or simulate (def: %d)\n" 522 " if using --input-file, must be enabled AFTER on command line\n" 523 " --start-event <int> event number to start at when reading from a file (def: %d)\n" 524 " --loop-over-file after reaching the end of the file, start over from the beginning until " 525 " <num-events> events have been processed\n" 526 " --shell start interactive shell instead of running test_standard()\n" 528 "If no --input-file is specified, will trigger simulation\n" 529 " --num-tracks <int> number of tracks to generate for each event (def: %d)\n" 530 "\n----------------------------------------------------------------------------------------------------------" 532 "Threading related options\n\n" 533 " --num-thr-sim <int> number of threads for simulation (def: %d)\n" 534 " --num-thr <int> number of threads for track finding (def: %d)\n" 535 " --num-thr-ev <int> number of threads to run the event loop (def: %d)\n" 536 " --seeds-per-task <int> number of seeds to process in a tbb task (def: %d)\n" 537 " --hits-per-task <int> number of layer1 hits per task when using find seeds (def: %d)\n" 538 "\n----------------------------------------------------------------------------------------------------------" 540 "FittingTestMPlex options\n\n" 541 " --fit-std run standard fitting test (def: %s)\n" 542 " --fit-std-only run only standard fitting test (def: %s)\n" 543 " --cf-fitting enable conformal fit before fitting tracks to get initial estimate of track " 544 "parameters and errors (def: %s)\n" 545 " --fit-val enable ROOT based validation for fittingMPlex (def: %s)\n" 546 "\n----------------------------------------------------------------------------------------------------------" 548 "BuildingTestMPlex options\n\n" 549 " **Specify which building routine you would like to run\n" 550 " --build-cmssw run dummy validation of CMSSW tracks with MkBuilder stuff (def: %s)\n" 551 " --build-bh run best-hit building test (def: %s)\n" 552 " --build-std run standard combinatorial building test (def: %s)\n" 553 " --build-ce run clone engine combinatorial building test (def: %s)\n" 554 " --build-mimi run clone engine on multiple-iteration test (def: %s)\n" 555 " --num-iters-cmssw <int> number of mimi iterations to run (def: set to 3 when --build-mimi is in effect, " 558 " **Seeding options\n" 559 " --seed-input <str> which seed collecion used for building (def: %s)\n" 560 " --seed-cleaning <str> which seed cleaning to apply if using cmssw seeds (def: %s)\n" 561 " --cf-seeding enable conformal fit over seeds (def: %s)\n" 563 " **Duplicate removal options\n" 564 " --remove-dup run duplicate removal after building, using both hit and kinematic criteria (def: " 566 " --remove-dup-no-hit run duplicate removal after building, using kinematic criteria only (def: %s)\n" 568 " **Dead module (strip) option\n" 569 " --use-dead-modules run duplicate removal after building, using both hit and kinematic criteria " 572 " **Additional options for building\n" 573 " --use-phiq-arr use phi-Q arrays in select hit indices (def: %s)\n" 574 " --kludge-cms-hit-errors make sure err(xy) > 15 mum, err(z) > 30 mum (def: %s)\n" 575 " --backward-fit perform backward fit during building (def: %s)\n" 576 " --no-backward-search do not do backward search after backward fit\n" 577 " (def: do search if backward-fit is enabled and available in given iteration)\n" 578 " --include-pca do the backward fit to point of closest approach, does not imply " 579 "'--backward-fit' (def: %s)\n" 580 "\n----------------------------------------------------------------------------------------------------------" 582 "Validation options\n\n" 583 " **Text file based options\n" 584 " --quality-val enable printout validation for MkBuilder (def: %s)\n" 585 " must enable: --dump-for-plots\n" 586 " --dump-for-plots make shell printouts for plots (def: %s)\n" 587 " --mtv-like-val configure validation to emulate CMSSW MultiTrackValidator (MTV) (def: %s)\n" 588 " --mtv-require-seeds configure validation to emulate MTV but require sim tracks to be matched to " 591 " **ROOT based options\n" 592 " --sim-val-for-cmssw enable ROOT based validation for CMSSW tracks with simtracks as reference [eff, " 593 "FR, DR] (def: %s)\n" 594 " --sim-val enable ROOT based validation for seeding, building, and fitting with simtracks " 595 "as reference [eff, FR, DR] (def: %s)\n" 596 " --cmssw-val enable ROOT based validation for building and fitting with CMSSW tracks as " 597 "reference [eff, FR, DR] (def: %s)\n" 598 " must enable: --geom CMS-phase1 --read-cmssw-tracks\n" 599 " --cmssw-match-fw <str> which cmssw track matching routine to use if validating against CMSSW tracks, " 600 "forward built tracks only (def: %s)\n" 601 " must enable: --geom CMS-phase1 --cmssw-val --read-cmssw-tracks\n" 602 " --cmssw-match-bk <str> which cmssw track matching routine to use if validating against CMSSW tracks, " 603 "backward fit tracks only (def: %s)\n" 604 " must enable: --geom CMS-phase1 --cmssw-val --read-cmssw-tracks --backward-fit " 605 "--backward-fit-pca\n" 606 " --inc-shorts include short reco tracks into FR (def: %s)\n" 607 " --keep-hit-info keep vectors of hit idxs and branches in trees (def: %s)\n" 608 " --try-to-save-sim-info two options for this flag [related to validation with simtracks as reference " 609 "collection] (def: %s)\n" 610 " a) IF (--read-simtrack-states is enabled)\n" 611 " If a sim track is associated to a reco track, but it does not contain " 612 "the last found on the reco track\n" 613 " still save sim track kinematic info from generator position\n" 614 " b) ELSE (--read-simtrack-states is NOT enabled)\n" 615 " Save sim track kinematic info from generator position if matched to " 617 "\n----------------------------------------------------------------------------------------------------------" 619 "Combo spaghetti, that's with cole slaw:\n\n" 620 " **Building and fitting combo options\n" 621 " --backward-fit-pca perform backward fit to point of closest approach during building\n" 622 " == --backward-fit --include-pca\n" 623 " **Seed combo options\n" 624 " --cmssw-simseeds use CMS geom with simtracks for seeds\n" 625 " == --geom CMS-phase1 --seed-input %s\n" 626 " --cmssw-stdseeds use CMS geom with CMSSW seeds uncleaned\n" 627 " == --geom CMS-phase1 --seed-input %s --seed-cleaning %s\n" 628 " --cmssw-n2seeds use CMS geom with CMSSW seeds cleaned with N^2 routine\n" 629 " == --geom CMS-phase1 --seed-input %s --seed-cleaning %s\n" 630 " --cmssw-pureseeds use CMS geom with pure CMSSW seeds (seeds which produced CMSSW reco tracks), " 631 "enable read of CMSSW tracks\n" 632 " == --geom CMS-phase1 --seed-input %s --seed-cleaning %s --read-cmssw-tracks\n" 633 " --cmssw-goodlabelseeds use CMS geom with CMSSW seeds with label() >= 0\n" 634 " == --geom CMS-phase1 --seed-input %s --seed-cleaning %s\n" 636 " **CMSSW validation combo options\n" 637 " --cmssw-val-fhit-bhit use CMSSW validation with hit based matching (50 percent after seed) for forward " 639 " use CMSSW validation with hit based matching (50 percent after seed) for " 640 "backward fit tracks\n" 641 " == --cmssw-val --read-cmssw-tracks --cmssw-match-fw %s --cmssw-match-bk %s\n" 642 " must enable: --backward-fit-pca\n" 643 " --cmssw-val-fhit-bprm use CMSSW validation with hit based matching (50 percent after seed) for forward " 645 " use CMSSW validation with track parameter based matching for backward fit " 647 " == --cmssw-val --read-cmssw-tracks --cmssw-match-fw %s --cmssw-match-bk %s\n" 648 " must enable: --backward-fit-pca\n" 649 " --cmssw-val-fprm-bhit use CMSSW validation with track parameter based matching for forward built " 651 " use CMSSW validation with hit based matching (50 percent after seed) for " 652 "backward fit tracks\n" 653 " == --cmssw-val --read-cmssw-tracks --cmssw-match-fw %s --cmssw-match-bk %s\n" 654 " must enable: --backward-fit-pca\n" 655 " --cmssw-val-fprm-bprm use CMSSW validation with track parameter based matching for forward built " 657 " use CMSSW validation with track parameter based matching for backward fit " 659 " == --cmssw-val --read-cmssw-tracks --cmssw-match-fw %s --cmssw-match-bk %s\n" 660 " must enable: --backward-fit-pca\n" 661 " --cmssw-val-label use CMSSW validation with stricter hit based matching for both forward built and " 662 "backward fit tracks, enable read of CMSSW tracks\n" 663 " == --cmssw-val --read-cmssw-tracks --cmssw-match-fw %s --cmssw-match-bk %s\n" 664 " must enable: --cmssw-pureseeds --backward-fit-pca\n" 665 "\n----------------------------------------------------------------------------------------------------------" 667 "JSON config patcher options:\n\n" 668 " --json-load <filename> load single IterationConfig from given JSON file (def: do not load)\n" 669 " can be specified multiple times for several files\n" 670 " --json-patch <filename> patch IterationsInfo from given JSON file (def: do not patch)\n" 671 " can be specified multiple times for several files\n" 672 " --json-save-iterations <fname-fmt> save per iteration json files\n" 673 " %%d in fname-fmt gets replaced with iteration index\n" 674 " %%s in fname-fmt gets replaced with iteration algorithm name\n" 675 " exactly one of %%d and %%s must be specified\n" 676 " --json-save-iterations-include-iter-info-preamble (def: %s)\n" 677 " --json-verbose print each patch assignment as it is being made (def: %s)\n" 678 " --json-dump-before print iteration config before patching (def: %s)\n" 679 " --json-dump-after print iteration config after patching (def: %s)\n" 680 "\n----------------------------------------------------------------------------------------------------------" 687 g_input_file.c_str(),
688 g_output_file.c_str(),
703 !(g_run_build_all || g_run_build_cmssw || g_run_build_bh || g_run_build_std || g_run_build_ce)),
707 b2a(g_run_build_all || g_run_build_cmssw),
708 b2a(g_run_build_all || g_run_build_bh),
709 b2a(g_run_build_all || g_run_build_std),
710 b2a(g_run_build_all || g_run_build_ce),
711 b2a(g_run_build_all || g_run_build_mimi),
767 printf(
"List of options for string based inputs \n");
775 printf(
"--seed-input \n");
779 printf(
"--seed-cleaning \n");
783 printf(
"--cmssw-matching \n");
790 else if (*
i ==
"--geom") {
793 }
else if (*
i ==
"--silent") {
795 }
else if (*
i ==
"--best-out-of") {
798 }
else if (*
i ==
"--input-file") {
801 g_operation =
"read";
803 }
else if (*
i ==
"--output-file") {
806 g_operation =
"write";
807 }
else if (*
i ==
"--read-cmssw-tracks") {
809 }
else if (*
i ==
"--read-simtrack-states") {
811 }
else if (*
i ==
"--num-events") {
814 }
else if (*
i ==
"--start-event") {
816 g_start_event = atoi(
i->c_str());
817 }
else if (*
i ==
"--loop-over-file") {
819 }
else if (*
i ==
"--shell") {
821 }
else if (*
i ==
"--num-tracks") {
824 }
else if (*
i ==
"--num-thr-sim") {
827 }
else if (*
i ==
"--num-thr") {
830 }
else if (*
i ==
"--num-thr-ev") {
833 }
else if (*
i ==
"--seeds-per-task") {
836 }
else if (*
i ==
"--hits-per-task") {
839 }
else if (*
i ==
"--fit-std") {
840 g_run_fit_std =
true;
841 }
else if (*
i ==
"--fit-std-only") {
842 g_run_fit_std =
true;
843 g_run_build_all =
false;
844 g_run_build_bh =
false;
845 g_run_build_std =
false;
846 g_run_build_ce =
false;
847 }
else if (*
i ==
"--cf-fitting") {
849 }
else if (*
i ==
"--fit-val") {
851 }
else if (*
i ==
"--build-cmssw") {
852 g_run_build_all =
false;
853 g_run_build_cmssw =
true;
854 g_run_build_bh =
false;
855 g_run_build_std =
false;
856 g_run_build_ce =
false;
857 }
else if (*
i ==
"--build-bh") {
858 g_run_build_all =
false;
859 g_run_build_cmssw =
false;
860 g_run_build_bh =
true;
861 g_run_build_std =
false;
862 g_run_build_ce =
false;
863 }
else if (*
i ==
"--build-std") {
864 g_run_build_all =
false;
865 g_run_build_cmssw =
false;
866 g_run_build_bh =
false;
867 g_run_build_std =
true;
868 g_run_build_ce =
false;
869 }
else if (*
i ==
"--build-ce") {
870 g_run_build_all =
false;
871 g_run_build_cmssw =
false;
872 g_run_build_bh =
false;
873 g_run_build_std =
false;
874 g_run_build_ce =
true;
875 }
else if (*
i ==
"--build-mimi") {
876 g_run_build_all =
false;
877 g_run_build_cmssw =
false;
878 g_run_build_bh =
false;
879 g_run_build_std =
false;
880 g_run_build_ce =
false;
881 g_run_build_mimi =
true;
884 }
else if (*
i ==
"--num-iters-cmssw") {
887 }
else if (*
i ==
"--seed-input") {
890 }
else if (*
i ==
"--seed-cleaning") {
893 }
else if (*
i ==
"--cf-seeding") {
895 }
else if (*
i ==
"--use-phiq-arr") {
896 #ifdef CONFIG_PhiQArrays 899 printf(
"--use-phiq-arr has no effect: recompile with CONFIG_PhiQArrays\n");
901 }
else if (*
i ==
"--remove-dup") {
902 Config::removeDuplicates =
true;
904 }
else if (*
i ==
"--remove-dup-no-hit") {
905 Config::removeDuplicates =
true;
907 }
else if (*
i ==
"--use-dead-modules") {
909 }
else if (*
i ==
"--kludge-cms-hit-errors") {
911 }
else if (*
i ==
"--backward-fit") {
913 }
else if (*
i ==
"--no-backward-search") {
915 }
else if (*
i ==
"--include-pca") {
917 }
else if (*
i ==
"--quality-val") {
919 }
else if (*
i ==
"--dump-for-plots") {
921 }
else if (*
i ==
"--mtv-like-val") {
925 }
else if (*
i ==
"--mtv-require-seeds") {
930 }
else if (*
i ==
"--sim-val-for-cmssw") {
932 }
else if (*
i ==
"--sim-val") {
934 }
else if (*
i ==
"--cmssw-val") {
936 }
else if (*
i ==
"--cmssw-match-fw") {
939 }
else if (*
i ==
"--cmssw-match-bk") {
942 }
else if (*
i ==
"--inc-shorts") {
944 }
else if (*
i ==
"--keep-hit-info") {
946 }
else if (*
i ==
"--try-to-save-sim-info") {
948 }
else if (*
i ==
"--backward-fit-pca") {
951 }
else if (*
i ==
"--cmssw-simseeds") {
954 }
else if (*
i ==
"--cmssw-stdseeds") {
958 }
else if (*
i ==
"--cmssw-n2seeds") {
962 }
else if (*
i ==
"--cmssw-pureseeds") {
967 }
else if (*
i ==
"--cmssw-goodlabelseeds") {
971 }
else if (*
i ==
"--cmssw-val-fhit-bhit") {
976 }
else if (*
i ==
"--cmssw-val-fhit-bprm") {
981 }
else if (*
i ==
"--cmssw-val-fprm-bhit") {
986 }
else if (*
i ==
"--cmssw-val-fprm-bprm") {
991 }
else if (*
i ==
"--cmssw-val-label") {
996 }
else if (*
i ==
"--json-load") {
999 }
else if (*
i ==
"--json-patch") {
1002 }
else if (*
i ==
"--json-save-iterations") {
1005 }
else if (*
i ==
"--json-save-iterations-include-iter-info-preamble") {
1007 }
else if (*
i ==
"--json-verbose") {
1009 }
else if (*
i ==
"--json-dump-before") {
1011 }
else if (*
i ==
"--json-dump-after") {
1014 fprintf(
stderr,
"Error: Unknown option/argument '%s'.\n",
i->c_str());
1026 std::cerr <<
"What have you done?!? Can't mix cmssw label matching without pure seeds! Exiting...\n";
1029 std::cerr <<
"What have you done?!? Short reco tracks are already accounted for in the MTV-Like Validation! Inclusive " 1030 "shorts is only an option for the standard simval, and will break the MTV-Like simval! Exiting...\n";
1036 printf(
"mkFit configuration complete.\n" 1037 " vusize=%d, num_thr_events=%d, num_thr_finder=%d\n" 1038 " sizeof(Track)=%zu, sizeof(Hit)=%zu, sizeof(SVector3)=%zu, sizeof(SMatrixSym33)=%zu, sizeof(MCHitInfo)=%zu\n",
int openRead(const std::string &fname, int expected_n_layers)
std::map< std::string, std::pair< seedOpts, std::string > > seedOptsMap
double runBuildingTestPlexStandard(Event &ev, const EventOfHits &eoh, MkBuilder &builder)
ROOT::Math::SVector< float, 3 > SVector3
void setOpt(const std::string &cmd_ln_str, T &c_opt, const U &g_opt_map, const std::string &ex_txt)
bool has_suffix(const std::string &str, const std::string &suffix)
std::map< std::string, std::pair< matchOpts, std::string > > matchOptsMap
std::vector< std::string > json_patch_filenames
static Validation * make_validation(const std::string &, const TrackerInfo *)
void execTrackerInfoCreatorPlugin(const std::string &base, TrackerInfo &ti, IterationsInfo &ii, bool verbose)
void recalculateDependentConstants()
constexpr bool usePhiQArrays
void patch_Files(IterationsInfo &its_info, const std::vector< std::string > &fnames, ConfigJsonPatcher::PatchReport *report=nullptr)
matchOpts cmsswMatchingFW
std::string getOpt(const T &c_opt, const U &g_opt_map)
void loadHitsAndBeamSpot(Event &ev, EventOfHits &eoh)
void skipNEvents(int n_to_skip)
matchOpts cmsswMatchingBK
void setupStandardFunctionsFromNames()
void listOpts(const U &g_opt_map)
void loadDeads(EventOfHits &eoh, const std::vector< DeadVec > &deadvectors)
int main(int argc, const char *argv[])
std::unique_ptr< IterationConfig > patchLoad_File(const IterationsInfo &its_info, const std::string &fname, ConfigJsonPatcher::PatchReport *report=nullptr)
void runBuildingTestPlexDumbCMSSW(Event &ev, const EventOfHits &eoh, MkBuilder &builder)
constexpr int numThreadsFinder
void save_Iterations(IterationsInfo &its_info, const std::string &fname_fmt, bool include_iter_info_preamble)
constexpr bool nan_etc_sigs_enable
static std::mutex printmutex
double runBuildingTestPlexCloneEngine(Event &ev, const EventOfHits &eoh, MkBuilder &builder)
void next_arg_or_die(lStr_t &args, lStr_i &i, bool allow_single_minus=false)
void dump(IterationsInfo &its_info)
std::map< std::string, std::pair< cleanOpts, std::string > > cleanOptsMap
bool json_save_iters_include_iter_info_preamble
std::vector< std::string > json_load_filenames
std::vector< double > runBtpCe_MultiIter(Event &ev, const EventOfHits &eoh, MkBuilder &builder, int n)
static std::unique_ptr< MkBuilder > make_builder(bool silent=true)
constexpr int numSeedsPerTask
constexpr int numThreadsEvents
std::list< std::string > lStr_t
const bool useHitsForDuplicates
std::string json_save_iters_fname_fmt
ROOT::Math::SMatrix< float, 3, 3, ROOT::Math::MatRepSym< float, 3 > > SMatrixSym33
int finderReportBestOutOfN
std::vector< DeadVec > deadvectors
double runBuildingTestPlexBestHit(Event &ev, const EventOfHits &eoh, MkBuilder &builder)