13 void mt103_fillNtupleFromMultipleThreads()
22 const size_t nEntries = 65535;
25 const size_t nWorkers = 4;
28 const size_t nEventsPerWorker = nEntries / nWorkers;
31 auto fileName =
"mt103_fillNtupleFromMultipleThreads.root";
38 auto work_function = [&](
int seed) {
39 auto f = merger.GetFile();
40 TNtuple ntrand(
"ntrand",
"Random Numbers",
"r");
49 for (
auto i :
ROOT::TSeqI(nEntries)) ntrand.Fill(rnd.Gaus());
54 std::vector<std::thread> workers;
57 workers.emplace_back(work_function, i+1);
60 for (
auto &&worker : workers) worker.join();
This is the base class for the ROOT Random number generators.
A simple TTree restricted to a list of float variables only.
TBufferMerger is a class to facilitate writing data in parallel from multiple threads, while writing to a single output file.
void EnableThreadSafety()
Enables the global mutex to make ROOT thread safe/aware.
A pseudo container class which is a generator of indices.