+
+}
+
+//___________________________________________
+void AliMUONTriggerElectronics::Feed(const AliMUONVTriggerStore& triggerStore)
+{
+ //
+ /// Fill inputs from reconstructed local trigger store
+ //
+ AliMUONLocalTrigger* locTrg;
+ TIter next(triggerStore.CreateLocalIterator());
+ TArrayS xyPattern[2];
+ UShort_t xy[2][4];
+ Int_t loCircuit;
+ while ( ( locTrg = static_cast<AliMUONLocalTrigger*>( next() )) != NULL ){
+ locTrg->GetXPattern(xyPattern[0]);
+ locTrg->GetYPattern(xyPattern[1]);
+ loCircuit = locTrg->LoCircuit();
+ AliMUONLocalTriggerBoard* localBoard = fCrates->LocalBoard(loCircuit);
+ for (Int_t icath = 0; icath<2; ++icath){
+ for (Int_t ich = 0; ich < 4; ++ich){
+ xy[icath][ich] = xyPattern[icath][ich];
+ }
+ }
+ localBoard->SetXY(xy);
+ }
+
+ FeedCopyNeighbours();
+}
+
+//_______________________________________________________________________
+Bool_t AliMUONTriggerElectronics::ModifiedLocalResponse(Int_t loCircuit,
+ Bool_t& bendingPlaneResp,
+ Bool_t& nonBendingPlaneResp,
+ Bool_t isCoinc44,
+ Int_t removeChamber)
+{
+ //
+ /// Re-compute the local trigger response
+ /// with some modifications (i.e. setting coinc44 or after removing one chamber)
+ //
+
+ bendingPlaneResp = kFALSE;
+ nonBendingPlaneResp = kFALSE;
+
+ Bool_t isTriggered = kFALSE;
+
+ AliMUONLocalTriggerBoard* currBoard = fCrates->LocalBoard(loCircuit);
+
+ if ( ! currBoard ) return isTriggered;
+
+ AliMUONLocalTriggerBoard localBoard (*currBoard);
+
+ if (removeChamber>=0 && removeChamber<=3){
+
+ // Set the bit pattern of selected chamber to 0
+ UShort_t xy[2][4];
+ UShort_t xyu[2][4];
+ UShort_t xyd[2][4];
+
+ localBoard.GetXY(xy);
+ localBoard.GetXYU(xyu);
+ localBoard.GetXYD(xyd);
+
+ for(Int_t icath=0; icath<2; icath++){
+ xy[icath][removeChamber] = 0;
+ xyu[icath][removeChamber] = 0;
+ xyd[icath][removeChamber] = 0;
+ }
+
+ localBoard.SetXY(xy);
+ localBoard.SetXYU(xyu);
+ localBoard.SetXYD(xyd);
+ }
+
+ localBoard.ResetResponse();
+
+ localBoard.SetCoinc44((Int_t)isCoinc44);
+ localBoard.Response();
+
+ bendingPlaneResp = localBoard.IsTrigX();
+ nonBendingPlaneResp = localBoard.IsTrigY();
+ isTriggered = localBoard.Triggered();
+
+ return isTriggered;
+}
+
+
+//_______________________________________________________________________
+void AliMUONTriggerElectronics::ResponseRemovingChambers(AliMUONVTriggerStore& triggerStore)
+{
+ /// Update local board information with the trigger response after removing each chamber
+
+ AliCodeTimerAuto("", 0);
+