ECCE @ EIC Software
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4BaseRNtupleManager.hh
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file G4BaseRNtupleManager.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 base class for read Ntuple manager.
28 // It defines functions independent from the output type.
29 //
30 // Author: Ivana Hrivnacova, 20/07/2017 (ivana@ipno.in2p3.fr)
31 
32 #ifndef G4BaseRNtupleManager_h
33 #define G4BaseRNtupleManager_h 1
34 
35 #include "G4VRNtupleManager.hh"
36 #include "globals.hh"
37 
38 #include <vector>
39 
41 {
42  // Disable using the object managers outside G4VAnalysisManager and
43  // its messenger
44  friend class G4VAnalysisReader;
45 
46  public:
47  explicit G4BaseRNtupleManager(const G4AnalysisManagerState& state);
48  virtual ~G4BaseRNtupleManager();
49 
50  // deleted copy constructor & assignment operator
51  G4BaseRNtupleManager(const G4BaseRNtupleManager& 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) final;
59  virtual G4bool SetNtupleFColumn(const G4String& columnName,
60  G4float& value) final;
61  virtual G4bool SetNtupleDColumn(const G4String& columnName,
62  G4double& value) final;
63  virtual G4bool SetNtupleSColumn(const G4String& columnName,
64  G4String& value) final;
65  // Methods for ntuple with id > FirstNtupleId
66  virtual G4bool SetNtupleIColumn(G4int ntupleId,
67  const G4String& columnName, G4int& value)= 0;
68  virtual G4bool SetNtupleFColumn(G4int ntupleId,
69  const G4String& columnName, G4float& value)= 0;
70  virtual G4bool SetNtupleDColumn(G4int ntupleId,
71  const G4String& columnName, G4double& value)= 0;
72  virtual G4bool SetNtupleSColumn(G4int ntupleId,
73  const G4String& columnName, G4String& value)= 0;
74  // Bind the ntuple columns of vector type
75  // Methods for ntuple with id = FirstNtupleId
76  virtual G4bool SetNtupleIColumn(const G4String& columnName,
77  std::vector<G4int>& vector) final;
78  virtual G4bool SetNtupleFColumn(const G4String& columnName,
79  std::vector<G4float>& vector) final;
80  virtual G4bool SetNtupleDColumn(const G4String& columnName,
81  std::vector<G4double>& vector) final;
82  // Methods for ntuple with id > FirstNtupleId
83  virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String& columnName,
84  std::vector<G4int>& vector) = 0;
85  virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String& columnName,
86  std::vector<G4float>& vector) = 0;
87  virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String& columnName,
88  std::vector<G4double>& vector) = 0;
89  virtual G4bool GetNtupleRow() final;
90  virtual G4bool GetNtupleRow(G4int ntupleId) = 0;
91 
92  // Access methods
93  virtual G4int GetNofNtuples() const = 0;
94 
95  private:
96  // methods
97  G4int GetCurrentNtupleId() const;
98 };
99 
100 #endif
101