10 #include <arich/utility/ARICHAerogelHist.h> 
   30 ARICHAerogelHist::ARICHAerogelHist(
const char* name, 
const char* title) : TH2Poly(), m_histName(name), m_histTitle(title)
 
   38     std::cout << setw(10) << 
"ring" << setw(10) << 
"nTiles" << setw(10) << 
"tileRmin" << setw(10) << 
"tileRmax" << std::endl;
 
   39     for (
unsigned int i = 0; i < 
m_nTiles.size(); i++)
 
   61     for (Int_t j = 0; j < 
m_nTiles[iR]; j++) {
 
   62       phi = phi0 + deltaPhi * j;
 
   67       for (
unsigned int i = 0; i < n; i++) {
 
   68         xold = m.second[i].X();
 
   69         yold = m.second[i].Y();
 
   87   unsigned int ringu = ring;
 
   89   if (ringu > 
m_nTiles.size() || ringu < 1)
 
   91   if (column > 
m_nTiles[ring - 1] || column < 1)
 
   93   for (Int_t i = 1; i < ring; i++)
 
   95   return binID + column;
 
  102   TVector2 v(xold, yold);
 
  104   vrot = v.Rotate(phi);
 
  113   TCanvas* c1 = 
new TCanvas(
"c1", 
"c1", 1000, 1000);
 
  116   c1->SetRightMargin(0.17);
 
  117   c1->SetLeftMargin(0.12);
 
  118   c1->SetTopMargin(0.15);
 
  119   c1->SetBottomMargin(0.15);
 
  121   TH2F* frame = 
new TH2F(
"h2", 
"h2", 40, -1200, 1200, 40, -1200, 1200);
 
  123   frame->GetXaxis()->SetTitle(
"x (mm)");
 
  124   frame->GetYaxis()->SetTitle(
"y (mm)");
 
  125   frame->GetXaxis()->CenterTitle();
 
  126   frame->GetYaxis()->CenterTitle();
 
  127   frame->GetYaxis()->SetTitleOffset(1.5);
 
  128   frame->SetStats(kFALSE);
 
  135   if (outDirName.Length() > 0) {
 
  136     std::cout << 
"outDirName.Length() " << outDirName.Length() << std::endl;
 
  137     TString outnamePDF = outDirName; outnamePDF += 
m_histName; outnamePDF += 
".pdf";
 
  138     TString outnameEPS = outDirName; outnameEPS += 
m_histName; outnameEPS += 
".eps";
 
  139     c1->SaveAs(outnamePDF.Data());
 
  140     c1->SaveAs(outnameEPS.Data());
 
  150     std::cout << 
" --> Aerogel ring : " << m.first << 
'\n';
 
  151     for (i = 0; i < m.second.size(); i++) {
 
  152       std::cout << 
"                    " << setw(15) << m.second[i].X() << setw(15) << m.second[i].Y() << std::endl;
 
  161   for (
unsigned int i = 0; i < 
m_nTiles.size(); i++) {
 
  162     std::vector<TVector2> vecTvec;
 
  168     double phimin = lmin / rmin;
 
  169     double phimax = lmax / rmax;
 
  170     double x1 = rmin * TMath::Cos(phimin / 2.0);
 
  171     double y1 = rmin * TMath::Sin(phimin / 2.0);
 
  173     vecTvec.push_back(v1);
 
  174     double x2 = rmax * TMath::Cos(phimax / 2.0);
 
  175     double y2 = rmax * TMath::Sin(phimax / 2.0);
 
  177     vecTvec.push_back(v2);
 
  183         v.SetMagPhi(rmax, (phimax / 2.0 - dPhi * (j + 1)));
 
  184         vecTvec.push_back(v);
 
  191     vecTvec.push_back(v3);
 
  195     vecTvec.push_back(v4);
 
  201         v.SetMagPhi(rmin, (-phimax / 2.0 + dPhi * (j + 1)));
 
  202         vecTvec.push_back(v);
 
  206     vecTvec.push_back(v1);
 
  236   for (
unsigned int i = 0; i < 
m_nTiles.size(); i++) {
 
TString m_histTitle
Histogram title.
TString m_histName
Histogram name.
std::map< Int_t, std::vector< TVector2 > > m_verticesMap
Aerogel vertices map.
Int_t m_verboseLevel
Verbose level.
std::vector< double > m_tileRmax
Maximum radius of aerogel ring.
void SetUpVerticesMap()
Function for calculation vertices for one aerogel tile.
std::vector< Int_t > m_nTiles
Number of tiles per ring.
std::vector< double > m_tileRcenter
Center radius of aerogel ring.
void SetInitialParametersByDefault()
Function which set initial values of input parameters.
Int_t m_nCircularPoints
Number of circular points.
std::vector< double > m_tileDeltaPhiCenter
Angle opening (phi) of the aerogel tile measured between two rays (0.0,0.0 : and centre of the ring f...
std::vector< double > m_tileRmin
Minimum radius of aerogel ring.
void dumpVerticesMap()
Function to print vertices for one aerogel tile.
std::vector< double > m_aerogelAriGapDeltaPhiCenter
Angle opening (phi) of the air gap between aerogel tiles.
Int_t GetBinIDFromRingColumn(Int_t ring, Int_t column)
Function which return histogram bin id from ring and column id's.
double m_aerogelTileGap
Distance between aerogel tiles.
void makeRotation(double xold, double yold, double &xnew, double &ynew, double phi)
Function to rotate 2D point (x and y) around z axis by angle phi.
void DrawHisto(TString opt, TString outDirName)
Function to draw the histogram.
Abstract base class for different kinds of events.