1 #ifndef ALI_MP_SEGMENTATION_H
2 #define ALI_MP_SEGMENTATION_H
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
8 // $MpId: AliMpSegmentation.h,v 1.7 2006/05/24 13:58:16 ivana Exp $
10 /// \ingroup management
11 /// \class AliMpSegmentation
12 /// \brief Singleton container class for mapping segmentations
14 /// It provides access to mapping segmentations based on the
15 /// AliMpVSegmentation interface. \n
16 /// Mapping segmentations for all detection elements
17 /// are created at the first call to AliMpSegmentation::Instance().
18 /// The class is a singleton, it has all constructors
19 /// private, except for the special constructor for Root I/O.
21 /// \author Ivana Hrivnacova, IPN Orsay; Laurent Aphecetche, SUBATECH
27 #ifndef ALI_MP_STRING_OBJ_MAP_H
28 # include "AliMpStringObjMap.h"
31 #ifndef ALI_MP_EX_MAP_H
32 # include "AliMpExMap.h"
35 class AliMpVSegmentation;
36 class AliMpSegmentation;
40 class AliMpSegmentation : public TObject {
43 AliMpSegmentation(TRootIOCtor* /*ioCtor*/);
44 virtual ~AliMpSegmentation();
47 static AliMpSegmentation* Instance();
50 const AliMpVSegmentation* GetMpSegmentation(
51 Int_t detElemId, Int_t cath,
52 Bool_t warn = true) const;
54 const AliMpVSegmentation* GetMpSegmentationByElectronics(
55 Int_t detElemId, Int_t elCardID,
56 Bool_t warn = true) const;
60 AliMpSegmentation(const AliMpSegmentation& rhs);
61 AliMpSegmentation& operator=(const AliMpSegmentation& rhs);
63 AliMpVSegmentation* CreateMpSegmentation(
64 Int_t detElemId, Int_t cath);
66 AliMpExMap* FillElCardsMap(Int_t detElemId);
68 // static data members
69 static AliMpSegmentation* fgInstance; ///< Singleton instance
72 AliMpStringObjMap fMpSegmentations;///< Map of mapping segmentations to DE names
73 AliMpExMap fElCardsMap; ///< Map of el. cards IDs to segmentations
76 ClassDef(AliMpSegmentation,1) // The factory for building mapping segmentations
79 #endif //ALI_MP_SEGMENTATION_H