Geant4 11.2.2
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 <fstream>
39
40template <typename NT, typename FT>
42{
43 public:
45 : fG4NtupleBooking(g4NtupleBooking)
46 {}
47
50 {
51 if ( fIsNtupleOwner ) delete fNtuple;
52 }
53
54 // Set methods
55 void SetFile(std::shared_ptr<FT> file);
56 void SetNtuple(NT* ntuple);
57 void SetFileName(const G4String& fileName);
58 void SetActivation(G4bool activation);
59 void SetIsNtupleOwner(G4bool isNtupleOwner);
60 void SetHasFill(G4bool hasFill);
61 void Reset();
62
63 // Get methods
64 std::shared_ptr<FT> GetFile() const;
65 NT* GetNtuple() const;
67 const tools::ntuple_booking& GetNtupleBooking() const;
68
73
74 private:
75 std::shared_ptr<FT> fFile { nullptr };
76 NT* fNtuple { nullptr };
77 G4NtupleBooking* fG4NtupleBooking { nullptr };
78 G4bool fIsNtupleOwner { true };
79 G4bool fHasFill { false };
80};
81
82// inline functions
83
84template <typename NT, typename FT>
85void G4TNtupleDescription<NT, FT>::SetFile(std::shared_ptr<FT> file)
86{ fFile = file; }
87
88template <typename NT, typename FT>
90{ fNtuple = ntuple; }
91
92template <typename NT, typename FT>
94{ fG4NtupleBooking->fFileName = fileName; }
95
96template <typename NT, typename FT>
98{ fG4NtupleBooking->fActivation = activation; }
99
100template <typename NT, typename FT>
102{ fIsNtupleOwner = isNtupleOwner; }
103
104template <typename NT, typename FT>
106{ fHasFill = hasFill; }
107
108template <typename NT, typename FT>
110{
111 if (fIsNtupleOwner) delete fNtuple;
112 fNtuple = nullptr;
113}
114
115template <typename NT, typename FT>
116std::shared_ptr<FT> G4TNtupleDescription<NT, FT>::GetFile() const
117{ return fFile; }
118
119template <typename NT, typename FT>
121{ return fNtuple; }
122
123template <typename NT, typename FT>
126{ return fG4NtupleBooking; }
127
128template <typename NT, typename FT>
129const tools::ntuple_booking&
131{ return fG4NtupleBooking->fNtupleBooking; }
132
133template <typename NT, typename FT>
135{ return fG4NtupleBooking->fFileName; }
136
137template <typename NT, typename FT>
139{ return fG4NtupleBooking->fActivation; }
140
141template <typename NT, typename FT>
143{ return fIsNtupleOwner; }
144
145template <typename NT, typename FT>
147{ return fHasFill; }
148
149#endif
bool G4bool
Definition G4Types.hh:86
void SetFile(std::shared_ptr< FT > file)
const tools::ntuple_booking & GetNtupleBooking() const
G4TNtupleDescription(G4NtupleBooking *g4NtupleBooking)
void SetIsNtupleOwner(G4bool isNtupleOwner)
void SetActivation(G4bool activation)
G4NtupleBooking * GetG4NtupleBooking() const
void SetFileName(const G4String &fileName)
G4TNtupleDescription()=delete
std::shared_ptr< FT > GetFile() const
void SetHasFill(G4bool hasFill)
tools::ntuple_booking fNtupleBooking