Geant4-11
G4Hdf5AnalysisManager.cc
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// Author: Ivana Hrivnacova, 20/07/2017 (ivana@ipno.in2p3.fr)
28
30#include "G4Hdf5FileManager.hh"
35#include "G4Threading.hh"
36#include "G4AutoLock.hh"
37
38using namespace G4Analysis;
39
40// mutex in a file scope
41
42namespace {
43 //Mutex to lock master manager when opening a file
45 //Mutex to lock master manager when closing a file
47}
48
49// G4Hdf5AnalysisManager* G4Hdf5AnalysisManager::fgMasterInstance = nullptr;
50// G4ThreadLocal G4bool G4Hdf5AnalysisManager::fgIsInstance = false;
51
52//_____________________________________________________________________________
54{
56 fgIsInstance = true;
57 return instance.Instance();
58}
59
60//_____________________________________________________________________________
62{
63 return fgIsInstance;
64}
65
66//_____________________________________________________________________________
69{
70#ifdef G4MULTITHREADED
71#ifndef H5_HAVE_THREADSAFE
72 G4Exception("G4Hdf5AnalysisManager::G4Hdf5AnalysisManager",
73 "Analysis_F001", FatalException,
74 "Your HDF5 lib is not built with H5_HAVE_THREADSAFE.");
75#endif
76#endif
77
79
80 // File manager
81 fFileManager = std::make_shared<G4Hdf5FileManager>(fState);
83
84 // Ntuple file manager
85 fNtupleFileManager = std::make_shared<G4Hdf5NtupleFileManager>(fState);
86 fNtupleFileManager->SetFileManager(fFileManager);
87 fNtupleFileManager->SetBookingManager(fNtupleBookingManager);
88}
89
90//_____________________________________________________________________________
92{
93 if ( fState.GetIsMaster() ) fgMasterInstance = nullptr;
94 fgIsInstance = false;
95}
96
97//
98// protected methods
99//
100
101//_____________________________________________________________________________
103{
104 // Create ntuple manager(s)
105 // and set it to base class which takes then their ownership
106 SetNtupleManager(fNtupleFileManager->CreateNtupleManager());
107
108 auto result = true;
109
111 result &= fFileManager->OpenFile(fileName);
112 result &= fNtupleFileManager->ActionAtOpenFile(fFileManager->GetFullFileName());
113 lock.unlock();
114
115 return result;
116}
117
118//_____________________________________________________________________________
120{
121 auto result = true;
122
123 Message(kVL4, "write", "files");
124
127 }
128 else {
129 // Open all files registered with objects
130 fFileManager->OpenFiles();
131
132 // Write all histograms/profile on master
134 }
135
136 // Write ASCII if activated
137 if ( IsAscii() ) {
138 result &= WriteAscii(fFileManager->GetFileName());
139 }
140
141 Message(kVL3, "write", "files", "", result);
142
143 return result;
144}
145
146//_____________________________________________________________________________
148{
149 auto result = true;
150
152 result &= fFileManager->CloseFiles();
153
154 if ( reset ) {
155 // reset data
156 result = ResetImpl();
157 if ( ! result ) {
158 Warn("Resetting data failed", fkClass, "OpenDirectory");
159 }
160 }
161 result &= fNtupleFileManager->ActionAtCloseFile(reset);
162
163 lock.unlock();
164
165 return result;
166}
167
168//_____________________________________________________________________________
170{
171 auto result = true;
172
174 if ( fNtupleFileManager != nullptr ) {
175 result &= fNtupleFileManager->Reset();
176 }
177
178 return result;
179}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
Definition: G4Exception.cc:35
#define G4MUTEX_INITIALIZER
Definition: G4Threading.hh:85
std::mutex G4Mutex
Definition: G4Threading.hh:81
bool G4bool
Definition: G4Types.hh:86
virtual G4bool CloseFileImpl(G4bool reset) final
virtual G4bool OpenFileImpl(const G4String &fileName) final
virtual G4bool WriteImpl() final
static G4Hdf5AnalysisManager * fgMasterInstance
static G4Hdf5AnalysisManager * Instance()
virtual G4bool ResetImpl() final
static G4ThreadLocal G4bool fgIsInstance
std::shared_ptr< G4Hdf5NtupleFileManager > fNtupleFileManager
static constexpr std::string_view fkClass
std::shared_ptr< G4Hdf5FileManager > fFileManager
virtual G4bool ResetImpl() override
virtual G4bool WriteImpl() override
std::shared_ptr< G4NtupleBookingManager > fNtupleBookingManager
void Message(G4int level, const G4String &action, const G4String &objectType, const G4String &objectName="", G4bool success=true) const
G4AnalysisManagerState fState
void SetFileManager(std::shared_ptr< G4VFileManager > fileManager)
G4bool WriteAscii(const G4String &fileName)
void SetNtupleManager(std::shared_ptr< G4VNtupleManager > ntupleManager)
constexpr G4int kVL3
constexpr G4int kVL4
void Warn(const G4String &message, const std::string_view inClass, const std::string_view inFunction)
G4bool IsWorkerThread()
Definition: G4Threading.cc:123