]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONConstants.cxx
Removing circular dependences, work in progress (Ch. Finck)
[u/mrichter/AliRoot.git] / MUON / AliMUONConstants.cxx
index 61834a4fd11fa8253ab379b074d59518ccce68df..888901c7977bb66ab6634f768cecb7fd06f1f85f 100644 (file)
  * provided "as is" without express or implied warranty.                  *
  **************************************************************************/
 
-/*
-$Log$
-Revision 1.4  2000/10/06 09:09:56  morsch
-Outer radius of chambers adjusted to accomodate slat chambers (to be checked and updated).
-
-Revision 1.3  2000/10/02 16:58:29  egangler
-Cleaning of the code :
--> coding conventions
--> void Streamers
--> some useless includes removed or replaced by "class" statement
-
-Revision 1.2  2000/06/27 09:46:57  morsch
-kMAXZOOM global constant now in AliMUONConstants
-
-Revision 1.1  2000/06/26 14:02:38  morsch
-Add class AliMUONConstants with MUON specific constants using static memeber data and access methods.
-
-*/
+/* $Id$ */
 
+#include <TMath.h>
 #include "AliMUONConstants.h"
 
-
 ClassImp(AliMUONConstants)
 
 Int_t   AliMUONConstants::fgNCh = 14;
 Int_t   AliMUONConstants::fgNTrackingCh = 10;
 Int_t   AliMUONConstants::fgNTriggerCh = 4;
 Int_t   AliMUONConstants::fgNTriggerCircuit = 234;
-Float_t AliMUONConstants::fgDefaultChamberZ[14] =
-{530., 550., 672.5, 699.5, 960.1, 988.9, 1252.29, 1282.04, 1413.13, 1442.88,
-                  1610, 1625., 1710., 1725.}; 
 
-Float_t  AliMUONConstants::fgDmin[7] = {  35.,  47.,  66.0,   80.,   80., 100., 100.};    
-Float_t  AliMUONConstants::fgDmax[7]  = {183., 245., 316.6,  560.,  560., 830., 880.};  
+Float_t AliMUONConstants::fgDefaultChamberZ[14] = 
+  {-533.5, -546.5, -678.5, -693.5, // St12
+   -966.9, -997.9, -1274.5, -1305.5, -1408.6, -1439.6, // St345  update sept04 Ch. Finck 
+   -1603.5, -1620.5, -1703.5, -1720.5}; // M1 & M2
+
+Float_t  AliMUONConstants::fgDzCh   = 15.5/2.;
+Float_t  AliMUONConstants::fgDzSlat = 8.5/2.;
+
+Float_t  AliMUONConstants::fgSqrtKx3Slat = 0.7131;
+Float_t  AliMUONConstants::fgSqrtKy3Slat = 0.7642;
+
+Float_t  AliMUONConstants::fgSqrtKx3St12 = 0.7000;
+Float_t  AliMUONConstants::fgSqrtKy3St12 = 0.7550;
+
+Float_t  AliMUONConstants::fgChargeCorrelSlat = 0.11;
+Float_t  AliMUONConstants::fgChargeCorrelSt12 = 0.0; //???
+
+Float_t  AliMUONConstants::fgPitchSlat = 0.25;
+Float_t  AliMUONConstants::fgPitchSt12 = 0.20; 
+
+Float_t  AliMUONConstants::fgDmin[7] = {  36.4,  46.2,  66.0,   80.,   80., 100., 100.};    
+Float_t  AliMUONConstants::fgDmax[7]  = {183., 245., 395.,  560.,  563., 850., 900.};  
+Int_t    AliMUONConstants::fgMaxZoom = 20;
 
-Int_t   AliMUONConstants::fgMaxZoom = 20;
+//______________________________________________________________________________
+Int_t AliMUONConstants::ChamberNumber(Float_t z) 
+{
+  // return chamber number according z position of hit. Should be taken from geometry ?
+  Float_t dMaxChamber = DzSlat() + DzCh() + 0.25; // cm st 3 &4 & 5
+  if ( z >  (DefaultChamberZ(4)+50.)) dMaxChamber = 7.; // cm stations 1 & 2
+  Int_t iChamber;
 
+  for (iChamber = 0; iChamber < 10; iChamber++) {
+    
+    if (TMath::Abs(z-DefaultChamberZ(iChamber)) < dMaxChamber) {
+      return iChamber;
+    }
+  }
+  return -1;
+}