source: trunk/MagicSoft/Mars/mgeom/MGeomCam.cc@ 2384

Last change on this file since 2384 was 2236, checked in by tbretz, 21 years ago
*** empty log message ***
File size: 4.5 KB
Line 
1/* ======================================================================== *\
2!
3! *
4! * This file is part of MARS, the MAGIC Analysis and Reconstruction
5! * Software. It is distributed to you in the hope that it can be a useful
6! * and timesaving tool in analysing Data of imaging Cerenkov telescopes.
7! * It is distributed WITHOUT ANY WARRANTY.
8! *
9! * Permission to use, copy, modify and distribute this software and its
10! * documentation for any purpose is hereby granted without fee,
11! * provided that the above copyright notice appear in all copies and
12! * that both that copyright notice and this permission notice appear
13! * in supporting documentation. It is provided "as is" without express
14! * or implied warranty.
15! *
16!
17!
18! Author(s): Thomas Bretz 12/2000 <mailto:tbretz@uni-sw.gwdg.de>
19! Author(s): Harald Kornmayer 1/2001
20!
21! Copyright: MAGIC Software Development, 2000-2002
22!
23!
24\* ======================================================================== */
25
26///////////////////////////////////////////////////////////////////////
27//
28// MGeomCam
29//
30// This is the base class of different camera geometries. It creates
31// a pixel object for a given number of pixels and defines the
32// interface of how to acccess the geometry information.
33//
34///////////////////////////////////////////////////////////////////////
35#include "MGeomCam.h"
36
37#include <TClass.h> // IsA()->New()
38
39#include "MLog.h"
40#include "MLogManip.h"
41
42#include "MGeomPix.h"
43
44ClassImp(MGeomCam);
45
46using namespace std;
47
48MGeomCam::MGeomCam()
49 : fNumPixels(0), fCamDist(0), fConvMm2Deg(0)
50{
51}
52
53
54
55// --------------------------------------------------------------------------
56//
57// Initializes a Camera Geometry with npix pixels. All pixels
58// are deleted when the corresponding array is deleted.
59//
60MGeomCam::MGeomCam(UInt_t npix, Float_t dist, const char *name, const char *title)
61 : fNumPixels(npix), fCamDist(dist), fConvMm2Deg(kRad2Deg/(dist*1000)), fPixels(npix)
62{
63 fName = name ? name : "MGeomCam";
64 fTitle = title ? title : "Storage container for a camera geometry";
65
66 //
67 // make sure that the destructor delete all contained objects
68 //
69 fPixels.SetOwner();
70
71 for (UInt_t i=0; i<npix; i++)
72 fPixels[i] = new MGeomPix;
73
74 SetReadyToSave();
75}
76
77MGeomPix &MGeomCam::operator[](Int_t i)
78{
79 return *static_cast<MGeomPix*>(fPixels.UncheckedAt(i));
80}
81
82MGeomPix &MGeomCam::operator[](Int_t i) const
83{
84 return *static_cast<MGeomPix*>(fPixels.UncheckedAt(i));
85}
86
87// --------------------------------------------------------------------------
88//
89// Set the kIsOuterRing flag for all pixels which have a outermost pixel
90// as Next Neighbor and don't have the kIsOutermostRing flag itself.
91//
92void MGeomCam::InitOuterRing()
93{
94 fPixels.ForEach(MGeomPix, CheckOuterRing)(*this);
95}
96
97// --------------------------------------------------------------------------
98//
99// Calculate the highest sector index+1 of all pixels, please make sure
100// the the sector numbers are continous.
101//
102void MGeomCam::CalcNumSectors()
103{
104 fNumSectors = 0;
105
106 for (UInt_t i=0; i<fNumPixels; i++)
107 {
108 const MGeomPix &pix = (*this)[i];
109 const UInt_t s = pix.GetSector();
110
111 if (s>fNumSectors)
112 fNumSectors = s;
113 }
114
115 fNumSectors++;
116}
117
118// --------------------------------------------------------------------------
119//
120// Calculate the maximum radius of the camera. This is ment for GUI layout.
121//
122void MGeomCam::CalcMaxRadius()
123{
124 fMaxRadius = 0;
125
126 for (UInt_t i=0; i<fNumPixels; i++)
127 {
128 const MGeomPix &pix = (*this)[i];
129
130 const Float_t x = pix.GetX();
131 const Float_t y = pix.GetY();
132 const Float_t d = pix.GetD();
133
134 const Float_t maxr = sqrt(x*x+y*y) + d;
135
136 if (maxr>fMaxRadius)
137 fMaxRadius = maxr;
138 }
139}
140
141// --------------------------------------------------------------------------
142//
143// returns the ratio of the area of the pixel with index 0 to the pixel
144// with the specified index i. 0 Is returned if the index argument is
145// out of range.
146//
147Float_t MGeomCam::GetPixRatio(UInt_t i) const
148{
149 return i<fNumPixels ? (*this)[0].GetA()/(*this)[i].GetA() : 0;
150}
151
152// --------------------------------------------------------------------------
153//
154// Prints the Geometry information of all pixels in the camera
155//
156void MGeomCam::Print(Option_t *) const
157{
158 //
159 // Print Information about the Geometry of the camera
160 //
161 *fLog << all << " Number of Pixels (" << GetTitle() << "): " << fNumPixels << endl;
162
163 fPixels.Print();
164}
165
166TObject *MGeomCam::Clone(const char *newname) const
167{
168 return (TObject*)IsA()->New();
169}
Note: See TracBrowser for help on using the repository browser.