Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4TNtupleDescription.hh
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26
27// Structure templated containing the information related to an ntuple
28// for all output types.
29//
30// Author: Ivana Hrivnacova, 19/06/2015 ([email protected])
31
32#ifndef G4TNtupleDescription_h
33#define G4TNtupleDescription_h 1
34
36#include "globals.hh"
37
38#include "tools/ntuple_booking"
39
40#include <fstream>
41
42template <typename NT, typename FT>
44{
45 public:
47 : fNtupleBooking(g4NtupleBooking->fNtupleBooking),
48 fFileName(g4NtupleBooking->fFileName),
49 fActivation(g4NtupleBooking->fActivation)
50 {}
51
54 {
55 if ( fIsNtupleOwner ) delete fNtuple;
56 }
57
58 // Set methods
59 void SetFile(std::shared_ptr<FT> file);
60 void SetNtuple(NT* ntuple);
61 void SetFileName(const G4String& fileName);
62 void SetActivation(G4bool activation);
63 void SetIsNtupleOwner(G4bool isNtupleOwner);
64 void SetHasFill(G4bool hasFill);
65 void Reset();
66
67 // Get methods
68 std::shared_ptr<FT> GetFile() const;
69 NT* GetNtuple() const;
70 const tools::ntuple_booking& GetNtupleBooking() const;
75
76 private:
77 std::shared_ptr<FT> fFile { nullptr };
78 NT* fNtuple { nullptr };
79 tools::ntuple_booking fNtupleBooking;
80 G4String fFileName;
81 G4bool fActivation { true };
82 G4bool fIsNtupleOwner { true };
83 G4bool fHasFill { false };
84};
85
86// inline functions
87
88template <typename NT, typename FT>
89void G4TNtupleDescription<NT, FT>::SetFile(std::shared_ptr<FT> file)
90{ fFile = file; }
91
92template <typename NT, typename FT>
94{ fNtuple = ntuple; }
95
96template <typename NT, typename FT>
98{ fFileName = fileName; }
99
100template <typename NT, typename FT>
102{ fActivation = activation; }
103
104template <typename NT, typename FT>
106{ fIsNtupleOwner = isNtupleOwner; }
107
108template <typename NT, typename FT>
110{ fHasFill = hasFill; }
111
112template <typename NT, typename FT>
114{
115 if (fIsNtupleOwner) delete fNtuple;
116 fNtuple = nullptr;
117}
118
119template <typename NT, typename FT>
120std::shared_ptr<FT> G4TNtupleDescription<NT, FT>::GetFile() const
121{ return fFile; }
122
123template <typename NT, typename FT>
125{ return fNtuple; }
126
127template <typename NT, typename FT>
128const tools::ntuple_booking&
130{ return fNtupleBooking; }
131
132template <typename NT, typename FT>
134{ return fFileName; }
135
136template <typename NT, typename FT>
138{ return fActivation; }
139
140template <typename NT, typename FT>
142{ return fIsNtupleOwner; }
143
144template <typename NT, typename FT>
146{ return fHasFill; }
147
148#endif
bool G4bool
Definition: G4Types.hh:86
void SetFile(std::shared_ptr< FT > file)
const tools::ntuple_booking & GetNtupleBooking() const
G4TNtupleDescription(G4NtupleBooking *g4NtupleBooking)
void SetNtuple(NT *ntuple)
void SetIsNtupleOwner(G4bool isNtupleOwner)
void SetActivation(G4bool activation)
void SetFileName(const G4String &fileName)
G4TNtupleDescription()=delete
std::shared_ptr< FT > GetFile() const
G4String GetFileName() const
void SetHasFill(G4bool hasFill)