///
/// \author Rachid Guernane (LPCCFd)
-#ifndef ROOT_TTask
-# include "TTask.h"
-#endif
-
-#ifndef ROOT_TArrayI
-# include "TArrayI.h"
+#ifndef ROOT_TObject
+# include "TObject.h"
#endif
#ifndef ROOT_TString
class AliMUONTriggerCrate;
class AliMUONCalibrationData;
-class AliMUONData;
class AliMUONGlobalTriggerBoard;
-class TClonesArray;
+class AliMUONTriggerCrateStore;
+class AliMUONVTriggerStore;
+class AliMUONVDigitStore;
-class AliMUONTriggerElectronics : public TTask
+class AliMUONTriggerElectronics : public TObject
{
public:
- AliMUONTriggerElectronics(AliMUONData* data = 0,
- AliMUONCalibrationData* calibData=0);
- virtual ~AliMUONTriggerElectronics();
+ AliMUONTriggerElectronics(AliMUONCalibrationData* calibData=0);
- virtual void Exec(Option_t*);
-
-// CRATE CONFIG FROM ASCII FILE
- virtual void SetDataSource(TString SourceFile = "$ALICE_ROOT/MUON/data/CRATE.TXT")
- {fSourceFileName = SourceFile;}
+ virtual ~AliMUONTriggerElectronics();
virtual void Factory(AliMUONCalibrationData* calibData);
void LoadMasks(AliMUONCalibrationData* calibData);
- virtual void AddCrate(char *name);
-
- virtual AliMUONTriggerCrate* Crate(char *name);
- virtual void Feed();
virtual void Feed(UShort_t pattern[2][4]);
- virtual void FeedM();
-
- virtual void BoardName(Int_t ix, Int_t iy, char *name);
-
+ virtual void Feed(const AliMUONVDigitStore& digitStore);
+ virtual void Feed(AliMUONVTriggerStore& triggerStore);
virtual void Reset();
virtual void Scan(Option_t *option);
virtual void RegionalResponse();
virtual void GlobalResponse();
- virtual void BuildName(Int_t icirc, char name[20]);
-
virtual void DumpOS();
- virtual void Digits2Trigger();
- virtual void Trigger();
- virtual void ClearDigitNumbers();
- virtual void DigitFiredCircuit(Int_t circuit, Int_t cathode, Int_t chamber, Int_t digit);
+ virtual void Digits2Trigger(const AliMUONVDigitStore& digitStore,
+ AliMUONVTriggerStore& triggerStore);
+
+ virtual Bool_t ModifiedLocalResponse(Int_t loCircuit,
+ Bool_t& bendingPlaneResp,
+ Bool_t& nonBendingPlaneResp,
+ Bool_t isCoinc44 = kFALSE,
+ Int_t removeChamber = -1);
+
+ virtual void ResponseRemovingChambers(AliMUONVTriggerStore& triggerStore);
+
+ /// Return Crate array
+ AliMUONTriggerCrateStore* GetCrateStore() {return fCrates;}
- protected:
+ private:
+ /// Not implemented
AliMUONTriggerElectronics(const AliMUONTriggerElectronics& right);
+ /// Not implemented
AliMUONTriggerElectronics& operator = (const AliMUONTriggerElectronics& right);
+
+ void FeedCopyNeighbours();
+ /// set copy card array
+ void SetCopyInput();
+
private:
- TString fSourceFileName; // Source file
- TClonesArray *fCrates; // Crate array
- AliMUONGlobalTriggerBoard *fGlobalTriggerBoard; // Global trigger board
- Int_t fNCrates; // Number of trigger crates
- static const Int_t fgkNCrates; // Number of trigger crates (const)
- UShort_t fLocal[16][16]; // 16 crates of 16 LB
- UShort_t fRegional[16]; // 16 RB
- UShort_t fGlobal; // 1 GB
- AliMUONData *fMUONData; //! Data container for MUON subsystem
- TArrayI fDigitNumbers[234]; //! The digit number that fired a circuit.
- char **fCrateMap; // Map crate name <-> crate number
- Int_t fBoardMap[234]; // Map board number <-> slot number
-
- ClassDef(AliMUONTriggerElectronics,1)
+ TList* fCopyXInput[2]; ///< list of copy X input from local to local board
+ TList* fCopyYInput[2]; ///< list of copy Y input from local to local board
+ AliMUONTriggerCrateStore *fCrates; ///< Crate array
+ AliMUONGlobalTriggerBoard *fGlobalTriggerBoard; ///< Global trigger board
+
+ ClassDef(AliMUONTriggerElectronics,4) //Manager class for muon trigger electronics
};
#endif