ROOT logo
#ifndef ALIEMCALGEOMETRY_H
#define ALIEMCALGEOMETRY_H
/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
 * See cxx source for full Copyright notice                               */

/* $Id$ */

//_________________________________________________________________________
// Geometry class  for EMCAL : singleton
// EMCAL consists of a layers of scintillator, and lead.
//                  
//*-- Author: Sahal Yacoob (LBL / UCT)
//*--   and : Yves Schutz (Subatech)
//*--   and : Alexei Pavlinov (WSU) - shashlyk staff
//*--   and : Gustavo Conesa: Add TRU mapping. TRU parameters still not fixed.
//*--   and : Magali Estienne : analysis access adaptations
//*--   and : Adapted for DCAL, M.L. Wang CCNU & Subatech Oct-18-2012

// --- ROOT system ---
#include <TNamed.h>
#include <TMath.h>
#include <TArrayD.h>
#include <TVector3.h>
#include <TGeoMatrix.h> 
class TBrowser ;
class TParticle ;

// --- AliRoot header files ---
#include "AliEMCALEMCGeometry.h"
#include "AliEMCALGeoParams.h"
class AliEMCALShishKebabTrd1Module;
class AliLog;

class AliEMCALGeometry : public TNamed {

public: 
  enum fEMCSMType { kEMCAL_Standard = 0, kEMCAL_Half = 1, kEMCAL_3rd = 2, kDCAL_Standard = 3, kDCAL_Ext= 4 }; // possible SM Type

  AliEMCALGeometry();
  AliEMCALGeometry(const Text_t* name, const Text_t* title="",
                   const Text_t* mcname="", const Text_t* mctitle="");
  AliEMCALGeometry(const AliEMCALGeometry & geom);
  
  virtual ~AliEMCALGeometry(void); 
  AliEMCALGeometry & operator = (const AliEMCALGeometry  & rvalue);
  
  static AliEMCALGeometry * GetInstance(const Text_t* name,      const Text_t* title="",
                                        const Text_t* mcname="TGeant3", const Text_t* mctitle="") ; 
  static AliEMCALGeometry * GetInstance();


  //////////
  // General
  //
  static Bool_t  IsInitialized(void)            {return AliEMCALEMCGeometry::fgInit; }
  static const Char_t* GetDefaultGeometryName() {return AliEMCALEMCGeometry::fgkDefaultGeometryName;}
  
  /////////////
  // TRD1 stuff
  void    CreateListOfTrd1Modules();
  TList  *GetShishKebabTrd1Modules() const {return fShishKebabTrd1Modules;}
  AliEMCALShishKebabTrd1Module *GetShishKebabModule(Int_t neta) const;

  void PrintGeometryGeoUtils();   // *MENU*  
  void PrintCellIndexes(Int_t absId=0, int pri=0, const char *tit="") const ;  //*MENU*
  void PrintLocalTrd1(Int_t pri=0) const;  // *MENU*
  virtual void Browse(TBrowser* b);
  virtual Bool_t  IsFolder() const;

  virtual Bool_t Impact(const TParticle *particle) const;
  void ImpactOnEmcal(TVector3 vtx, Double_t theta, Double_t phi, Int_t & absId, TVector3 & vimpact) const;
  Bool_t IsInEMCAL(Double_t x, Double_t y, Double_t z) const;
  Bool_t IsInDCAL(Double_t x, Double_t y, Double_t z) const;
  Int_t  IsInEMCALOrDCAL(Double_t x, Double_t y, Double_t z) const;

  //////////////////////////////////////
  // Return EMCAL geometrical parameters
  //
  
  AliEMCALEMCGeometry* GetEMCGeometry()       const { return fEMCGeometry                            ; }
  //
  const Char_t*  GetNameOfEMCALEnvelope(void) const { return fEMCGeometry->GetNameOfEMCALEnvelope()  ; }
  Float_t  GetArm1PhiMin(void)                const { return fEMCGeometry->GetArm1PhiMin()           ; }
  Float_t  GetArm1PhiMax(void)                const { return fEMCGeometry->GetArm1PhiMax()           ; }
  Float_t  GetArm1EtaMin(void)                const { return fEMCGeometry->GetArm1EtaMin()           ; }
  Float_t  GetArm1EtaMax(void)                const { return fEMCGeometry->GetArm1EtaMax()           ; }
  Float_t  GetIPDistance(void)                const { return fEMCGeometry->GetIPDistance()           ; }   
  Float_t  GetEnvelop(Int_t index)            const { return fEMCGeometry->GetEnvelop(index)         ; }  
  Float_t  GetShellThickness(void)            const { return fEMCGeometry->GetShellThickness()       ; }
  Float_t  GetZLength(void)                   const { return fEMCGeometry->GetZLength()              ; } 
  Float_t  GetDCALInnerEdge(void)             const { return fEMCGeometry->GetDCALInnerEdge()        ; }
  Float_t  GetDCALPhiMin(void)                const { return fEMCGeometry->GetDCALPhiMin()           ; }
  Float_t  GetDCALPhiMax(void)                const { return fEMCGeometry->GetDCALPhiMax()           ; }
  Float_t  GetEMCALPhiMax(void)               const { return fEMCGeometry->GetEMCALPhiMax()          ; }
  Int_t    GetNECLayers(void)                 const { return fEMCGeometry->GetNECLayers()            ; }
  Float_t  GetDCALInnerExtandedEta(void)      const { return fEMCGeometry->GetDCALInnerExtandedEta() ; }
  Int_t    GetNZ(void)                        const { return fEMCGeometry->GetNZ()                   ; }
  Int_t    GetNEta(void)                      const { return fEMCGeometry->GetNEta()                 ; }
  Int_t    GetNPhi(void)                      const { return fEMCGeometry->GetNPhi()                 ; }
  Float_t  GetECPbRadThick(void)              const { return fEMCGeometry->GetECPbRadThick()         ; }
  Float_t  GetECScintThick(void)              const { return fEMCGeometry->GetECScintThick()         ; }
  Float_t  GetSampling(void)                  const { return fEMCGeometry->GetSampling()             ; } 
  Int_t    GetNumberOfSuperModules(void)      const { return fEMCGeometry->GetNumberOfSuperModules() ; }
  Float_t  GetPhiGapForSuperModules(void)     const { return fEMCGeometry->GetPhiGapForSuperModules(); }
  Float_t  GetPhiModuleSize(void)             const { return fEMCGeometry->GetPhiModuleSize()        ; }
  Float_t  GetEtaModuleSize(void)             const { return fEMCGeometry->GetEtaModuleSize()        ; }
  Float_t  GetFrontSteelStrip(void)           const { return fEMCGeometry->GetFrontSteelStrip()      ; }
  Float_t  GetLateralSteelStrip(void)         const { return fEMCGeometry->GetLateralSteelStrip()    ; }
  Float_t  GetPassiveScintThick(void)         const { return fEMCGeometry->GetPassiveScintThick()    ; }
  Float_t  GetPhiTileSize(void)               const { return fEMCGeometry->GetPhiTileSize()          ; }
  Float_t  GetEtaTileSize(void)               const { return fEMCGeometry->GetEtaTileSize()          ; }
  Float_t  GetPhiSuperModule(void)            const { return fEMCGeometry->GetPhiSuperModule()       ; }
  Int_t    GetNPhiSuperModule(void)           const { return fEMCGeometry->GetNPhiSuperModule()      ; }
  Int_t    GetNPHIdiv(void)                   const { return fEMCGeometry->GetNPHIdiv()              ; }
  Int_t    GetNETAdiv(void)                   const { return fEMCGeometry->GetNETAdiv()              ; }
  Int_t    GetNCells(void)                    const { return fEMCGeometry->GetNCells()               ; }
  Float_t  GetLongModuleSize(void)            const { return fEMCGeometry->GetLongModuleSize()       ; }
  Float_t  GetTrd1Angle(void)                 const { return fEMCGeometry->GetTrd1Angle()            ; }
  Float_t  Get2Trd1Dx2(void)                  const { return fEMCGeometry->Get2Trd1Dx2()             ; }
  Float_t  GetTrd1AlFrontThick()              const { return fEMCGeometry->GetTrd1AlFrontThick()     ; }
  Float_t  GetTrd1BondPaperThick()            const { return fEMCGeometry->GetTrd1BondPaperThick()   ; }
  // --
  Int_t    GetNCellsInSupMod(void)            const { return fEMCGeometry->GetNCellsInSupMod()       ; }
  Int_t    GetNCellsInModule(void)            const { return fEMCGeometry->GetNCellsInModule()       ; }
  Int_t    GetKey110DEG(void)                 const { return fEMCGeometry->GetKey110DEG()            ; }
  Int_t    GetnSupModInDCAL(void)             const { return fEMCGeometry->GetnSupModInDCAL()        ; }
  Int_t    GetILOSS(void)                     const { return fEMCGeometry->GetILOSS()                ; }
  Int_t    GetIHADR(void)                     const { return fEMCGeometry->GetIHADR()                ; }  
  // --
  Float_t  GetDeltaEta(void)                  const { return fEMCGeometry->GetDeltaEta()             ; }
  Float_t  GetDeltaPhi(void)                  const { return fEMCGeometry->GetDeltaPhi()             ; }
  Int_t    GetNTowers(void)                   const { return fEMCGeometry->GetNTowers()              ; }
  //
  Double_t GetPhiCenterOfSM(Int_t nsupmod)    const { return fEMCGeometry->GetPhiCenterOfSM(nsupmod) ; }
  Double_t GetPhiCenterOfSMSec(Int_t nsupmod) const { return fEMCGeometry->GetPhiCenterOfSMSec(nsupmod) ; }
  Float_t  GetSuperModulesPar(Int_t ipar)     const { return fEMCGeometry->GetSuperModulesPar(ipar)  ; }
  //
  Int_t    GetSMType(Int_t nSupMod)           const { if( nSupMod > fEMCGeometry->GetNumberOfSuperModules() ) return -1;
                                                      return fEMCSMSystem[nSupMod]		     ; }
  Bool_t   IsDCALSM(Int_t nSupMod) const;
  Bool_t   IsDCALExtSM(Int_t nSupMod) const;
  Bool_t   GetPhiBoundariesOfSM(Int_t nSupMod, Double_t &phiMin, Double_t &phiMax)    const 
    { return fEMCGeometry->GetPhiBoundariesOfSM(nSupMod, phiMin, phiMax)   ; }
  Bool_t   GetPhiBoundariesOfSMGap(Int_t nPhiSec, Double_t &phiMin, Double_t &phiMax) const 
    { return fEMCGeometry->GetPhiBoundariesOfSMGap(nPhiSec, phiMin, phiMax); }
  //
  // especially for SM in extension, where center of SM != center of the SM-section.
  // Used in AliEMCALv0 to calculate position.
  
  //////////////////////////////////////////////////
  // Obsolete methods to be thrown out when feasible
  Float_t GetGap2Active(void)                 const { return fEMCGeometry->GetGap2Active()           ; }
  Float_t GetSteelFrontThickness(void)        const { return fEMCGeometry->GetSteelFrontThickness()  ; }
  Float_t GetTrd2AngleY(void)                 const { return fEMCGeometry->GetTrd2AngleY()           ; }
  Float_t Get2Trd2Dy2(void)                   const { return fEMCGeometry->Get2Trd2Dy2()             ; }
  Float_t GetTubsR(void)                      const { return fEMCGeometry->GetTubsR()                ; }
  Float_t GetTubsTurnAngle(void)              const { return fEMCGeometry->GetTubsTurnAngle()        ; }
  //Float_t GetAlFrontThickness(void)           const { return fEMCGeometry->GetAlFrontThickness()     ; }
  //Float_t GetIP2ECASection(void)              const { return fEMCGeometry->GetIP2ECASection()        ; }   
  //////////////////////////////////////////////////
  
  ///////////////////////////////
  //Geometry data member setters
  //
  void SetNZ(Int_t nz)           { fEMCGeometry->SetNZ(nz)         ; }
  void SetNPhi(Int_t nphi)       { fEMCGeometry->SetNPhi(nphi)     ; }
  //Trigger
  void SetNTRUEta(Int_t ntru)    { fEMCGeometry->SetNTRUEta(ntru)  ; }
  void SetNTRUPhi(Int_t ntru)    { fEMCGeometry->SetNTRUPhi(ntru)  ; }
  //
  void SetSampling(Float_t samp) { fEMCGeometry->SetSampling(samp) ; }
  //
  void PrintGeometry()           { fEMCGeometry->PrintGeometry()   ; }  //*MENU*  
  
  //////////////////////////
  // Global geometry methods
  //
  void GetGlobal(const Double_t *loc, Double_t *glob, int ind) const;
  void GetGlobal(const TVector3 &vloc, TVector3 &vglob, int ind) const;
  void GetGlobal(Int_t absId, Double_t glob[3]) const;
  void GetGlobal(Int_t absId, TVector3 &vglob) const;

  ////////////////////////////////////////
  // May 31, 2006; ALICE numbering scheme: 
  // see ALICE-INT-2003-038: ALICE Coordinate System and Software Numbering Convention
  // All indexes are stared from zero now.
  // 
  // abs id <-> indexes; Shish-kebab case, only TRD1 now.
  // EMCAL -> Super Module -> module -> tower(or cell) - logic tree of EMCAL
  // 
  //**  Usual name of variable - Dec 18,2006 **
  //  nSupMod - index of super module (SM)
  //  nModule - index of module in SM
  //  nIphi   - phi index of tower(cell) in module
  //  nIeta   - eta index of tower(cell) in module
  //  
  //  Inside SM
  //  iphim   - phi index of module in SM  
  //  ietam   - eta index of module in SM  
  //
  //  iphi    - phi index of tower(cell) in SM  
  //  ieta    - eta index of tower(cell) in SM  
  //
  // for a given tower index absId returns eta and phi of gravity center of tower.
  void    EtaPhiFromIndex(Int_t absId, Double_t &eta, Double_t &phi) const;
  void    EtaPhiFromIndex(Int_t absId, Float_t  &eta, Float_t  &phi) const;

  Bool_t  GetAbsCellIdFromEtaPhi(Double_t eta,Double_t phi, Int_t &absId) const;
  Bool_t  SuperModuleNumberFromEtaPhi(Double_t eta, Double_t phi, Int_t &nSupMod) const;
  Int_t   GetAbsCellId(Int_t nSupMod, Int_t nModule, Int_t nIphi, Int_t nIeta) const;
  Bool_t  CheckAbsCellId(Int_t absId) const;
  Bool_t  GetCellIndex(Int_t absId, Int_t &nSupMod, Int_t &nModule, Int_t &nIphi, 
		       Int_t &nIeta) const;
  // Local coordinate of Super Module 
  void    GetModulePhiEtaIndexInSModule(Int_t nSupMod, Int_t nModule, Int_t &iphim, 
					Int_t &ietam) const;
  void    GetCellPhiEtaIndexInSModule(Int_t nSupMod, Int_t nModule, Int_t nIphi, Int_t nIeta,
                                      Int_t &iphi, Int_t &ieta) const ;
  Int_t   GetSuperModuleNumber(Int_t absId)  const;
  Int_t   GetNumberOfModuleInPhiDirection(Int_t nSupMod)  const
  { 
    if(     GetSMType(nSupMod) == kEMCAL_Half) return fNPhi/2;
    else if(GetSMType(nSupMod) == kEMCAL_3rd)  return fNPhi/3;
    else if(GetSMType(nSupMod) == kDCAL_Ext)   return fNPhi/3;
    else                                       return fNPhi;
  } 
  // From cell indexes to abs cell id
  void    GetModuleIndexesFromCellIndexesInSModule(Int_t nSupMod, Int_t iphi, Int_t ieta, 
					      Int_t &iphim, Int_t &ietam, Int_t &nModule) const;
  Int_t   GetAbsCellIdFromCellIndexes(Int_t nSupMod, Int_t iphi, Int_t ieta) const;

  // Methods for AliEMCALRecPoint - Feb 19, 2006
  Bool_t  RelPosCellInSModule(Int_t absId, 
                              Double_t &xr, Double_t &yr, Double_t &zr) const;
  Bool_t  RelPosCellInSModule(Int_t absId, Double_t distEff,
                              Double_t &xr, Double_t &yr, Double_t &zr) const;
  Bool_t  RelPosCellInSModule(Int_t absId, Double_t loc[3]) const;
  Bool_t  RelPosCellInSModule(Int_t absId, TVector3 &vloc)  const;

  Int_t  * GetEMCSystem()            const { return fEMCSMSystem          ; }     //EMC System, SM type list
  // Local Coordinates of SM
  TArrayD  GetCentersOfCellsEtaDir() const { return fCentersOfCellsEtaDir ; }     // size fNEta*fNETAdiv (for TRD1 only) (eta or z in SM, in cm)
  TArrayD  GetCentersOfCellsXDir()   const { return fCentersOfCellsXDir   ; }     // size fNEta*fNETAdiv (for TRD1 only) (       x in SM, in cm)
  TArrayD  GetCentersOfCellsPhiDir() const { return fCentersOfCellsPhiDir ; }     // size fNPhi*fNPHIdiv (for TRD1 only) (phi or y in SM, in cm)
  //
  TArrayD  GetEtaCentersOfCells()    const { return fEtaCentersOfCells    ; }     // [fNEta*fNETAdiv*fNPhi*fNPHIdiv], positive direction (eta>0); eta depend from phi position; 
  TArrayD  GetPhiCentersOfCells()    const { return fPhiCentersOfCells    ; }     // [fNPhi*fNPHIdiv] from center of SM (-10. < phi < +10.)

  
  // For gamma(Jet) trigger simulations *FIXME OLD TO BE REMOVED with AliEMCALTrigger*
  Int_t    GetNTRU()             const { return fEMCGeometry->GetNTRU()             ; }  
  Int_t    GetNTRUEta()          const { return fEMCGeometry->GetNTRUEta()          ; }  
  Int_t    GetNTRUPhi()          const { return fEMCGeometry->GetNTRUPhi()          ; }
  Int_t    GetNEtaSubOfTRU()     const { return fEMCGeometry->GetNEtaSubOfTRU()     ; }
  Int_t    GetNModulesInTRU()    const { return fEMCGeometry->GetNModulesInTRU()    ; }
  Int_t    GetNModulesInTRUEta() const { return fEMCGeometry->GetNModulesInTRUEta() ; }  
  Int_t    GetNModulesInTRUPhi() const { return fEMCGeometry->GetNModulesInTRUPhi() ; }
  Int_t    GetNTotalTRU()        const {return  fEMCGeometry->GetNTotalTRU()        ; }
  // *MEFIX OLD TO BE REMOVED*

  //
  // Tranforms Eta-Phi Module index in TRU into Eta-Phi index in Super Module
  void     GetModulePhiEtaIndexInSModuleFromTRUIndex(Int_t itru, Int_t iphitru, Int_t ietatru, 
                                                     Int_t &ietaSM, Int_t &iphiSM) const;
  Int_t   GetAbsTRUNumberFromNumberInSm(const Int_t row, const Int_t col, const Int_t sm) const ;

	
  void     BuildFastOR2DMap();
  Bool_t   GetAbsFastORIndexFromTRU(const Int_t iTRU, const Int_t iADC, Int_t& id) const;
  Bool_t                    GetAbsFastORIndexFromPositionInTRU(const Int_t iTRU, const Int_t iEta, const Int_t iPhi, Int_t& id) const;	
  Bool_t                    GetAbsFastORIndexFromPositionInSM( const Int_t  iSM, const Int_t iEta, const Int_t iPhi, Int_t& id) const;	
  Bool_t                    GetAbsFastORIndexFromPositionInEMCAL(                const Int_t iEta, const Int_t iPhi, Int_t& id) const;
  Bool_t             GetTRUFromAbsFastORIndex(const Int_t id, Int_t& iTRU, Int_t& iADC) const;
  Bool_t   GetPositionInTRUFromAbsFastORIndex(const Int_t id, Int_t& iTRU, Int_t& iEta, Int_t& iPhi) const;
  Bool_t    GetPositionInSMFromAbsFastORIndex(const Int_t id, Int_t& iSM, Int_t& iEta, Int_t& iPhi) const;
  Bool_t GetPositionInEMCALFromAbsFastORIndex(const Int_t id, Int_t& iEta, Int_t& iPhi) const;
  Bool_t          GetFastORIndexFromCellIndex(const Int_t id, Int_t& idx) const;
  Bool_t          GetCellIndexFromFastORIndex(const Int_t id, Int_t idx[4]) const;
  Bool_t              GetTRUIndexFromSTUIndex(const Int_t id, Int_t& idx) const;
  Int_t               GetTRUIndexFromSTUIndex(const Int_t id) const;
  Bool_t           GetTRUIndexFromOnlineIndex(const Int_t id, Int_t& idx) const;
  Int_t            GetTRUIndexFromOnlineIndex(const Int_t id) const;
  Bool_t           GetOnlineIndexFromTRUIndex(const Int_t id, Int_t& idx) const;
  Int_t            GetOnlineIndexFromTRUIndex(const Int_t id) const;
  Bool_t            GetFastORIndexFromL0Index(const Int_t iTRU, const Int_t id, Int_t idx[], const Int_t size) const;
	
  ///////////////////
  // useful utilities
  //
  Float_t AngleFromEta(Float_t eta)        const { // returns theta in radians for a given pseudorapidity
    return 2.0*TMath::ATan(TMath::Exp(-eta));
  }
  Float_t ZFromEtaR(Float_t r,Float_t eta) const { // returns z in for a given
    // pseudorapidity and r=sqrt(x*x+y*y).
    return r/TMath::Tan(AngleFromEta(eta));
  }

  //Method to set shift-rotational matrixes from ESDHeader
  void SetMisalMatrix(const TGeoHMatrix * m, Int_t smod);
	
  //Alternate geometry that allows to calculate tower position for different particles and different alignments
  void RecalculateTowerPosition(Float_t drow, Float_t dcol, const Int_t sm, const Float_t depth,
                                const Float_t misaligTransShifts[15], const Float_t misaligRotShifts[15],Float_t global[3]) const;
  
  //Returns shift-rotational matrixes for different volumes
  const TGeoHMatrix * GetMatrixForSuperModule(Int_t smod)const ;
	
protected:

  void Init(void);     		     // initializes the parameters of EMCAL
  
  AliEMCALEMCGeometry * fEMCGeometry;// Geometry object for Electromagnetic calorimeter

  TString  fGeoName;                 // geometry name
  Int_t    *fEMCSMSystem;	           // geometry structure
  Int_t    fKey110DEG;               // for calculation abs cell id; 19-oct-05 
  Int_t    fnSupModInDCAL;           // for calculation abs cell id; 06-nov-12
  Int_t    fNCellsInSupMod;          // number cell in super module
  Int_t    fNETAdiv;                 // number eta divizion of module
  Int_t    fNPHIdiv;                 // number phi divizion of module
  Int_t    fNCellsInModule;          // number cell in module
  TArrayD  fPhiBoundariesOfSM;       // phi boundaries of SM in rad; size is fNumberOfSuperModules;
  TArrayD  fPhiCentersOfSM;          // phi of centers of SM; size is fNumberOfSuperModules/2
  TArrayD  fPhiCentersOfSMSec;       // phi of centers of section where SM lies; size is fNumberOfSuperModules/2
  // Local Coordinates of SM
  TArrayD  fPhiCentersOfCells;       // [fNPhi*fNPHIdiv] from center of SM (-10. < phi < +10.)
  TArrayD  fCentersOfCellsEtaDir;    // size fNEta*fNETAdiv (for TRD1 only) (eta or z in SM, in cm)
  TArrayD  fCentersOfCellsPhiDir;    // size fNPhi*fNPHIdiv (for TRD1 only) (phi or y in SM, in cm)
  TArrayD  fEtaCentersOfCells;       // [fNEta*fNETAdiv*fNPhi*fNPHIdiv], positive direction (eta>0); eta depend from phi position; 
  Int_t    fNCells;                  // number of cells in calo
  Int_t    fNPhi;                    // Number of Towers in the PHI direction
  TArrayD  fCentersOfCellsXDir;      // size fNEta*fNETAdiv (for TRD1 only) (       x in SM, in cm)
  Float_t  fEnvelop[3];              // the GEANT TUB for the detector 
  Float_t  fArm1EtaMin;              // Minimum pseudorapidity position of EMCAL in Eta
  Float_t  fArm1EtaMax;              // Maximum pseudorapidity position of EMCAL in Eta
  Float_t  fArm1PhiMin;              // Minimum angular position of EMCAL in Phi (degrees)
  Float_t  fArm1PhiMax;              // Maximum angular position of EMCAL in Phi (degrees)
  Float_t  fEtaMaxOfTRD1;            // Max eta in case of TRD1 geometry (see AliEMCALShishKebabTrd1Module)
  Float_t  fDCALPhiMin;              // Minimum angular position of DCAL in Phi (degrees)
  Float_t  fDCALPhiMax;              // Maximum angular position of DCAL in Phi (degrees)
  Float_t  fEMCALPhiMax;             // Maximum angular position of EMCAL in Phi (degrees)
  Float_t  fDCALStandardPhiMax;      // special edge for the case that DCAL contian extension
  Float_t  fDCALInnerExtandedEta;    // DCAL inner edge in Eta (with some extension)
  TList   *fShishKebabTrd1Modules;   // list of modules
  Float_t  fParSM[3];                // SM sizes as in GEANT (TRD1)
  Float_t  fPhiModuleSize;           // Phi -> X 
  Float_t  fEtaModuleSize;           // Eta -> Y 
  Float_t  fPhiTileSize;             // Size of phi tile
  Float_t  fEtaTileSize;             // Size of eta tile
  Int_t    fNZ;                      // Number of Towers in the Z direction
  Float_t  fIPDistance;		           // Radial Distance of the inner surface of the EMCAL
  Float_t  fLongModuleSize;          // Size of long module
  // Geometry Parameters
  Float_t  fShellThickness;	         // Total thickness in (x,y) direction
  Float_t  fZLength;		             // Total length in z direction
  Float_t  fSampling;		             // Sampling factor

  Int_t    fFastOR2DMap[48][124];    // FastOR 2D Map over full EMCal
	
  TGeoHMatrix* fkSModuleMatrix[AliEMCALGeoParams::fgkEMCALModules] ; //Orientations of EMCAL super modules
  Bool_t   fUseExternalMatrices;      // Use the matrices set in fkSModuleMatrix and not those in the geoManager
	
private:
  
  static AliEMCALGeometry *fgGeom;	               // Pointer to the unique instance of the singleton
  static Bool_t            fgInit;	               // Tells if geometry has been succesfully set up.
  static const Char_t     *fgkDefaultGeometryName; // Default name of geometry
  
  
  ClassDef(AliEMCALGeometry,17)       // EMCAL geometry class 

} ;

#endif // AliEMCALGEOUTILS_H

 AliEMCALGeometry.h:1
 AliEMCALGeometry.h:2
 AliEMCALGeometry.h:3
 AliEMCALGeometry.h:4
 AliEMCALGeometry.h:5
 AliEMCALGeometry.h:6
 AliEMCALGeometry.h:7
 AliEMCALGeometry.h:8
 AliEMCALGeometry.h:9
 AliEMCALGeometry.h:10
 AliEMCALGeometry.h:11
 AliEMCALGeometry.h:12
 AliEMCALGeometry.h:13
 AliEMCALGeometry.h:14
 AliEMCALGeometry.h:15
 AliEMCALGeometry.h:16
 AliEMCALGeometry.h:17
 AliEMCALGeometry.h:18
 AliEMCALGeometry.h:19
 AliEMCALGeometry.h:20
 AliEMCALGeometry.h:21
 AliEMCALGeometry.h:22
 AliEMCALGeometry.h:23
 AliEMCALGeometry.h:24
 AliEMCALGeometry.h:25
 AliEMCALGeometry.h:26
 AliEMCALGeometry.h:27
 AliEMCALGeometry.h:28
 AliEMCALGeometry.h:29
 AliEMCALGeometry.h:30
 AliEMCALGeometry.h:31
 AliEMCALGeometry.h:32
 AliEMCALGeometry.h:33
 AliEMCALGeometry.h:34
 AliEMCALGeometry.h:35
 AliEMCALGeometry.h:36
 AliEMCALGeometry.h:37
 AliEMCALGeometry.h:38
 AliEMCALGeometry.h:39
 AliEMCALGeometry.h:40
 AliEMCALGeometry.h:41
 AliEMCALGeometry.h:42
 AliEMCALGeometry.h:43
 AliEMCALGeometry.h:44
 AliEMCALGeometry.h:45
 AliEMCALGeometry.h:46
 AliEMCALGeometry.h:47
 AliEMCALGeometry.h:48
 AliEMCALGeometry.h:49
 AliEMCALGeometry.h:50
 AliEMCALGeometry.h:51
 AliEMCALGeometry.h:52
 AliEMCALGeometry.h:53
 AliEMCALGeometry.h:54
 AliEMCALGeometry.h:55
 AliEMCALGeometry.h:56
 AliEMCALGeometry.h:57
 AliEMCALGeometry.h:58
 AliEMCALGeometry.h:59
 AliEMCALGeometry.h:60
 AliEMCALGeometry.h:61
 AliEMCALGeometry.h:62
 AliEMCALGeometry.h:63
 AliEMCALGeometry.h:64
 AliEMCALGeometry.h:65
 AliEMCALGeometry.h:66
 AliEMCALGeometry.h:67
 AliEMCALGeometry.h:68
 AliEMCALGeometry.h:69
 AliEMCALGeometry.h:70
 AliEMCALGeometry.h:71
 AliEMCALGeometry.h:72
 AliEMCALGeometry.h:73
 AliEMCALGeometry.h:74
 AliEMCALGeometry.h:75
 AliEMCALGeometry.h:76
 AliEMCALGeometry.h:77
 AliEMCALGeometry.h:78
 AliEMCALGeometry.h:79
 AliEMCALGeometry.h:80
 AliEMCALGeometry.h:81
 AliEMCALGeometry.h:82
 AliEMCALGeometry.h:83
 AliEMCALGeometry.h:84
 AliEMCALGeometry.h:85
 AliEMCALGeometry.h:86
 AliEMCALGeometry.h:87
 AliEMCALGeometry.h:88
 AliEMCALGeometry.h:89
 AliEMCALGeometry.h:90
 AliEMCALGeometry.h:91
 AliEMCALGeometry.h:92
 AliEMCALGeometry.h:93
 AliEMCALGeometry.h:94
 AliEMCALGeometry.h:95
 AliEMCALGeometry.h:96
 AliEMCALGeometry.h:97
 AliEMCALGeometry.h:98
 AliEMCALGeometry.h:99
 AliEMCALGeometry.h:100
 AliEMCALGeometry.h:101
 AliEMCALGeometry.h:102
 AliEMCALGeometry.h:103
 AliEMCALGeometry.h:104
 AliEMCALGeometry.h:105
 AliEMCALGeometry.h:106
 AliEMCALGeometry.h:107
 AliEMCALGeometry.h:108
 AliEMCALGeometry.h:109
 AliEMCALGeometry.h:110
 AliEMCALGeometry.h:111
 AliEMCALGeometry.h:112
 AliEMCALGeometry.h:113
 AliEMCALGeometry.h:114
 AliEMCALGeometry.h:115
 AliEMCALGeometry.h:116
 AliEMCALGeometry.h:117
 AliEMCALGeometry.h:118
 AliEMCALGeometry.h:119
 AliEMCALGeometry.h:120
 AliEMCALGeometry.h:121
 AliEMCALGeometry.h:122
 AliEMCALGeometry.h:123
 AliEMCALGeometry.h:124
 AliEMCALGeometry.h:125
 AliEMCALGeometry.h:126
 AliEMCALGeometry.h:127
 AliEMCALGeometry.h:128
 AliEMCALGeometry.h:129
 AliEMCALGeometry.h:130
 AliEMCALGeometry.h:131
 AliEMCALGeometry.h:132
 AliEMCALGeometry.h:133
 AliEMCALGeometry.h:134
 AliEMCALGeometry.h:135
 AliEMCALGeometry.h:136
 AliEMCALGeometry.h:137
 AliEMCALGeometry.h:138
 AliEMCALGeometry.h:139
 AliEMCALGeometry.h:140
 AliEMCALGeometry.h:141
 AliEMCALGeometry.h:142
 AliEMCALGeometry.h:143
 AliEMCALGeometry.h:144
 AliEMCALGeometry.h:145
 AliEMCALGeometry.h:146
 AliEMCALGeometry.h:147
 AliEMCALGeometry.h:148
 AliEMCALGeometry.h:149
 AliEMCALGeometry.h:150
 AliEMCALGeometry.h:151
 AliEMCALGeometry.h:152
 AliEMCALGeometry.h:153
 AliEMCALGeometry.h:154
 AliEMCALGeometry.h:155
 AliEMCALGeometry.h:156
 AliEMCALGeometry.h:157
 AliEMCALGeometry.h:158
 AliEMCALGeometry.h:159
 AliEMCALGeometry.h:160
 AliEMCALGeometry.h:161
 AliEMCALGeometry.h:162
 AliEMCALGeometry.h:163
 AliEMCALGeometry.h:164
 AliEMCALGeometry.h:165
 AliEMCALGeometry.h:166
 AliEMCALGeometry.h:167
 AliEMCALGeometry.h:168
 AliEMCALGeometry.h:169
 AliEMCALGeometry.h:170
 AliEMCALGeometry.h:171
 AliEMCALGeometry.h:172
 AliEMCALGeometry.h:173
 AliEMCALGeometry.h:174
 AliEMCALGeometry.h:175
 AliEMCALGeometry.h:176
 AliEMCALGeometry.h:177
 AliEMCALGeometry.h:178
 AliEMCALGeometry.h:179
 AliEMCALGeometry.h:180
 AliEMCALGeometry.h:181
 AliEMCALGeometry.h:182
 AliEMCALGeometry.h:183
 AliEMCALGeometry.h:184
 AliEMCALGeometry.h:185
 AliEMCALGeometry.h:186
 AliEMCALGeometry.h:187
 AliEMCALGeometry.h:188
 AliEMCALGeometry.h:189
 AliEMCALGeometry.h:190
 AliEMCALGeometry.h:191
 AliEMCALGeometry.h:192
 AliEMCALGeometry.h:193
 AliEMCALGeometry.h:194
 AliEMCALGeometry.h:195
 AliEMCALGeometry.h:196
 AliEMCALGeometry.h:197
 AliEMCALGeometry.h:198
 AliEMCALGeometry.h:199
 AliEMCALGeometry.h:200
 AliEMCALGeometry.h:201
 AliEMCALGeometry.h:202
 AliEMCALGeometry.h:203
 AliEMCALGeometry.h:204
 AliEMCALGeometry.h:205
 AliEMCALGeometry.h:206
 AliEMCALGeometry.h:207
 AliEMCALGeometry.h:208
 AliEMCALGeometry.h:209
 AliEMCALGeometry.h:210
 AliEMCALGeometry.h:211
 AliEMCALGeometry.h:212
 AliEMCALGeometry.h:213
 AliEMCALGeometry.h:214
 AliEMCALGeometry.h:215
 AliEMCALGeometry.h:216
 AliEMCALGeometry.h:217
 AliEMCALGeometry.h:218
 AliEMCALGeometry.h:219
 AliEMCALGeometry.h:220
 AliEMCALGeometry.h:221
 AliEMCALGeometry.h:222
 AliEMCALGeometry.h:223
 AliEMCALGeometry.h:224
 AliEMCALGeometry.h:225
 AliEMCALGeometry.h:226
 AliEMCALGeometry.h:227
 AliEMCALGeometry.h:228
 AliEMCALGeometry.h:229
 AliEMCALGeometry.h:230
 AliEMCALGeometry.h:231
 AliEMCALGeometry.h:232
 AliEMCALGeometry.h:233
 AliEMCALGeometry.h:234
 AliEMCALGeometry.h:235
 AliEMCALGeometry.h:236
 AliEMCALGeometry.h:237
 AliEMCALGeometry.h:238
 AliEMCALGeometry.h:239
 AliEMCALGeometry.h:240
 AliEMCALGeometry.h:241
 AliEMCALGeometry.h:242
 AliEMCALGeometry.h:243
 AliEMCALGeometry.h:244
 AliEMCALGeometry.h:245
 AliEMCALGeometry.h:246
 AliEMCALGeometry.h:247
 AliEMCALGeometry.h:248
 AliEMCALGeometry.h:249
 AliEMCALGeometry.h:250
 AliEMCALGeometry.h:251
 AliEMCALGeometry.h:252
 AliEMCALGeometry.h:253
 AliEMCALGeometry.h:254
 AliEMCALGeometry.h:255
 AliEMCALGeometry.h:256
 AliEMCALGeometry.h:257
 AliEMCALGeometry.h:258
 AliEMCALGeometry.h:259
 AliEMCALGeometry.h:260
 AliEMCALGeometry.h:261
 AliEMCALGeometry.h:262
 AliEMCALGeometry.h:263
 AliEMCALGeometry.h:264
 AliEMCALGeometry.h:265
 AliEMCALGeometry.h:266
 AliEMCALGeometry.h:267
 AliEMCALGeometry.h:268
 AliEMCALGeometry.h:269
 AliEMCALGeometry.h:270
 AliEMCALGeometry.h:271
 AliEMCALGeometry.h:272
 AliEMCALGeometry.h:273
 AliEMCALGeometry.h:274
 AliEMCALGeometry.h:275
 AliEMCALGeometry.h:276
 AliEMCALGeometry.h:277
 AliEMCALGeometry.h:278
 AliEMCALGeometry.h:279
 AliEMCALGeometry.h:280
 AliEMCALGeometry.h:281
 AliEMCALGeometry.h:282
 AliEMCALGeometry.h:283
 AliEMCALGeometry.h:284
 AliEMCALGeometry.h:285
 AliEMCALGeometry.h:286
 AliEMCALGeometry.h:287
 AliEMCALGeometry.h:288
 AliEMCALGeometry.h:289
 AliEMCALGeometry.h:290
 AliEMCALGeometry.h:291
 AliEMCALGeometry.h:292
 AliEMCALGeometry.h:293
 AliEMCALGeometry.h:294
 AliEMCALGeometry.h:295
 AliEMCALGeometry.h:296
 AliEMCALGeometry.h:297
 AliEMCALGeometry.h:298
 AliEMCALGeometry.h:299
 AliEMCALGeometry.h:300
 AliEMCALGeometry.h:301
 AliEMCALGeometry.h:302
 AliEMCALGeometry.h:303
 AliEMCALGeometry.h:304
 AliEMCALGeometry.h:305
 AliEMCALGeometry.h:306
 AliEMCALGeometry.h:307
 AliEMCALGeometry.h:308
 AliEMCALGeometry.h:309
 AliEMCALGeometry.h:310
 AliEMCALGeometry.h:311
 AliEMCALGeometry.h:312
 AliEMCALGeometry.h:313
 AliEMCALGeometry.h:314
 AliEMCALGeometry.h:315
 AliEMCALGeometry.h:316
 AliEMCALGeometry.h:317
 AliEMCALGeometry.h:318
 AliEMCALGeometry.h:319
 AliEMCALGeometry.h:320
 AliEMCALGeometry.h:321
 AliEMCALGeometry.h:322
 AliEMCALGeometry.h:323
 AliEMCALGeometry.h:324
 AliEMCALGeometry.h:325
 AliEMCALGeometry.h:326
 AliEMCALGeometry.h:327
 AliEMCALGeometry.h:328
 AliEMCALGeometry.h:329
 AliEMCALGeometry.h:330
 AliEMCALGeometry.h:331
 AliEMCALGeometry.h:332
 AliEMCALGeometry.h:333
 AliEMCALGeometry.h:334
 AliEMCALGeometry.h:335
 AliEMCALGeometry.h:336
 AliEMCALGeometry.h:337
 AliEMCALGeometry.h:338
 AliEMCALGeometry.h:339
 AliEMCALGeometry.h:340
 AliEMCALGeometry.h:341
 AliEMCALGeometry.h:342
 AliEMCALGeometry.h:343
 AliEMCALGeometry.h:344
 AliEMCALGeometry.h:345
 AliEMCALGeometry.h:346
 AliEMCALGeometry.h:347
 AliEMCALGeometry.h:348
 AliEMCALGeometry.h:349
 AliEMCALGeometry.h:350
 AliEMCALGeometry.h:351
 AliEMCALGeometry.h:352
 AliEMCALGeometry.h:353
 AliEMCALGeometry.h:354
 AliEMCALGeometry.h:355
 AliEMCALGeometry.h:356
 AliEMCALGeometry.h:357
 AliEMCALGeometry.h:358
 AliEMCALGeometry.h:359
 AliEMCALGeometry.h:360
 AliEMCALGeometry.h:361
 AliEMCALGeometry.h:362
 AliEMCALGeometry.h:363
 AliEMCALGeometry.h:364
 AliEMCALGeometry.h:365
 AliEMCALGeometry.h:366
 AliEMCALGeometry.h:367
 AliEMCALGeometry.h:368
 AliEMCALGeometry.h:369
 AliEMCALGeometry.h:370
 AliEMCALGeometry.h:371
 AliEMCALGeometry.h:372
 AliEMCALGeometry.h:373
 AliEMCALGeometry.h:374
 AliEMCALGeometry.h:375