Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4VRNtupleManager.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// The pure abstract base class for read Ntuple manager.
28//
29// Author: Ivana Hrivnacova, 09/04/2014 (ivana@ipno.in2p3.fr)
30
31#ifndef G4VRNtupleManager_h
32#define G4VRNtupleManager_h 1
33
35#include "globals.hh"
36
37#include <vector>
38
40{
41 // Disable using the object managers outside G4VAnalysisManager and
42 // its messenger
43 friend class G4VAnalysisReader;
44
45 public:
47 : G4BaseAnalysisManager(state) {}
49 ~G4VRNtupleManager() override = default;
50
51 // deleted copy constructor & assignment operator
54
55 protected:
56 // Methods to read ntuple from a file
57 virtual G4int ReadNtupleImpl(const G4String& ntupleName,
58 const G4String& fileName,
59 const G4String& dirName,
60 G4bool isUserFileName) = 0;
61
62 // Methods for ntuple with id = FirstNtupleId
63 virtual G4bool SetNtupleIColumn(const G4String& columnName,
64 G4int& value) = 0;
65 virtual G4bool SetNtupleFColumn(const G4String& columnName,
66 G4float& value) = 0;
67 virtual G4bool SetNtupleDColumn(const G4String& columnName,
68 G4double& value) = 0;
69 virtual G4bool SetNtupleSColumn(const G4String& columnName,
70 G4String& value) = 0;
71 // Bind the ntuple columns of vector type
72 virtual G4bool SetNtupleIColumn(const G4String& columnName,
73 std::vector<G4int>& vector) = 0;
74 virtual G4bool SetNtupleFColumn(const G4String& columnName,
75 std::vector<G4float>& vector) = 0;
76 virtual G4bool SetNtupleDColumn(const G4String& columnName,
77 std::vector<G4double>& vector) = 0;
78 virtual G4bool SetNtupleSColumn(const G4String& columnName,
79 std::vector<std::string>& vector) = 0;
80 // Methods for ntuple with id > FirstNtupleId
81 virtual G4bool SetNtupleIColumn(G4int ntupleId,
82 const G4String& columnName, G4int& value)= 0;
83 virtual G4bool SetNtupleFColumn(G4int ntupleId,
84 const G4String& columnName, G4float& value)= 0;
85 virtual G4bool SetNtupleDColumn(G4int ntupleId,
86 const G4String& columnName, G4double& value)= 0;
87 virtual G4bool SetNtupleSColumn(G4int ntupleId,
88 const G4String& columnName, G4String& value)= 0;
89 // Bind the ntuple columns of vector type
90 virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String& columnName,
91 std::vector<G4int>& vector) = 0;
92 virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String& columnName,
93 std::vector<G4float>& vector) = 0;
94 virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String& columnName,
95 std::vector<G4double>& vector) = 0;
96 virtual G4bool SetNtupleSColumn(G4int ntupleId, const G4String& columnName,
97 std::vector<std::string>& vector) = 0;
98 virtual G4bool GetNtupleRow() = 0;
99 virtual G4bool GetNtupleRow(G4int ntupleId) = 0;
100
101 // Access methods
102 virtual G4int GetNofNtuples() const = 0;
103};
104
105#endif
106
float G4float
Definition G4Types.hh:84
double G4double
Definition G4Types.hh:83
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
virtual G4bool SetNtupleSColumn(const G4String &columnName, std::vector< std::string > &vector)=0
G4VRNtupleManager()=delete
virtual G4int ReadNtupleImpl(const G4String &ntupleName, const G4String &fileName, const G4String &dirName, G4bool isUserFileName)=0
virtual G4bool GetNtupleRow(G4int ntupleId)=0
virtual G4bool GetNtupleRow()=0
virtual G4bool SetNtupleFColumn(const G4String &columnName, G4float &value)=0
virtual G4bool SetNtupleDColumn(const G4String &columnName, std::vector< G4double > &vector)=0
virtual G4bool SetNtupleIColumn(const G4String &columnName, G4int &value)=0
virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String &columnName, G4int &value)=0
virtual G4int GetNofNtuples() const =0
virtual G4bool SetNtupleSColumn(G4int ntupleId, const G4String &columnName, std::vector< std::string > &vector)=0
virtual G4bool SetNtupleDColumn(const G4String &columnName, G4double &value)=0
~G4VRNtupleManager() override=default
virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String &columnName, G4float &value)=0
virtual G4bool SetNtupleSColumn(G4int ntupleId, const G4String &columnName, G4String &value)=0
virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String &columnName, G4double &value)=0
G4VRNtupleManager & operator=(const G4VRNtupleManager &rhs)=delete
virtual G4bool SetNtupleFColumn(const G4String &columnName, std::vector< G4float > &vector)=0
virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String &columnName, std::vector< G4int > &vector)=0
virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String &columnName, std::vector< G4float > &vector)=0
virtual G4bool SetNtupleIColumn(const G4String &columnName, std::vector< G4int > &vector)=0
G4VRNtupleManager(const G4AnalysisManagerState &state)
virtual G4bool SetNtupleSColumn(const G4String &columnName, G4String &value)=0
G4VRNtupleManager(const G4VRNtupleManager &rhs)=delete
virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String &columnName, std::vector< G4double > &vector)=0