1 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
2 * See cxx source for full Copyright notice */
5 // $MpId: AliMpManuGeo.h,v 1.5 2006/05/24 13:58:16 ivana Exp $
7 /// \ingroup management
8 /// \class AliMpLocalBoard
9 /// \brief Class that manages the properties of the local board
11 /// \author Ch. Finck; Subatech Nantes
13 #ifndef ALI_MP_LOCAL_BOARD_H
14 #define ALI_MP_LOCAL_BOARD_H
18 #include "AliMpArrayI.h"
22 class AliMpLocalBoard : public TNamed
26 AliMpLocalBoard(Int_t id, const Char_t* name, Int_t slot);
27 AliMpLocalBoard(TRootIOCtor* /*ioCtor*/);
28 virtual ~AliMpLocalBoard();
31 Bool_t AddDE(Int_t detElemId);
32 Int_t GetNofDEs() const;
33 Int_t GetDEId(Int_t index) const;
34 Int_t GetDEIdByChamber(Int_t chamberId) const;
35 Bool_t HasDEId(Int_t detElemId) const;
39 /// Return the identifier (unique)
40 Int_t GetId() const {return fId;}
41 /// Return the slot Identifier in the given crate
42 Int_t GetSlot() const {return fSlot;}
46 Bool_t AddSwitch(Int_t swit);
47 Int_t GetNofSwitches() const;
48 Int_t GetSwitch(Int_t index) const;
50 // switch enum for local board (see PRR, chpt: 2.4.4)
51 enum {kX2d, kX2m, kX2u, ///< (1) indicate a change of strip pitch in Y circuit
52 kOR0, kOR1, ///< taking into account the different segmentation in Y from MT1 to MT2
53 kENY, ///< (0) enable communication in Y to n+/-1 board via tranverse connector, (1) disable
54 kZeroAllYLSB,///< (1) reset the LSB for special configuration of board RC2L5B4 & RC2L6B1
55 kZeroDown, ///< (0) information is expected from n-1 board for X input, (1) not
56 kZeroMiddle, ///< (0) always, not used
57 kZeroUp }; ///< (0) information is expected from n+1 board for X input, (1) not
59 // Transverse connector
61 /// Set transverse connector
62 void SetTC(Bool_t connect) {fTC = connect;}
63 /// Return transverse connector
64 Bool_t GetTC() const {return fTC;}
69 void SetCrate(TString name) {fCrate = name;}
71 TString GetCrate() const {return fCrate;}
75 /// Set notified flag (not copy card)
76 void SetNotified(Bool_t notify) {fNotified = notify;}
77 /// Return notified flag (not copy card)
78 Bool_t IsNotified() const {return fNotified;}
80 // given position (line, col)
81 AliMpIntPair GetPosition() const;
83 // Id to be copy to or from
85 /// Get Id from where the X input are copied
86 Int_t GetInputXfrom() {return fInputXfrom;}
87 /// Get Id to where the X input are copied
88 Int_t GetInputXto() {return fInputXto;}
89 /// Get Id from where the Y input are copied
90 Int_t GetInputYfrom() {return fInputYfrom;}
91 /// Get Id to where the Y input are copied
92 Int_t GetInputYto() {return fInputYto;}
94 /// Set Id from where the X input are copied
95 void SetInputXfrom(Int_t id) {fInputXfrom = id;}
96 /// Set Id to where the X input are copied
97 void SetInputXto(Int_t id) {fInputXto = id;}
98 /// Set Id from where the Y input are copied
99 void SetInputYfrom(Int_t id) {fInputYfrom = id;}
100 /// Set Id to where the Y input are copied
101 void SetInputYto(Int_t id) {fInputYto = id;}
107 AliMpLocalBoard(const AliMpLocalBoard& src);
109 AliMpLocalBoard& operator = (const AliMpLocalBoard& src) ;
111 Int_t GetIndex(Int_t chamberId) const;
113 Int_t fId; ///< Identifier (unique)
114 Int_t fSlot; ///< Slot Identifier in the given crate
116 Bool_t fTC; ///< Transverse connector
117 TString fCrate; ///< Crate name
118 AliMpArrayI fSwitches; ///< switches
119 Bool_t fNotified; ///< notified flag (not copy card)
120 AliMpArrayI fDEId; ///< list of Detection element to which this local board is connected
121 Int_t fInputXfrom;///< local id of x3-4 inputs copied from (zero: not copied)
122 Int_t fInputXto; ///< local id of x3-4 inputs copied to (zero: not copied)
123 Int_t fInputYfrom;///< local id of y1-4 inputs copied from (zero: not copied)
124 Int_t fInputYto; ///< local id of y1-4 inputs copied to (zero: not copied)
126 ClassDef(AliMpLocalBoard,1) //utility class for the motif type