]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONLocalTrigger.h
Correcting MUONGenerateGeometryData.C macro description
[u/mrichter/AliRoot.git] / MUON / AliMUONLocalTrigger.h
index 6911f8b208d0c5a91f791822bc1ca207178122b3..3b068c5c94a8ac80a90cdb8632968c6190da28ce 100644 (file)
@@ -7,23 +7,29 @@
 /* $Id$ */
 // Revision of includes 07/05/2004
 
+/// \ingroup base
+/// \class AliMUONLocalTrigger
+/// \brief Reconstructed Local Trigger object
+
 #include <TObject.h>
+#include <TArrayI.h>
 
 class AliMUONLocalTrigger : public TObject {
  public:
   AliMUONLocalTrigger();
   AliMUONLocalTrigger(const AliMUONLocalTrigger& rhs); // copy constructor !
-  AliMUONLocalTrigger(Int_t* localtr);
+  AliMUONLocalTrigger(const Int_t* localtr, const TArrayI& digits);
   virtual ~AliMUONLocalTrigger(){;}
   AliMUONLocalTrigger& operator=(const AliMUONLocalTrigger& rhs); 
 
-  Int_t LoCircuit() const {return fLoCircuit;}; 
-  Int_t LoStripX() const {return fLoStripX;};    
-  Int_t LoDev() const {return fLoDev;};     
-  Int_t LoStripY() const {return fLoStripY;};  
-  Int_t LoLpt() const {return fLoLpt;};     
-  Int_t LoHpt() const {return fLoHpt;};     
-  Int_t LoApt() const {return fLoApt;}; 
+  // getter methods
+  Int_t LoCircuit() const {return fLoCircuit;}
+  Int_t LoStripX() const {return fLoStripX;}   
+  Int_t LoDev() const {return fLoDev;}
+  Int_t LoStripY() const {return fLoStripY;}
+  Int_t LoLpt() const {return fLoLpt;}
+  Int_t LoHpt() const {return fLoHpt;}
+  Int_t LoApt() const {return fLoApt;}
 
    
   UShort_t GetX1Pattern() const {return fX1Pattern;}
@@ -38,7 +44,32 @@ class AliMUONLocalTrigger : public TObject {
 
   Char_t GetLoDecision();
 
-  ClassDef(AliMUONLocalTrigger,2)  // reconstructed Local Trigger object
+  // setter methods
+  void SetLoCircuit(Int_t loCir) {fLoCircuit = loCir;}
+  void SetLoStripX(Int_t loStrX) {fLoStripX = loStrX;}   
+  void SetLoDev(Int_t loDev)     {fLoDev = loDev;}
+  void SetLoStripY(Int_t loStrY) {fLoStripY = loStrY;}
+  void SetLoLpt(Int_t loLpt)     {fLoLpt = loLpt;}
+  void SetLoHpt(Int_t loHpt)     {fLoHpt = loHpt;}
+  void SetLoApt(Int_t loApt)     {fLoApt = loApt;}
+
+  void SetX1Pattern(UShort_t pat) {fX1Pattern = pat;}
+  void SetX2Pattern(UShort_t pat) {fX2Pattern = pat;}
+  void SetX3Pattern(UShort_t pat) {fX3Pattern = pat;}
+  void SetX4Pattern(UShort_t pat) {fX4Pattern = pat;}
+
+  void SetY1Pattern(UShort_t pat) {fY1Pattern = pat;}
+  void SetY2Pattern(UShort_t pat) {fY2Pattern = pat;}
+  void SetY3Pattern(UShort_t pat) {fY3Pattern = pat;}
+  void SetY4Pattern(UShort_t pat) {fY4Pattern = pat;}
+
+  // data link
+  Int_t NumberOfDigits() const { return fDigits.GetSize(); }
+  Int_t GetDigitNumber(Int_t i) const { return fDigits[i]; }
+  void GetDigit(Int_t i, Int_t& chamber, Int_t& cathode, Int_t& digit) const;
+
+  static Int_t EncodeDigitNumber(Int_t chamber, Int_t cathode, Int_t digit);
+  static void DecodeDigitNumber(Int_t digitnumber, Int_t& chamber, Int_t& cathode, Int_t& digit);
 
 private:
   Int_t fLoCircuit; // circuit number 
@@ -60,6 +91,10 @@ private:
   UShort_t fY4Pattern;
 
   Char_t fLoDecision; // local decision word (4 bits)
+
+  TArrayI fDigits;    // List of digit numbers from which this object was created.
+
+  ClassDef(AliMUONLocalTrigger,2)  // reconstructed Local Trigger object
 };
 #endif