ECCE @ EIC Software
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4VRNtupleManager.hh
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file G4VRNtupleManager.hh
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 
34 #include "G4BaseAnalysisManager.hh"
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) {}
48  virtual ~G4VRNtupleManager() {}
49 
50  // deleted copy constructor & assignment operator
51  G4VRNtupleManager(const G4VRNtupleManager& rhs) = delete;
52  G4VRNtupleManager& operator=(const G4VRNtupleManager& rhs) = delete;
53 
54  protected:
55  // Methods to read ntuple from a file
56  // Methods for ntuple with id = FirstNtupleId
57  virtual G4bool SetNtupleIColumn(const G4String& columnName,
58  G4int& value) = 0;
59  virtual G4bool SetNtupleFColumn(const G4String& columnName,
60  G4float& value) = 0;
61  virtual G4bool SetNtupleDColumn(const G4String& columnName,
62  G4double& value) = 0;
63  virtual G4bool SetNtupleSColumn(const G4String& columnName,
64  G4String& value) = 0;
65  // Bind the ntuple columns of vector type
66  virtual G4bool SetNtupleIColumn(const G4String& columnName,
67  std::vector<G4int>& vector) = 0;
68  virtual G4bool SetNtupleFColumn(const G4String& columnName,
69  std::vector<G4float>& vector) = 0;
70  virtual G4bool SetNtupleDColumn(const G4String& columnName,
71  std::vector<G4double>& vector) = 0;
72  // Methods for ntuple with id > FirstNtupleId
73  virtual G4bool SetNtupleIColumn(G4int ntupleId,
74  const G4String& columnName, G4int& value)= 0;
75  virtual G4bool SetNtupleFColumn(G4int ntupleId,
76  const G4String& columnName, G4float& value)= 0;
77  virtual G4bool SetNtupleDColumn(G4int ntupleId,
78  const G4String& columnName, G4double& value)= 0;
79  virtual G4bool SetNtupleSColumn(G4int ntupleId,
80  const G4String& columnName, G4String& value)= 0;
81  // Bind the ntuple columns of vector type
82  virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String& columnName,
83  std::vector<G4int>& vector) = 0;
84  virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String& columnName,
85  std::vector<G4float>& vector) = 0;
86  virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String& columnName,
87  std::vector<G4double>& vector) = 0;
88  virtual G4bool GetNtupleRow() = 0;
89  virtual G4bool GetNtupleRow(G4int ntupleId) = 0;
90 
91  // Access methods
92  virtual G4int GetNofNtuples() const = 0;
93 };
94 
95 #endif
96