Geant4  v4-10.4-release
 모두 클래스 네임스페이스들 파일들 함수 변수 타입정의 열거형 타입 열거형 멤버 Friends 매크로 그룹들 페이지들
G4Hdf5FileManager.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 // $Id$
27 
28 // The manager for Hdf5 file output operations.
29 
30 // Author: Ivana Hrivnacova, 20/07/2017 (ivana@ipno.in2p3.fr)
31 
32 #ifndef G4Hdf5FileManager_h
33 #define G4Hdf5FileManager_h 1
34 
35 #include "G4VFileManager.hh"
36 #include "G4TNtupleDescription.hh"
37 #include "globals.hh"
38 
39 #include "tools/hdf5/ntuple"
40 
41 #include <fstream>
42 #include <memory>
43 
45 
47 {
48  public:
49  explicit G4Hdf5FileManager(const G4AnalysisManagerState& state);
51 
52  // Type aliases
55 
56  // Methods to manipulate output files
57  virtual G4bool OpenFile(const G4String& fileName) final;
58  virtual G4bool WriteFile() final;
59  virtual G4bool CloseFile() final;
60 
63  void CloseAfterHnWrite();
64 
65  // Set methods
66  void SetBasketSize(unsigned int basketSize);
67 
68  // Get methods
69  hid_t GetFile() const;
70  hid_t GetHistoDirectory() const;
71  hid_t GetNtupleDirectory() const;
72  unsigned int GetBasketSize() const;
73 
74  private:
75  G4bool CreateDirectory(const G4String& directoryType,
76  const G4String& directoryName, hid_t& directory);
77  G4bool WriteDirectory(const G4String& directoryType,
78  const G4String& directoryName, hid_t& directory);
79 
80  // constants
82 
83  // data members
84  hid_t fFile;
87  unsigned int fBasketSize;
88 };
89 
90 // inline functions
91 
92 inline void G4Hdf5FileManager::SetBasketSize(unsigned int basketSize)
93 { fBasketSize = basketSize; }
94 
95 inline hid_t G4Hdf5FileManager::GetFile() const
96 { return fFile; }
97 
99 { return fHistoDirectory; }
100 
102 { return fNtupleDirectory; }
103 
104 inline unsigned int G4Hdf5FileManager::GetBasketSize() const
105 { return fBasketSize; }
106 
107 #endif
tools::hdf5::ntuple NtupleType
hid_t GetFile() const
#define inline
Definition: internal.h:71
TTree * ntuple
unsigned int GetBasketSize() const
static const G4String fgkDefaultDirectoryName
hid_t GetHistoDirectory() const
G4bool WriteDirectory(const G4String &directoryType, const G4String &directoryName, hid_t &directory)
G4bool CreateDirectory(const G4String &directoryType, const G4String &directoryName, hid_t &directory)
unsigned int fBasketSize
bool G4bool
Definition: G4Types.hh:79
void SetBasketSize(unsigned int basketSize)
hid_t GetNtupleDirectory() const
const G4ThreeVector const G4double const
G4Hdf5FileManager(const G4AnalysisManagerState &state)
virtual G4bool OpenFile(const G4String &fileName) final
virtual G4bool CloseFile() final
virtual G4bool WriteFile() final