// // ******************************************************************** // * License and Disclaimer * // * * // * The Geant4 software is copyright of the Copyright Holders of * // * the Geant4 Collaboration. It is provided under the terms and * // * conditions of the Geant4 Software License, included in the file * // * LICENSE and available at http://cern.ch/geant4/license . These * // * include a list of copyright holders. * // * * // * Neither the authors of this software system, nor their employing * // * institutes,nor the agencies providing financial support for this * // * work make any representation or warranty, express or implied, * // * regarding this software system or assume any liability for its * // * use. Please see the license in the file LICENSE and URL above * // * for the full disclaimer and the limitation of liability. * // * * // * This code implementation is the result of the scientific and * // * technical work of the GEANT4 collaboration. * // * By using, copying, modifying or distributing the software (or * // * any work based on the software) you agree to acknowledge its * // * use in resulting scientific publications, and indicate your * // * acceptance of all terms of the Geant4 Software license. * // ******************************************************************** // // $Id: G4VNtupleManager.hh 70604 2013-06-03 11:27:06Z ihrivnac $ // Base class for Ntuple manager. // It defines functions independent from the output type. // // Author: Ivana Hrivnacova, 18/06/2013 (ivana@ipno.in2p3.fr) #ifndef G4VNtupleManager_h #define G4VNtupleManager_h 1 #include "G4BaseAnalysisManager.hh" #include "globals.hh" #include class G4VNtupleManager : public G4BaseAnalysisManager { // Disable using the object managers outside G4VAnalysisManager and // its messenger friend class G4VAnalysisManager; protected: G4VNtupleManager(const G4AnalysisManagerState& state); virtual ~G4VNtupleManager(); // Methods for handling ntuples virtual G4int CreateNtuple(const G4String& name, const G4String& title) = 0; // Create columns in the last created ntuple virtual G4int CreateNtupleIColumn(const G4String& name) = 0; virtual G4int CreateNtupleFColumn(const G4String& name) = 0; virtual G4int CreateNtupleDColumn(const G4String& name) = 0; virtual void FinishNtuple() = 0; // Create columns in the ntuple with given id virtual G4int CreateNtupleIColumn(G4int ntupleId, const G4String& name) = 0; virtual G4int CreateNtupleFColumn(G4int ntupleId, const G4String& name) = 0; virtual G4int CreateNtupleDColumn(G4int ntupleId, const G4String& name) = 0; virtual void FinishNtuple(G4int ntupleId) = 0; // The ntuple column ids are generated automatically starting from 0; // with the following function it is possible to change it // to start from another value G4bool SetFirstNtupleColumnId(G4int firstId); // Methods to fill histogrammes, ntuples // Methods for ntuple with id = FirstNtupleId virtual G4bool FillNtupleIColumn(G4int id, G4int value) = 0; virtual G4bool FillNtupleFColumn(G4int id, G4float value) = 0; virtual G4bool FillNtupleDColumn(G4int id, G4double value) = 0; virtual G4bool AddNtupleRow() = 0; // Methods for ntuple with id > FirstNtupleId (when more ntuples exist) virtual G4bool FillNtupleIColumn(G4int ntupleId, G4int columnId, G4int value) = 0; virtual G4bool FillNtupleFColumn(G4int ntupleId, G4int columnId, G4float value) = 0; virtual G4bool FillNtupleDColumn(G4int ntupleId, G4int columnId, G4double value) = 0; virtual G4bool AddNtupleRow(G4int ntupleId) = 0; // Access methods virtual G4int GetNofNtuples() const = 0; protected: G4int fFirstNtupleColumnId; G4bool fLockFirstNtupleColumnId; }; #endif