Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4XmlRNtupleManager.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// Manager class for Xml read ntuples.
28// It implements functions specific to Xml read ntuples.
29//
30// Author: Ivana Hrivnacova, 25/07/2014 ([email protected])
31
32#ifndef G4XmlRNtupleManager_h
33#define G4XmlRNtupleManager_h 1
34
35#include "G4TRNtupleManager.hh"
36#include "globals.hh"
37
38#include "toolx/raxml"
39
40#include <string_view>
41#include <utility>
42#include <vector>
43
45struct G4XmlRNtupleDescription;
46
47class G4XmlRNtupleManager : public G4TRNtupleManager<tools::aida::ntuple>
48{
49 friend class G4XmlAnalysisReader;
50
51 public:
52 explicit G4XmlRNtupleManager(const G4AnalysisManagerState& state);
54 ~G4XmlRNtupleManager() override = default;
55
56 protected:
57 // Set methods
58 void SetFileManager(std::shared_ptr<G4XmlRFileManager> fileManager);
59
60 // Methods from base classes
64 using G4TRNtupleManager<tools::aida::ntuple>::SetNtupleIColumn;
65 using G4TRNtupleManager<tools::aida::ntuple>::SetNtupleFColumn;
66 using G4TRNtupleManager<tools::aida::ntuple>::SetNtupleDColumn;
67 using G4TRNtupleManager<tools::aida::ntuple>::SetNtupleSColumn;
68
69 // Override base class functions for vector columns
70 // in order to fill the maps
71
73 G4int ntupleId, const G4String& columnName, std::vector<G4int>& vector) final;
75 G4int ntupleId, const G4String& columnName, std::vector<G4float>& vector) final;
77 G4int ntupleId, const G4String& columnName, std::vector<G4double>& vector) final;
79 G4int ntupleId, const G4String& columnName, std::vector<std::string>& vector) final;
80
81 private:
82 // Methods from the base class
83 G4int ReadNtupleImpl(const G4String& ntupleName, const G4String& fileName,
84 const G4String& dirName, G4bool isUserFileName) final;
85 G4bool GetTNtupleRow(G4TRNtupleDescription<tools::aida::ntuple>* ntupleDescription) final;
86
87 // Static data members
88 static constexpr std::string_view fkClass { "G4XmlRNtupleManager" };
89
90 // Data members
91 std::shared_ptr<G4XmlRFileManager> fFileManager { nullptr };
92};
93
94inline void
95G4XmlRNtupleManager::SetFileManager(std::shared_ptr<G4XmlRFileManager> fileManager)
96{
97 fFileManager = std::move(fileManager);
98}
99
100#endif
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
G4bool SetNtupleFColumn(const G4String &columnName, G4float &value) final
G4bool SetNtupleDColumn(const G4String &columnName, G4double &value) final
G4bool SetNtupleIColumn(const G4String &columnName, G4int &value) final
G4bool SetNtupleIColumn(G4int ntupleId, const G4String &columnName, std::vector< G4int > &vector) final
G4bool SetNtupleFColumn(G4int ntupleId, const G4String &columnName, std::vector< G4float > &vector) final
G4bool SetNtupleSColumn(G4int ntupleId, const G4String &columnName, std::vector< std::string > &vector) final
~G4XmlRNtupleManager() override=default
G4bool SetNtupleDColumn(G4int ntupleId, const G4String &columnName, std::vector< G4double > &vector) final
void SetFileManager(std::shared_ptr< G4XmlRFileManager > fileManager)
G4XmlRNtupleManager()=delete