BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
HistogramMeanFromFile.hh
1/*
2Beam Delivery Simulation (BDSIM) Copyright (C) Royal Holloway,
3University of London 2001 - 2022.
4
5This file is part of BDSIM.
6
7BDSIM is free software: you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published
9by the Free Software Foundation version 3 of the License.
10
11BDSIM is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with BDSIM. If not, see <http://www.gnu.org/licenses/>.
18*/
19#ifndef HISTOGRAMMEANFROMFILE_H
20#define HISTOGRAMMEANFROMFILE_H
21
22#include <vector>
23
24#include "Rtypes.h" // for classdef
25
27
29
30class TDirectory;
31
42{
43public:
46
49
50 virtual ~HistogramMeanFromFile();
51
55
57 void Terminate();
58
60 void Write(TDirectory* dir = nullptr);
61
62private:
63
64 std::vector<HistogramAccumulator*> histograms1d;
65 std::vector<HistogramAccumulator*> histograms2d;
66 std::vector<HistogramAccumulator*> histograms3d;
67 std::vector<HistogramAccumulator*> histograms4d;
68
69 ClassDef(HistogramMeanFromFile, 1);
70};
71
72#endif
Holder for a set of histograms to be stored.
Class to accumulate and merge histograms in different ways.
Accumulator to merge pre-made per-entry histograms.
void Write(TDirectory *dir=nullptr)
Write to file.
HistogramMeanFromFile()
Public constructor only for compatibility with ROOT - not indended for use.
void Accumulate(BDSOutputROOTEventHistograms *hNew)
void Terminate()
Finish calculation.