Geant4  10.03
DicomRun.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 // $Id: DicomRun.hh 92820 2015-09-17 15:22:14Z gcosmo $
27 //
30 //
31 
32 #ifndef DicomRun_h
33 #define DicomRun_h 1
34 
35 #include "G4Run.hh"
36 #include "G4Event.hh"
37 
38 #include "G4THitsMap.hh"
39 #include <vector>
40 
41 //---------------------------------------------------------------------
48 //---------------------------------------------------------------------
49 
50 class DicomRun : public G4Run {
51 
52 public:
53  // constructor and destructor.
54  // vector of multifunctionaldetector name has to given to constructor.
55  DicomRun();
56  DicomRun(const std::vector<G4String> mfdName);
57  virtual ~DicomRun();
58 
59 public:
60  // virtual method from G4Run.
61  // The method is overriden in this class for scoring.
62  virtual void RecordEvent(const G4Event*);
63 
64  // Access methods for scoring information.
65  // - Number of HitsMap for this RUN.
66  // This is equal to number of collections.
67  G4int GetNumberOfHitsMap() const {return fRunMap.size();}
68  // - Get HitsMap of this RUN.
69  // by sequential number, by multifucntional name and collection name,
70  // and by collection name with full path.
72  G4THitsMap<G4double>* GetHitsMap(const G4String& detName,
73  const G4String& colName) const;
74  G4THitsMap<G4double>* GetHitsMap(const G4String& fullName) const;
75 
76  void ConstructMFD(const std::vector<G4String>&);
77 
78  virtual void Merge(const G4Run*);
79 
80 private:
81  std::vector<G4String> fCollName;
82  std::vector<G4int> fCollID;
83  std::vector<G4THitsMap<G4double>*> fRunMap;
84 
85 };
86 
87 //==========================================================================
88 // Generic Functions to help with merge
89 //==========================================================================
90 template <typename T>
91 inline void Copy(std::vector<T>& main, const std::vector<T>& data)
92 {
93  for(unsigned i = main.size(); i < data.size(); ++i) {
94  main.push_back(data.at(i));
95  }
96 }
97 //==========================================================================
98 template <typename T>
99 inline unsigned Copy(std::vector<T*>& main, const std::vector<T*>& data)
100 {
101  unsigned size_diff = data.size() - main.size();
102  for(unsigned i = main.size(); i < data.size(); ++i) {
103  main.push_back(new T(*data.at(i)));
104  }
105  return size_diff;
106 }
107 //==========================================================================
108 template <typename T>
109 inline void Print(const std::vector<T>& data)
110 {
111  G4cout << G4endl;
112  for(unsigned i = 0; i < data.size(); ++i) {
113  G4cout << "\t\t" << i << " \t\t " << data.at(i) << G4endl;
114  }
115  G4cout << G4endl;
116 }
117 //==========================================================================
118 
119 #endif
DicomRun class.
Definition: DicomRun.hh:50
virtual void Merge(const G4Run *)
Definition: DicomRun.cc:190
void Copy(std::vector< T > &main, const std::vector< T > &data)
Definition: DicomRun.hh:91
virtual void RecordEvent(const G4Event *)
Definition: DicomRun.cc:151
void ConstructMFD(const std::vector< G4String > &)
Definition: DicomRun.cc:100
virtual ~DicomRun()
Definition: DicomRun.cc:84
int G4int
Definition: G4Types.hh:78
G4int GetNumberOfHitsMap() const
Definition: DicomRun.hh:67
G4GLOB_DLL std::ostream G4cout
DicomRun()
(Description) DicomRun Class is for accumulating scored quantities which is scored using G4MutiFuncti...
Definition: DicomRun.cc:67
Definition: G4Run.hh:46
void Print(const std::vector< T > &data)
Definition: DicomRun.hh:109
int main(int argc, char **argv)
Definition: genwindef.cc:359
std::vector< G4THitsMap< G4double > * > fRunMap
Definition: DicomRun.hh:83
#define G4endl
Definition: G4ios.hh:61
G4THitsMap< G4double > * GetHitsMap(G4int i) const
Definition: DicomRun.hh:71
std::vector< G4String > fCollName
Definition: DicomRun.hh:81
std::vector< G4int > fCollID
Definition: DicomRun.hh:82