Updated det element names (Christian)
[u/mrichter/AliRoot.git] / MUON / mapping / AliMpMotifMap.h
1 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
2  * See cxx source for full Copyright notice                               */
3
4 // $Id$
5 // $MpId: AliMpMotifMap.h,v 1.14 2006/05/24 13:58:18 ivana Exp $
6
7 /// \ingroup motif
8 /// \class AliMpMotifMap
9 /// \brief Motif map containers
10 ///
11 /// The class defines:
12 /// - map of motif objects to their string IDs
13 /// - map of motif type objects to their string IDs
14 /// - map of motif position objects to their string IDs
15 /// - map of motif position objects to their global indices
16 ///
17 /// \author David Guez, Ivana Hrivnacova; IPN Orsay
18
19 #ifndef ALI_MP_MOTIF_MAP_H
20 #define ALI_MP_MOTIF_MAP_H
21
22 #include <TObject.h>
23
24 #include "AliMpContainers.h"
25
26 #ifdef WITH_STL
27 #include "AliMpIntPair.h"
28 #endif
29
30 #ifdef WITH_ROOT
31 #include "AliMpExMap.h"
32 #endif
33
34 #ifdef WITH_STL
35 #include <map>
36 #include <iterator>
37 #endif
38
39 class AliMpVMotif;
40 class AliMpMotifType;
41 class AliMpMotifPosition;
42 class AliMpMotifMap;
43
44 class TArrayI;
45 class TString;
46 class TVector2;
47
48 class AliMpMotifMap : public TObject
49 {
50   public:
51 #ifdef WITH_STL
52     typedef std::map<TString, AliMpVMotif*> MotifMap;
53     typedef MotifMap::const_iterator        MotifMapIterator;
54     typedef std::map<TString, AliMpMotifType*> MotifTypeMap;
55     typedef MotifTypeMap::const_iterator       MotifTypeMapIterator;
56     typedef std::map<Int_t, AliMpMotifPosition*>  MotiPositionMap;
57     typedef MotiPositionMap::const_iterator       MotifPositionMapIterator;
58     typedef std::map<AliMpIntPair, AliMpMotifPosition*> MotifPositionMap2;
59     typedef MotifPositionMap2::const_iterator           MotifPositionMap2Iterator;
60 #endif    
61 #ifdef WITH_ROOT
62     typedef AliMpExMap MotifMap;
63     typedef AliMpExMap MotifTypeMap;
64     typedef AliMpExMap MotifPositionMap;
65     typedef AliMpExMap MotifPositionMap2;
66 #endif    
67
68   public:
69     AliMpMotifMap(Bool_t /*standardConstructor*/);
70     AliMpMotifMap();
71     virtual ~AliMpMotifMap();
72     
73     // methods
74     Bool_t  AddMotif(AliMpVMotif* motif, Bool_t warn = true);
75     Bool_t  AddMotifType(AliMpMotifType* motifType, Bool_t warn = true);
76     Bool_t  AddMotifPosition(AliMpMotifPosition* motifType, Bool_t warn = true);
77     void   FillMotifPositionMap2();
78     virtual void Print(const char* option = "ALL") const;
79     void   PrintGlobalIndices(const char* fileName) const;
80     void   UpdateGlobalIndices(const char* fileName);
81    
82     // find methods
83     AliMpVMotif*  FindMotif(const TString& motifID) const;
84     AliMpVMotif*  FindMotif(const TString& motifID, const TString& motifTypeID, 
85                             const TVector2& padDimensions) const;
86     AliMpMotifType*      FindMotifType(const TString& motifTypeID) const;
87     AliMpMotifPosition*  FindMotifPosition(Int_t motifPositionID) const;
88
89     /// Find all motifPositionsIDs (=electronicCardNumbers) handled by this map
90     void    GetAllMotifPositionsIDs(TArrayI& enc) const;
91     UInt_t  GetNofMotifPositions() const;
92     AliMpMotifPosition* GetMotifPosition(UInt_t index) const;
93
94     /// Calculate total number of pads defined in the map
95     Int_t CalculateNofPads() const;
96      
97   private:
98     // methods
99     void  PrintMotif(const AliMpVMotif* motif) const;
100     void  PrintMotifType(const AliMpMotifType* motifType) const;
101     void  PrintMotifPosition(const AliMpMotifPosition* motifPosition) const;
102     void  PrintMotifPosition2(const AliMpMotifPosition* motifPosition) const;
103     void  PrintMotifs() const;
104     void  PrintMotifTypes() const;
105     void  PrintMotifPositions() const;
106     void  PrintMotifPositions2() const;
107  
108     // data members
109     MotifMap           fMotifs;         ///< motifs map
110     MotifTypeMap       fMotifTypes;     ///< motifs types map
111 #ifdef WITH_STL
112     std::map<Int_t, AliMpMotifPosition*> fMotifPositions; ///< motif positions map by Id
113 #endif
114 #ifdef WITH_ROOT
115     MotifPositionMap   fMotifPositions; ///< motifs positions map
116 #endif
117     MotifPositionMap2  fMotifPositions2;///< motifs positions map
118
119   ClassDef(AliMpMotifMap,1)  // motif map
120 };
121
122 #endif //ALI_MP_MOTIF_MAP_H