18 const std::shared_ptr<GOptions>& gopt,
19 const std::shared_ptr<GLogger>& log,
20 const std::shared_ptr<const gdynamicdigitization::dRoutinesMap>& dynamicRoutinesMap) -> std::vector<std::unique_ptr<GEventDataCollection>> {
21 std::mutex collectorMtx;
22 std::vector<std::unique_ptr<GEventDataCollection>> collected;
27 std::atomic<int> next{1};
33 std::vector<jthread_alias> pool;
35 pool.reserve(nthreads);
37 for (
int tid = 0; tid < nthreads; ++tid) {
39 pool.emplace_back([&, tid]
42 log->info(0,
"worker ", tid,
" started");
45 thread_local std::vector<std::unique_ptr<GEventDataCollection>> localRunData;
51 int evn = next.fetch_add(1, std::memory_order_relaxed);
52 if (evn > nevents)
break;
54 auto gheader = GEventHeader::create(gopt);
55 auto eventData = std::make_unique<GEventDataCollection>(gopt, std::move(gheader));
58 for (
unsigned i = 1; i < 3; i++) {
59 auto hit = GHit::create(gopt);
60 auto true_data = dynamicRoutinesMap->at(
plugin_name)->collectTrueInformation(hit, i);
61 auto digi_data = dynamicRoutinesMap->at(
plugin_name)->digitizeHit(hit, i);
63 eventData->addDetectorDigitizedData(
"ctof", std::move(digi_data));
64 eventData->addDetectorTrueInfoData(
"ctof", std::move(true_data));
67 log->info(0,
"worker ", tid,
" event ", evn,
" has ", eventData->getDataCollectionMap().at(
"ctof")->getDigitizedData().size(),
" digitized hits");
69 localRunData.emplace_back(std::move(eventData));
76 std::scoped_lock lk(collectorMtx);
77 for (
auto& evt : localRunData) {
79 if (collected.size() >= 2)
break;
80 collected.emplace_back(std::move(evt));
85 log->info(0,
"worker ", tid,
" processed ", localCount,
" events");
95int main(
int argc,
char* argv[]) {
100 auto log = std::make_shared<GLogger>(gopts, SFUNCTION_NAME, PLUGIN_LOGGER);
102 constexpr int nevents = 10;
103 constexpr int nthreads = 8;
106 if (dynamicRoutinesMap->at(
plugin_name)->loadConstants(1,
"default") ==
false) {
107 log->error(1,
"Failed to load constants for dynamic routine",
plugin_name,
"for run number 1 with variation 'default'.");
113 for (
size_t i = 0; i < runData.size(); i++) { log->info(
" > Event ", i + 1,
" collected with local event number: ", runData[i]->getEventNumber()); }
auto run_simulation_in_threads(int nevents, int nthreads, const std::shared_ptr< GOptions > &gopt, const std::shared_ptr< GLogger > &log, const std::shared_ptr< const gdynamicdigitization::dRoutinesMap > &dynamicRoutinesMap) -> std::vector< std::unique_ptr< GEventDataCollection > >