62 fNPads[1] =
new UInt_t[fNRows[1]];
72 for (UInt_t irow=0; irow<fNRows[0];irow++){
73 UInt_t npads = (irow==0) ? 68 : 2 *Int_t(Double_t(irow)/3. +33.67);
81 Double_t k1 = 10.*TMath::Tan(10*TMath::DegToRad())/6.;
82 Double_t k2 = 15.*TMath::Tan(10*TMath::DegToRad())/6.;
83 for (UInt_t irow=0; irow<fNRows[1];irow++){
84 UInt_t npads = (irow<64) ?
85 2*Int_t(k1*Double_t(irow)+37.75):
86 2*Int_t(k2*Double_t(irow-64)+56.66);
102 const Float_t kInnerRadiusLow = 83.65;
103 const Float_t kInnerRadiusUp = 133.3;
104 const Float_t kOuterRadiusLow = 133.5;
105 const Float_t kOuterRadiusUp = 247.7;
106 const Float_t kInnerFrameSpace = 1.5;
107 const Float_t kOuterFrameSpace = 1.5;
108 const Float_t kInnerWireMount = 1.2;
109 const Float_t kOuterWireMount = 1.4;
110 const Float_t kZLength =250.;
111 const UInt_t kNRowLow = 63;
112 const UInt_t kNRowUp1 = 64;
113 const UInt_t kNRowUp2 = 32;
114 const UInt_t kNRowUp = 96;
115 const Float_t kInnerAngle = 20;
116 const Float_t kOuterAngle = 20;
120 const Float_t kInnerPadPitchLength = 0.75;
121 const Float_t kInnerPadPitchWidth = 0.40;
122 const Float_t kInnerPadLength = 0.75;
123 const Float_t kInnerPadWidth = 0.40;
124 const Float_t kOuter1PadPitchLength = 1.0;
125 const Float_t kOuterPadPitchWidth = 0.6;
126 const Float_t kOuter1PadLength = 1.0;
127 const Float_t kOuterPadWidth = 0.6;
128 const Float_t kOuter2PadPitchLength = 1.5;
129 const Float_t kOuter2PadLength = 1.5;
285 for (UInt_t i=0;i<2;i++){
293 for (UInt_t i=0;i<100;++i){
362 fNPads[1] =
new UInt_t[fNRows[1]];
369 for (UInt_t irow =0; irow<fNRows[0];irow++){
373 for (UInt_t irow =0; irow<fNRows[1];irow++){
378 for (UInt_t i=0;i<100;++i){
393 if (
this == &roc)
return (*
this);
425 if ((sector%36)>=18){
436 Double_t
alpha = TMath::DegToRad()*(10.+20.*(sector%18));
437 Float_t gx = pos[0]*TMath::Cos(alpha)-pos[1]*TMath::Sin(alpha);
438 Float_t gy = pos[1]*TMath::Cos(alpha)+pos[0]*TMath::Sin(alpha);
UInt_t fNInnerWiresPerPad
Number of wires per pad.
Float_t fOuterPadWidth
Outer pad width.
Float_t fOuterFrameSpace
space for outer frame in the phi direction
Float_t fOuter1PadLength
Outer pad length.
Float_t fOuterRadiusUp
upper radius of outer sector-IP
AliTPCROC & operator=(const AliTPCROC &roc)
UInt_t fNRowUp1
number of short pad rows per sector up -set
UInt_t fNPadsLow[100]
Lower sector, number of pads per row -calculated.
static Float_t GetIdealPosition(UInt_t sector, UInt_t row, UInt_t pad, coordType coord)
Float_t fOuterOffWire
oofset of first wire to the begining of the sector
Float_t fOuter2PadPitchLength
Outer pad pitch length.
Float_t fInnerPadWidth
Inner pad width.
auto coord(Vector &v, unsigned int n) noexcept
Returns an object to manage the coordinate n of a vector.
Float_t fYInner[100]
Inner sector, wire-length.
Float_t fOuterAngle
angular coverage
UInt_t fNtRows
total number of rows in TPC -calculated
Float_t fRInnerFirstWire
position of the first wire -calculated
UInt_t fNRowUp2
number of long pad rows per sector up -set
Float_t fInnerWireMount
space for wire mount, inner sector
UInt_t fOuterDummyWire
number of wires without pad readout
static AliTPCROC * Instance()
Float_t fOuterPadPitchWidth
Outer pad pitch width.
Float_t fZLength
length of the drift region of the TPC
Float_t fInnerPadPitchWidth
Inner pad pitch width.
Float_t fROuterLastWire
position of the last wire -calculated
UInt_t fNOuter1WiresPerPad
Number of wires per pad.
static AliTPCROC * fgInstance
Float_t fYOuter[100]
Outer sector, wire-length.
Float_t fROuterFirstWire
position of the first wire -calulated
Float_t fLastWireUp1
position of the last wire in outer1 sector
UInt_t * fRowPosIndex[2]
index array - inner - outer
UInt_t fNRows[2]
number of row - inner outer
UInt_t fNOuter2WiresPerPad
Number of wires per pad.
Float_t fOuterRadiusLow
lower radius of outer sector-IP
Float_t fInnerAngle
angular coverage
Float_t fInnerOffWire
oofset of first wire to the begining of the sector
UInt_t fNRowLow
number of pad rows per low sector -set
Float_t fPadRowUp[100]
Upper sector, pad row radii -calculated.
Float_t fPadRowLow[100]
Lower sector, pad row radii -calculated.
Float_t fOuterWireMount
space for wire mount, outer sector
Float_t fInnerWWPitch
pitch between wires in inner sector - calculated
Float_t fOuterWWPitch
pitch between wires in outer sector -calculated
Float_t fInnerPadPitchLength
Inner pad pitch length.
Geometry class for a single ROC.
UInt_t fInnerDummyWire
number of wires without pad readout
UInt_t GetNPads(UInt_t sector, UInt_t row) const
Float_t fInnerFrameSpace
space for inner frame in the phi direction
Float_t fOuter2PadLength
Outer pad length.
UInt_t fNPadsUp[100]
Upper sector, number of pads per row -calculated.
UInt_t fNSectors[2]
number of sectors - inner outer
Float_t fInnerRadiusUp
upper radius of inner sector-IP
UInt_t fNSectorsAll
number of sectors
UInt_t fNRowUp
number of pad rows per sector up -calculated
Float_t fOuter1PadPitchLength
Outer pad pitch length.
UInt_t fNChannels[2]
total number of pads - inner sector - outer sector
Float_t fInnerPadLength
Inner pad length.
Float_t fRInnerLastWire
position of the last wire -calculated
void GetPositionLocal(UInt_t sector, UInt_t row, UInt_t pad, Float_t *pos)
void GetPositionGlobal(UInt_t sector, UInt_t row, UInt_t pad, Float_t *pos)
UInt_t * fNPads[2]
number of pads in row - inner - outer
Float_t fInnerRadiusLow
lower radius of inner sector-IP