EEUnit

MEEEGeom

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
#ifndef CalibCalorimetry_EcalLaserAnalyzer_MEEEGeom_h
#define CalibCalorimetry_EcalLaserAnalyzer_MEEEGeom_h

//
// Authors  : Gautier Hamel de Monchenault and Julie Malcles, Saclay
//

#include <vector>
#include <map>
#include <list>

#include "TPolyLine.h"
#include "TGraph.h"

class MEEEGeom {
  // static functions
public:
  enum EEUnit { iEcalEndCap = 0, iDee, iQuadrant, iSector, iDCC, iLMRegion, iLMModule, iSuperCrystal, iCrystal };

  typedef int SuperCrysCoord;
  typedef int CrysCoord;

  typedef std::pair<float, float> EtaPhiPoint;

  static int dee(SuperCrysCoord iX, SuperCrysCoord iY, int iz);
  static int quadrant(SuperCrysCoord iX, SuperCrysCoord iY);
  static int sector(SuperCrysCoord iX, SuperCrysCoord iY);
  static int sm(SuperCrysCoord iX, SuperCrysCoord iY, int iz);
  static int lmmod(SuperCrysCoord iX, SuperCrysCoord iY);
  static int sc_in_quad(SuperCrysCoord iX, SuperCrysCoord iY);
  static int sc(SuperCrysCoord iX, SuperCrysCoord iY);
  static int dcc(SuperCrysCoord iX, SuperCrysCoord iY, int iz);
  static int lmr(SuperCrysCoord iX, SuperCrysCoord iY, int iz);
  static int side(SuperCrysCoord iX, SuperCrysCoord iY, int iz);

  static int crystal_in_sc(CrysCoord ix, CrysCoord iy);
  static int crystal(CrysCoord ix, CrysCoord iy);

  static int dee(int ilmr);
  static bool near(int ilmr);

  static TString smName(int ism);
  static int smFromDcc(int idcc);
  static int dccFromSm(int ism);

  static const bool pnTheory;  // if true: theoretical PN cabling for all dees
  static std::pair<int, int> pn(int dee, int ilmod);
  static std::pair<int, int> memFromLmr(int ilmr);
  static std::vector<int> lmmodFromLmr(int ilmr);
  static int deeFromMem(int imem);
  static int apdRefTower(int ilmr, int ilmmod);
  static std::vector<int> apdRefChannels(int ilmmod);

  static TGraph* getGraphBoundary(int type, int num, int iz = -1, int xside = 0);
  static void getBoundary(std::list<std::pair<float, float> >& l, int type, int num, int iz = -1, int xside = 0);

  static int sc_type(SuperCrysCoord iX, SuperCrysCoord iY);

  virtual ~MEEEGeom() {}

protected:
  //GHM  ClassDef(MEEEGeom,0) // MEEEGeom -- Monitoring utility for survey of Ecal
};

#endif