/* $Id$ */
-// ------------------
+//-----------------------------------------------------------------------------
// Class AliMUONTriggerResponseV1
// ------------------
// Trigger chamber response
// with cluster size activated
-
-#include <TMath.h>
-#include <TRandom.h>
+//-----------------------------------------------------------------------------
#include "AliMUONResponseTriggerV1.h"
-#include "AliMUONGeometrySegmentation.h"
-#include "AliMpPad.h"
#include "AliMUON.h"
#include "AliMUONDigit.h"
#include "AliMUONGeometryTransformer.h"
+#include "AliMUONConstants.h"
+
+#include "AliMpPad.h"
+#include "AliMpSegmentation.h"
#include "AliMpVSegmentation.h"
+#include "AliMpCathodType.h"
+
#include "AliRun.h"
-#include "AliMUONSegmentation.h"
+#include <TMath.h>
+#include <TRandom.h>
+
+/// \cond CLASSIMP
ClassImp(AliMUONResponseTriggerV1)
+/// \endcond
namespace
{
transformer->Global2Local(detElemId,xg,yg,zg,xl,yl,zl);
}
- AliMUONSegmentation* Segmentation()
- {
- static AliMUONSegmentation* segmentation = muon()->GetSegmentation();
- return segmentation;
- }
}
//------------------------------------------------------------------
AliMUONResponseTriggerV1::AliMUONResponseTriggerV1()
- : AliMUONResponseTrigger()
+ : AliMUONResponseTrigger(),
+ fGenerCluster(0),
+ fA(0),
+ fB(0),
+ fC(0)
{
-// default constructor
+/// default constructor
Float_t hv=9.2;
SetParameters(hv);
}
//------------------------------------------------------------------
AliMUONResponseTriggerV1::AliMUONResponseTriggerV1(Float_t hv)
- : AliMUONResponseTrigger()
+ : AliMUONResponseTrigger(),
+ fGenerCluster(0),
+ fA(0),
+ fB(0),
+ fC(0)
{
-// Constructor
+/// Constructor
SetParameters(hv);
}
//------------------------------------------------------------------
-void AliMUONResponseTriggerV1::SetParameters(Float_t hv){
-// initialize parameters accoring to HV
-// (see V.Barret B.Espagnon and P.Rosnet Alice/note xxx)
+AliMUONResponseTriggerV1::~AliMUONResponseTriggerV1()
+{
+/// destructor
+}
+
+//------------------------------------------------------------------
+void AliMUONResponseTriggerV1::SetParameters(Float_t hv)
+{
+/// initialize parameters accoring to HV
+/// (see V.Barret B.Espagnon and P.Rosnet Alice/note xxx)
+/// this parametrisation is valid only for the "streamer" mode
fA = 6.089 * hv - 52.70;
fB = 2.966;
fC = 4.3e-4 * hv - 3.5e-3;
}
//------------------------------------------------------------------
-Int_t AliMUONResponseTriggerV1::SetGenerCluster(){
-// Set the GenerCluster parameter and return 1
+Int_t AliMUONResponseTriggerV1::SetGenerCluster()
+{
+/// Set the GenerCluster parameter and return 1
fGenerCluster = gRandom->Rndm();
return 1;
}
Float_t AliMUONResponseTriggerV1::FireStripProb(Float_t x4, Float_t theta)
const
{
-// parametrisation of the probability that a strip neighbour of the main
-// strip is fired (V.Barret B.Espagnon and P.Rosnet INT/DIM/01-04 (2001)
-// WARNING : need to convert x4 from cm to mm
+/// parametrisation of the probability that a strip neighbour of the main
+/// strip is fired (V.Barret B.Espagnon and P.Rosnet INT/DIM/01-04 (2001)
+/// WARNING : need to convert x4 from cm to mm
+/// this parametrisation is valid only for the "streamer" mode
return
(TMath::Cos(theta)*fA/(fA+TMath::Cos(theta)*TMath::Power(x4*10.,fB))+fC)/
}
//------------------------------------------------------------------
-void AliMUONResponseTriggerV1::DisIntegrate(const AliMUONHit& hit, TList& digits)
+void AliMUONResponseTriggerV1::DisIntegrate(const AliMUONHit& hit, TList& digits, Float_t /*timeDif*/)
{
- //
- // Generate digits (on each cathode) from 1 hit, with cluster-size
- // generation.
- //
+ /// Generate digits (on each cathode) from 1 hit, with cluster-size
+ /// generation.
digits.Clear();
Float_t xhit = hit.X();
Float_t yhit = hit.Y();
- Float_t zhit = 0; // FIXME : should it be hit.Z() ?
+ Float_t zhit = hit.Z();
Int_t detElemId = hit.DetElemId();
Double_t x,y,z;
Float_t tof = hit.Age();
Int_t twentyNano(100);
- if (tof<fgkTofLimit)
+ if (tof<AliMUONConstants::TriggerTofLimit())
{
twentyNano=1;
}
+
+ Int_t nboard = 0;
- for ( Int_t cath = 0; cath < 2; ++cath )
+ for ( Int_t cath = AliMp::kCath0; cath <= AliMp::kCath1; ++cath )
{
- const AliMpVSegmentation* seg = Segmentation()->GetMpSegmentation(detElemId,cath);
+ const AliMpVSegmentation* seg
+ = AliMpSegmentation::Instance()
+ ->GetMpSegmentation(detElemId,AliMp::GetCathodType(cath));
- AliMpPad pad = seg->PadByPosition(TVector2(x,y),kFALSE);
- Int_t ix = pad.GetIndices().GetFirst();
- Int_t iy = pad.GetIndices().GetSecond();
+ AliMpPad pad = seg->PadByPosition(x,y,kFALSE);
+ Int_t ix = pad.GetIx();
+ Int_t iy = pad.GetIy();
- AliMUONDigit* d = new AliMUONDigit;
- d->SetDetElemId(detElemId);
+ AliDebug(1,Form("xhit,yhit=%e,%e lx,ly,lz=%e,%e,%e ix,iy=%d,%d",
+ xhit,yhit,x,y,z,ix,iy));
+
+ if ( !pad.IsValid() )
+ {
+ AliWarning(Form("hit w/o strip %d-%d xhit,yhit=%e,%e local x,y,z "
+ "%e,%e,%e ix,iy=%d,%d",detElemId,
+ cath,
+ xhit,yhit,x,y,z,ix,iy));
+ continue;
+ }
+
+ if ( cath == AliMp::kCath0 ) nboard = pad.GetLocalBoardId(0);
+
+ AliMUONDigit* d = new AliMUONDigit(detElemId,nboard,
+ pad.GetLocalBoardChannel(0),
+ cath);
+ d->SetPadXY(ix,iy);
+
+ d->SetCharge(twentyNano);
- d->SetPadX(ix);
- d->SetPadY(iy);
- d->SetSignal(twentyNano);
- d->AddPhysicsSignal(d->Signal());
- d->SetCathode(cath);
digits.Add(d);
SetGenerCluster(); // 1 randum number per cathode (to be checked)
Int_t ixNeigh = ( cath == 0 ) ? ix : xList[i];
Int_t iyNeigh = ( cath == 0 ) ? yList[i] : iy;
- AliMpIntPair pairNeigh = AliMpIntPair(ixNeigh,iyNeigh);
- AliMpPad padNeigh = seg->PadByIndices(pairNeigh,kFALSE);
+ AliMpPad padNeigh = seg->PadByIndices(ixNeigh,iyNeigh,kFALSE);
if(padNeigh.IsValid()){ // existing neighbourg
Int_t dix=-(ixNeigh-ix);
Int_t diy=-(iyNeigh-iy);
- Float_t xlocalNeigh = padNeigh.Position().X();
- Float_t ylocalNeigh = padNeigh.Position().Y();
- Float_t dpx = padNeigh.Dimensions().X();
- Float_t dpy = padNeigh.Dimensions().Y();
+ Float_t xlocalNeigh = padNeigh.GetPositionX();
+ Float_t ylocalNeigh = padNeigh.GetPositionY();
+ Float_t dpx = padNeigh.GetDimensionX();
+ Float_t dpy = padNeigh.GetDimensionY();
Float_t distX = TMath::Abs((Float_t)dix) * ((Float_t)dix * dpx + xlocalNeigh - x);
Float_t distY = TMath::Abs((Float_t)diy) * ((Float_t)diy * dpy + ylocalNeigh - y);
Float_t dist = TMath::Sqrt(distX*distX+distY*distY);
else qp = 0;
if (qp == 1) { // this digit is fired
- AliMUONDigit* dNeigh = new AliMUONDigit;
- dNeigh->SetDetElemId(detElemId);
-
- dNeigh->SetPadX(ixNeigh);
- dNeigh->SetPadY(iyNeigh);
+ Int_t neighBoard = 0;
+ if ( cath == AliMp::kCath0 ) neighBoard = padNeigh.GetLocalBoardId(0);
+ else {
+ const AliMpVSegmentation* seg0
+ = AliMpSegmentation::Instance()
+ ->GetMpSegmentation(detElemId,AliMp::GetCathodType(AliMp::kCath0));
+ AliMpPad padNeigh0 = seg0->PadByPosition(xlocalNeigh, y, kFALSE);
+ if ( ! padNeigh0.IsValid() ) continue; // This can happen only on the cut RPC, at boards 25, 30, 142 and 147
+ neighBoard = padNeigh0.GetLocalBoardId(0);
+ }
+ AliMUONDigit* dNeigh = new AliMUONDigit(detElemId,neighBoard,
+ padNeigh.GetLocalBoardChannel(0),
+ cath);
- dNeigh->SetSignal(twentyNano);
- dNeigh->AddPhysicsSignal(dNeigh->Signal());
- dNeigh->SetCathode(cath);
+ dNeigh->SetPadXY(ixNeigh,iyNeigh);
+ dNeigh->SetCharge(twentyNano);
digits.Add(dNeigh);
} // digit fired
} // pad is valid
//------------------------------------------------------------------
void AliMUONResponseTriggerV1::Neighbours(const Int_t cath,
const Int_t ix, const Int_t iy,
- Int_t Xlist[10], Int_t Ylist[10])
+ Int_t Xlist[10], Int_t Ylist[10]) const
{
+ ///-----------------BENDING----------------------------------------- /n
+ /// Returns list of 10 next neighbours for given X strip (ix, iy) /n
+ /// neighbour number 4 in the list - /n
+ /// neighbour number 3 in the list | /n
+ /// neighbour number 2 in the list |_ Upper part /n
+ /// neighbour number 1 in the list | /n
+ /// neighbour number 0 in the list - /n
+ /// X strip (ix, iy) /n
+ /// neighbour number 5 in the list - /n
+ /// neighbour number 6 in the list | _ Lower part /n
+ /// neighbour number 7 in the list | /n
+ /// neighbour number 8 in the list | /n
+ /// neighbour number 9 in the list - /n
+ /// /n
+ ///-----------------NON-BENDING------------------------------------- /n
+ /// Returns list of 10 next neighbours for given Y strip (ix, iy) /n
+ /// neighbour number 9 8 7 6 5 (Y strip (ix, iy)) 0 1 2 3 4 in the list /n
+ /// |_______| |_______/ /n
- //-----------------BENDING-----------------------------------------
- // Returns list of 10 next neighbours for given X strip (ix, iy)
- // neighbour number 4 in the list -
- // neighbour number 3 in the list |
- // neighbour number 2 in the list |_ Upper part
- // neighbour number 1 in the list |
- // neighbour number 0 in the list -
- // X strip (ix, iy)
- // neighbour number 5 in the list -
- // neighbour number 6 in the list | _ Lower part
- // neighbour number 7 in the list |
- // neighbour number 8 in the list |
- // neighbour number 9 in the list -
-
- //-----------------NON-BENDING-------------------------------------
- // Returns list of 10 next neighbours for given Y strip (ix, iy)
- // neighbour number 9 8 7 6 5 (Y strip (ix, iy)) 0 1 2 3 4 in the list
- // \_______/ \_______/
- // left right
+ /// left right /n
for (Int_t i=0; i<10; i++) {
Xlist[i]=-1;