00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #ifndef StMcEmcHitCollection_hh
00033 #define StMcEmcHitCollection_hh
00034
00035 #include "StMcEmcModuleHitCollection.hh"
00036
00037 class StMcCalorimeterHit;
00038
00039 class StMcEmcHitCollection : public TDataSet {
00040 public:
00041 enum EAddHit {kNull, kErr, kNew, kAdd};
00042 enum {mNumberOfModules=120};
00043 StMcEmcHitCollection();
00044 StMcEmcHitCollection(char*);
00045 StMcEmcHitCollection(const char*);
00046 virtual ~StMcEmcHitCollection();
00047
00048 StMcEmcHitCollection::EAddHit addHit(StMcCalorimeterHit*);
00049 unsigned long numberOfHits() const;
00050 unsigned int numberOfModules() const { return mNumberOfModules; }
00051 float sum() const;
00052
00053 StMcEmcModuleHitCollection* module(unsigned int m);
00054 const StMcEmcModuleHitCollection* module(unsigned int m) const;
00055
00056 StMcEmcModuleHitCollection& Module(unsigned int m);
00057 const StMcEmcModuleHitCollection& Module(unsigned int m) const;
00058
00059 StMcEmcModuleHitCollection& thisModule(unsigned int m) {
00060 TObjArray &modules = *GetObjArray();
00061 return *(StMcEmcModuleHitCollection *)modules[m];
00062 }
00063 const StMcEmcModuleHitCollection& thisModule(unsigned int m) const {
00064 TObjArray &modules = *GetObjArray();
00065 return *(const StMcEmcModuleHitCollection *)modules[m];
00066 }
00067
00068 virtual Bool_t IsFolder() const {return kTRUE;}
00069 virtual void Browse(TBrowser *b);
00070 void print();
00071 virtual void Print(Option_t *option="") const;
00072
00073 protected:
00074 void MakeHitCollection();
00075 protected:
00076 ClassDef(StMcEmcHitCollection,1)
00077 };
00078
00079 ostream& operator<<(ostream& os, const StMcEmcHitCollection&);
00080 #endif