50 const std::shared_ptr<GOptions>& gopt,
51 const std::shared_ptr<GLogger>& log,
52 const std::shared_ptr<const gdynamicdigitization::dRoutinesMap>& dynamicRoutinesMap)
53 -> std::vector<std::unique_ptr<GEventDataCollection>> {
54 std::mutex collectorMtx;
55 std::vector<std::unique_ptr<GEventDataCollection>> collected;
58 std::atomic<int> next{1};
61 std::vector<jthread_alias> pool;
62 pool.reserve(nthreads);
64 for (
int tid = 0; tid < nthreads; ++tid) {
65 pool.emplace_back([&, tid] {
66 log->info(0,
"worker ", tid,
" started");
69 thread_local std::vector<std::unique_ptr<GEventDataCollection>> localRunData;
72 int evn = next.fetch_add(1, std::memory_order_relaxed);
73 if (evn > nevents)
break;
76 auto eventData = std::make_unique<GEventDataCollection>(gopt, std::move(gevent_header));
79 for (
unsigned i = 1; i < 3; i++) {
81 auto true_data = dynamicRoutinesMap->at(
plugin_name)->collectTrueInformation(hit, i);
82 auto digi_data = dynamicRoutinesMap->at(
plugin_name)->digitizeHit(hit, i);
84 eventData->addDetectorDigitizedData(
"ctof", std::move(digi_data));
85 eventData->addDetectorTrueInfoData(
"ctof", std::move(true_data));
88 log->info(0,
"worker ", tid,
" event ", evn,
" has ",
89 eventData->getDataCollectionMap().at(
"ctof")->getDigitizedData().size(),
" digitized hits");
91 localRunData.emplace_back(std::move(eventData));
97 std::scoped_lock lk(collectorMtx);
98 for (
auto& evt : localRunData) {
99 if (collected.size() >= 2)
break;
100 collected.emplace_back(std::move(evt));
102 localRunData.clear();
105 log->info(0,
"worker ", tid,
" processed ", localCount,
" events");
127int main(
int argc,
char* argv[]) {
135 constexpr int nevents = 10;
136 constexpr int nthreads = 8;
140 if (dynamicRoutinesMap->at(
plugin_name)->loadConstants(1,
"default") ==
false) {
141 log->error(1,
"Failed to load constants for dynamic routine ",
plugin_name,
142 " for run number 1 with variation 'default'.");
148 for (
size_t i = 0; i < runData.size(); i++) {
149 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 > >
Runs a small simulated event loop using multiple worker threads.