/* ======================================================================== *\ ! ! * ! * This file is part of MARS, the MAGIC Analysis and Reconstruction ! * Software. It is distributed to you in the hope that it can be a useful ! * and timesaving tool in analysing Data of imaging Cerenkov telescopes. ! * It is distributed WITHOUT ANY WARRANTY. ! * ! * Permission to use, copy, modify and distribute this software and its ! * documentation for any purpose is hereby granted without fee, ! * provided that the above copyright notice appear in all copies and ! * that both that copyright notice and this permission notice appear ! * in supporting documentation. It is provided "as is" without express ! * or implied warranty. ! * ! ! ! Author(s): Thomas Bretz 12/2000 ! Author(s): Harald Kornmayer 1/2001 ! ! Copyright: MAGIC Software Development, 2000-2002 ! ! \* ======================================================================== */ /////////////////////////////////////////////////////////////////////// // // MHFadcCam // // This class contains a list of MHFadcPix. // /////////////////////////////////////////////////////////////////////// #include "MHFadcCam.h" #include "MRawEvtData.h" #include "MRawEvtPixelIter.h" ClassImp(MHFadcCam); // -------------------------------------------------------------------------- // // default constructor // creates an a list of histograms for all pixels and both gain channels // MHFadcCam::MHFadcCam(const char *name, const char *title) { // // set the name and title of this object // fName = name ? name : "MHFadcCam"; fTitle = title ? title : "Container for ADC spectra histograms"; // // loop over all Pixels and create two histograms // one for the Low and one for the High gain // connect all the histogram with the container fHist // fArray = new TObjArray(577); for (Int_t i=0; i<577; i++) (*fArray)[i] = new MHFadcPix(i+1); } // -------------------------------------------------------------------------- MHFadcCam::~MHFadcCam() { delete fArray; } // -------------------------------------------------------------------------- // // Our own clone function is necessary since root 3.01/06 or Mars 0.4 // I don't know the reason // TObject *MHFadcCam::Clone(const char *) const { MHFadcCam *cam = new MHFadcCam; for (int i=0; i<577; i++) { delete (*cam->fArray)[i]; (*cam->fArray)[i] = (MHFadcPix*)(*fArray)[i]->Clone(); } return cam; } // -------------------------------------------------------------------------- Bool_t MHFadcCam::Fill(const MParContainer *par) { MRawEvtData *evt = (MRawEvtData*)par; MRawEvtPixelIter pixel(evt); const Int_t nhisamples = evt->GetNumHiGainSamples(); const Int_t nlosamples = evt->GetNumLoGainSamples(); while (pixel.Next()) { const UInt_t id = pixel.GetPixelId(); for (Int_t i=0; i