BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
Loading...
Searching...
No Matches
HistogramAccumulatorSum.hh
1/*
2Beam Delivery Simulation (BDSIM) Copyright (C) Royal Holloway,
3University of London 2001 - 2023.
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 HISTOGRAMACCUMULATORSUM_H
20#define HISTOGRAMACCUMULATORSUM_H
21
22#include "HistogramAccumulator.hh"
23
24#include <string>
25
26#include "Rtypes.h" // for classdef
27
28class TH1;
29
39{
40public:
43
45 HistogramAccumulatorSum(TH1* baseHistogram,
46 int nDimensionsIn,
47 const std::string& resultHistName,
48 const std::string& resultHistTitle);
49
50 virtual ~HistogramAccumulatorSum(){;}
51
53 virtual void Accumulate(TH1* newValue);
54
56 virtual TH1* Terminate();
57
58 ClassDef(HistogramAccumulatorSum, 1);
59};
60
61#endif
Class to Sum histogram.
virtual void Accumulate(TH1 *newValue)
Use TH1::Add which works on 1,2 and 3D histograms.
virtual TH1 * Terminate()
Simply return the result as it's already the correct result.
HistogramAccumulatorSum()
Public constructor only for compatibility with ROOT - not intended for use.
Class to accumulate and merge histograms in different ways.
const std::string resultHistName
Name for resultant histogram.
const std::string resultHistTitle
Title for resultant histogram.