]> git.uio.no Git - u/mrichter/AliRoot.git/blob - MUON/mapping/AliMpRowSegmentRSpecial.h
Replacement of AliMpIntPair object with algoritmic
[u/mrichter/AliRoot.git] / MUON / mapping / AliMpRowSegmentRSpecial.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: AliMpRowSegmentRSpecial.h,v 1.9 2006/05/24 13:58:21 ivana Exp $
6
7 /// \ingroup sector
8 /// \class AliMpRowSegmentRSpecial
9 /// \brief A special outer row segment composed of the pad rows.
10 ///
11 /// \author David Guez, Ivana Hrivnacova; IPN Orsay
12
13 #ifndef ALI_MP_ROW_SEGMENT_R_SPECIAL_H
14 #define ALI_MP_ROW_SEGMENT_R_SPECIAL_H
15
16 #include "AliMpVRowSegmentSpecial.h"
17
18 #include <TVector2.h>
19
20 class AliMpRow;
21 class AliMpPadRow;
22 class AliMpVPadRowSegment;
23
24 class AliMpRowSegmentRSpecial : public AliMpVRowSegmentSpecial
25 {
26   public:
27     AliMpRowSegmentRSpecial(AliMpRow* row, Double_t offsetX);
28     AliMpRowSegmentRSpecial();
29     virtual ~AliMpRowSegmentRSpecial();
30     
31     // methods
32                   /// Nothing to be done for outer segments
33     virtual void  UpdatePadsOffset() {}
34     virtual Double_t  LeftBorderX() const;
35     virtual Double_t  RightBorderX() const;
36
37     // geometry
38     virtual TVector2  Position() const;
39
40     // set methods
41     virtual void   SetGlobalIndices(AliMpRow* rowBefore);
42     virtual Int_t  SetIndicesToMotifPosition(Int_t i, MpPair_t indices);
43
44   protected:
45     // methods
46     virtual TVector2  MotifCenterSlow(Int_t motifPositionId) const;
47     
48   private:
49     // methods
50     AliMpVPadRowSegment* FindMostLeftPadRowSegment(Int_t motifPositionId) const;
51     void SetGlobalIndicesLow();
52     
53   ClassDef(AliMpRowSegmentRSpecial,1)  // Row segment
54 };
55
56 #endif //ALI_MP_ROW_SEGMENT_R_SPECIAL_H