Changeset 2886 for trunk/MagicSoft
- Timestamp:
- 01/22/04 20:54:16 (21 years ago)
- Location:
- trunk/MagicSoft/Mars
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MagicSoft/Mars/Changelog
r2885 r2886 4 4 5 5 -*-*- END OF LINE -*-*- 6 7 2004/01/22: Abelardo Moralejo 8 9 * manalysis/MMcCalibrationUpdate.[h,cc] 10 - Now ratio of high to low gain is taken from MCalibrationCam if 11 it existed previously in the parameter list, instead of being 12 read again from the MMcFadcHeader. Removed Setter function for 13 fADC2PhInner, no longer necessary. Fixed error regarding the 14 pedestal conversion to photons (did not read conversion factor 15 from preexisting MCalibrationCam object). 16 17 * mcalib/MMcCalibrationCalc.cc 18 - Changed parameters of the histogram, and also the quantity being 19 histogrammed. Check that input data come from a noiseless camera 20 file before proceeding to do the calibration. Introduced lower 21 size in cut for calibration. Now rhe calibration constant is not 22 calculated from the mean of photons/ADC counts, but from the peak 23 of the histogram. 24 25 * macros/starmc.C 26 - Introduced new scheme. Now there are two loops over two different 27 sets of files. First loop calculates the calibration constants, 28 second one does the analysis. Introduced comments. Now the 29 histogram used in the light calibration is written to the output 30 file. 31 6 32 2004/01/22: Thomas Bretz 7 33 -
trunk/MagicSoft/Mars/macros/starmc.C
r2874 r2886 1 1 /* ======================================================================== *\ 2 !3 ! *4 ! * This file is part of MARS, the MAGIC Analysis and Reconstruction5 ! * Software. It is distributed to you in the hope that it can be a useful6 ! * 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 its10 ! * documentation for any purpose is hereby granted without fee,11 ! * provided that the above copyright notice appear in all copies and12 ! * that both that copyright notice and this permission notice appear13 ! * in supporting documentation. It is provided "as is" without express14 ! * or implied warranty.15 ! *16 !17 !18 ! Author(s): Abelardo Moralejo 1/2004 <mailto:moralejo@pd.infn.it>19 ! Thomas Bretz 5/2002 <mailto:tbretz@astro.uni-wuerzburg.de>20 !21 ! Copyright: MAGIC Software Development, 2000-200422 !23 !24 \* ======================================================================== */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): Abelardo Moralejo 1/2004 <mailto:moralejo@pd.infn.it> 19 ! Thomas Bretz 5/2002 <mailto:tbretz@astro.uni-wuerzburg.de> 20 ! 21 ! Copyright: MAGIC Software Development, 2000-2004 22 ! 23 ! 24 \* ======================================================================== */ 25 25 26 26 ///////////////////////////////////////////////////////////////////////////// … … 37 37 void starmc() 38 38 { 39 // 40 // This is a demonstration program which calculates the image 41 // parameters from Magic Monte Carlo files (output of camera). 42 43 // 44 // Create a empty Parameter List and an empty Task List 45 // The tasklist is identified in the eventloop by its name 46 // 47 MParList plist; 48 49 MTaskList tlist; 50 51 plist.AddToList(&tlist); 52 53 MSrcPosCam src; 54 src.SetReadyToSave(); 55 56 plist.AddToList(&src); 57 58 // 59 // Now setup the tasks and tasklist: 60 // --------------------------------- 61 // 62 MReadMarsFile read("Events"); 63 64 // ------------- user change ----------------- 65 66 read.AddFile("Gamma_zbin*.root"); 67 68 read.DisableAutoScheme(); 69 70 MGeomApply geom; // Reads in geometry from MC file and sets the right sizes for 71 // several parameter containers. 72 73 MMcPedestalCopy pcopy; 74 // Copies pedestal data from the MC file run fadc header to the MPedestalCam container. 75 76 MExtractSignal sigextract; 77 // Define ADC slices to be integrated in high and low gain: 78 sigextract.SetRange(0, 5, 0, 5); 79 80 MMcCalibrationUpdate mccalibupdate; 81 82 // 83 // Now introduce conversion factor from ADC counts to photons before camera for 84 // inner pixels. The corresponding value for outer pixels is then calculated 85 // automatically. Bear in mind that the conversion factor depend both on the 86 // parameters used in the camera simulation as well as on the number of 87 // integrated FADC slices. In the future it should be calculated in a previous 88 // event loop, either from the same MC file or from a MC calibration file 89 // written on purpose. 90 // (FIXME: the conversion must be calculated automatically from the analyzed file) 91 // 92 mccalibupdate.SetADC2PhInner(1.2586); 39 // 40 // This is a demonstration program which calculates the image 41 // parameters from Magic Monte Carlo files (output of camera). 93 42 94 43 95 MCalibrate calib; // Transforms signals from ADC counts into photons.44 // ------------- user change ----------------- 96 45 97 // MBlindPixelCalc blind; 98 // blind.SetUseInterpolation(); 46 TString* CalibrationFilename; 99 47 100 MImgCleanStd clean(4.1,3.4); // Applies tail cuts to image. 48 // 49 // Comment out next line to disable calibration. In that case the units of the 50 // MHillas.fSize parameter will be ADC counts (rather, equivalent ADC counts in 51 // inner pixels, since we correct for the possible differences in gain of outer 52 // pixels) 53 // 54 CalibrationFilename = new TString("../../../nonoise/gammas/Gamma_zbin0_0*.root"); 55 // File to be used in the calibration (must be a camera file without added noise) 56 57 Char_t* AnalysisFilename = "Proton_zbin*.root"; // File to be analyzed 58 Char_t* OutFilename = "star_mc.root"; // Output file name 59 60 Float_t CleanLev[2] = {4., 3.}; // Tail cuts for image analysis 61 62 Int_t BinsHigh[2] = {0, 5}; // First and last FADC bin of the range to be integrated, 63 Int_t BinsLow[2] = {0, 5}; // for high and low gain respectively. 64 65 // ------------------------------------------- 66 67 // 68 // Create a empty Parameter List and an empty Task List 69 // The tasklist is identified in the eventloop by its name 70 // 71 MParList plist; 72 73 MTaskList tlist; 74 75 plist.AddToList(&tlist); 76 77 MSrcPosCam src; 78 src.SetReadyToSave(); 79 80 plist.AddToList(&src); 81 82 // 83 // Now setup the tasks and tasklist: 84 // --------------------------------- 85 // 86 MReadMarsFile read("Events"); 87 88 if (CalibrationFilename) 89 read.AddFile(CalibrationFilename->Data()); 90 91 read.DisableAutoScheme(); 92 93 MGeomApply geom; // Reads in geometry from MC file and sets the right sizes for 94 // several parameter containers. 95 96 MMcPedestalCopy pcopy; 97 // Copies pedestal data from the MC file run fadc header to the MPedestalCam container. 98 99 MExtractSignal sigextract; 100 // Define ADC slices to be integrated in high and low gain: 101 sigextract.SetRange(BinsHigh[0], BinsHigh[1], BinsLow[0], BinsLow[1]); 102 103 MMcCalibrationUpdate mccalibupdate; 104 105 MCalibrate calib; // Transforms signals from ADC counts into photons. 106 107 // MBlindPixelCalc blind; 108 // blind.SetUseInterpolation(); 109 110 MImgCleanStd clean(CleanLev[0], CleanLev[1]); // Applies tail cuts to image. 111 112 MHillasCalc hcalc; // Calculates Hillas parameters not dependent on source position. 113 MHillasSrcCalc scalc; // Calculates source-dependent Hillas parameters 114 115 MMcCalibrationCalc mccalibcalc; 116 117 tlist.AddToList(&read); 118 tlist.AddToList(&geom); 119 tlist.AddToList(&pcopy); 120 121 tlist.AddToList(&sigextract); 122 tlist.AddToList(&mccalibupdate); 123 tlist.AddToList(&calib); 124 tlist.AddToList(&clean); 125 // tlist.AddToList(&blind); 126 tlist.AddToList(&hcalc); 127 128 tlist.AddToList(&mccalibcalc); 129 130 // 131 // Open output file: 132 // 133 MWriteRootFile write(OutFilename); // Writes output 134 write.AddContainer("MRawRunHeader", "RunHeaders"); 135 write.AddContainer("MMcRunHeader", "RunHeaders"); 136 write.AddContainer("MSrcPosCam", "RunHeaders"); 137 write.AddContainer("MMcEvt", "Events"); 138 write.AddContainer("MHillas", "Events"); 139 write.AddContainer("MHillasExt", "Events"); 140 write.AddContainer("MHillasSrc", "Events"); 141 write.AddContainer("MNewImagePar", "Events"); 142 143 // 144 // First loop: Calibration loop 145 // 146 147 MProgressBar bar; 148 bar.SetWindowName("Calibrating..."); 149 150 MEvtLoop evtloop; 151 evtloop.SetProgressBar(&bar); 152 evtloop.SetParList(&plist); 153 154 if (CalibrationFilename) 155 { 156 if (!evtloop.Eventloop()) 157 return; 158 mccalibcalc->GetHist()->Write(); 159 } 160 161 // 162 // Second loop: analysis loop 163 // 164 165 // 166 // Change the read task by another one which reads the file we want to analyze: 167 // 168 169 MReadMarsFile read2("Events"); 170 read2.AddFile(AnalysisFilename); 171 read2.DisableAutoScheme(); 172 tlist.AddToListBefore(&read2, &read, "All"); 173 tlist.RemoveFromList(&read); 174 175 bar.SetWindowName("Analyzing..."); 176 177 tlist.RemoveFromList(&mccalibcalc); // Removes calibration task from list. 178 179 tlist.AddToList(&scalc); // Calculates Source-dependent Hillas parameters 180 181 tlist.AddToList(&write); // Add task to write output. 182 183 if (!evtloop.Eventloop()) 184 return; 101 185 102 186 103 MHillasCalc hcalc; // Calculates Hillas parameters not dependent on source position. 104 MHillasSrcCalc scalc; // Calculates source-dependent Hillas parameters 105 // (!!Preliminary!! Will be removed later!) 106 107 108 // ------------- user change ----------------- 109 110 MWriteRootFile write("star_mc.root"); // Writes output 111 112 write.AddContainer("MRawRunHeader", "RunHeaders"); 113 write.AddContainer("MMcRunHeader", "RunHeaders"); 114 write.AddContainer("MSrcPosCam", "RunHeaders"); 115 write.AddContainer("MMcEvt", "Events"); 116 write.AddContainer("MHillas", "Events"); 117 write.AddContainer("MHillasExt", "Events"); 118 write.AddContainer("MHillasSrc", "Events"); 119 write.AddContainer("MNewImagePar", "Events"); 120 121 122 tlist.AddToList(&read); 123 tlist.AddToList(&geom); 124 tlist.AddToList(&pcopy); 125 126 tlist.AddToList(&sigextract); 127 tlist.AddToList(&mccalibupdate); 128 tlist.AddToList(&calib); 129 tlist.AddToList(&clean); 130 // tlist.AddToList(&blind); 131 tlist.AddToList(&hcalc); 132 tlist.AddToList(&scalc); 133 tlist.AddToList(&write); 134 135 // 136 // Create and set up the eventloop 137 // 138 MProgressBar bar; 139 140 MEvtLoop evtloop; 141 evtloop.SetProgressBar(&bar); 142 evtloop.SetParList(&plist); 143 144 // 145 // Execute your analysis 146 // 147 if (!evtloop.Eventloop()) 148 return; 149 150 tlist.PrintStatistics(); 187 tlist.PrintStatistics(); 151 188 } -
trunk/MagicSoft/Mars/manalysis/MMcCalibrationUpdate.cc
r2876 r2886 37 37 // MMcFadcHeader 38 38 // MRawRunHeader 39 // [MCalibrationCam] (if it existed previously) 39 40 // 40 41 // Output Containers: 41 // MCalibrationCam42 42 // MPedPhotCam 43 // [MCalibrationCam] (if it did not exist previously) 43 44 // 44 45 ///////////////////////////////////////////////////////////////////////////// … … 95 96 } 96 97 97 98 //---------------------------------------------------------------------------99 //100 // Set ADC to photon conversion factors.101 //102 void MMcCalibrationUpdate::SetADC2PhInner(Float_t x)103 {104 fADC2PhInner = x;105 106 return;107 }108 109 98 // -------------------------------------------------------------------------- 110 99 // … … 123 112 if ( !fCalCam ) 124 113 { 125 *fLog << warn<< dbginf << AddSerialNumber("MCalibrationCam") << " does not exist... Creating." << endl;114 *fLog << inf << dbginf << AddSerialNumber("MCalibrationCam") << " does not exist... Creating." << endl; 126 115 127 116 fCalCam = (MCalibrationCam*) pList->FindCreateObj(AddSerialNumber("MCalibrationCam")); … … 135 124 { 136 125 fFillCalibrationCam = kFALSE; 137 *fLog << warn << dbginf << AddSerialNumber("MCalibrationCam") << " already exists... " << endl;126 *fLog << inf << AddSerialNumber("MCalibrationCam") << " already exists... " << endl; 138 127 } 139 128 … … 189 178 190 179 // 191 // Set the ADC to photons conversion factor for outer pixels:192 //193 fADC2PhOuter = fADC2PhInner *194 (fHeaderFadc->GetAmplitud() / fHeaderFadc->GetAmplitudOuter());195 196 //197 // Set the conversion factor between high and low gain:198 //199 fConversionHiLo = fHeaderFadc->GetLow2HighGain();200 201 //202 180 // If MCalibrationCam already existed in the parameter list before 203 181 // MMcCalibrationUpdate::PreProcess was executed (from a … … 208 186 return kTRUE; 209 187 188 // 189 // Set the ADC to photons conversion factor for outer pixels: 190 // 191 fADC2PhOuter = fADC2PhInner * 192 (fHeaderFadc->GetAmplitud() / fHeaderFadc->GetAmplitudOuter()); 193 194 // 195 // Set the conversion factor between high and low gain: 196 // 197 fConversionHiLo = fHeaderFadc->GetLow2HighGain(); 210 198 211 199 const int num = fCalCam->GetSize(); … … 264 252 // counts for the RMS per slice: 265 253 // 266 267 254 268 255 const Float_t pedestrms = sigpix.IsLoGainUsed()? … … 279 266 MPedPhotPix &pedpix = (*fPedPhotCam)[i]; 280 267 281 Float_t adc2phot = (fGeom->GetPixRatio(i) < fGeom->GetPixRatio(0))? 282 fADC2PhOuter : fADC2PhInner; 268 MCalibrationPix &calpix = (*fCalCam)[i]; 269 Float_t adc2phot = calpix.GetMeanConversionBlindPixelMethod(); 270 Float_t hi2lo = calpix.GetConversionHiLo(); 283 271 284 272 if (sigpix.IsLoGainUsed()) 285 pedpix.Set(adc2phot* fConversionHiLo*pedestmean,286 adc2phot* fConversionHiLo*pedestrms);273 pedpix.Set(adc2phot*hi2lo*pedestmean, 274 adc2phot*hi2lo*pedestrms); 287 275 else 288 276 pedpix.Set(adc2phot*pedestmean, adc2phot*pedestrms); -
trunk/MagicSoft/Mars/manalysis/MMcCalibrationUpdate.h
r2876 r2886 35 35 MMcCalibrationUpdate(const char *name=NULL, const char *title=NULL); 36 36 37 void SetADC2PhInner(Float_t x);38 39 37 ClassDef(MMcCalibrationUpdate, 0) // Task which obtains, for MC files, the pedestal mean and rms, and the calibration factor from ADC counts to photons. 40 38 }; -
trunk/MagicSoft/Mars/mcalib/MMcCalibrationCalc.cc
r2885 r2886 71 71 fEvents = 0; 72 72 73 fHistRatio = new TH1F("HistRatio", "Ratio fPassPhotCone/fSize", 1000., 0., 10.); 73 fHistRatio = new TH1F("HistRatio", "log10(fPassPhotCone/fSize)", 1500., -3., 3.); 74 fHistRatio->GetXaxis()->SetTitle("log_{10}(fPassPhotCone / fSize) (in photons/ADC count)"); 74 75 } 75 76 … … 165 166 } 166 167 168 for (UInt_t ipix = 0; ipix < fGeom->GetNumPixels(); ipix++) 169 { 170 if (fHeaderFadc->GetPedestalRmsHigh(ipix) > 0 || 171 fHeaderFadc->GetPedestalRmsLow(ipix) > 0 ) 172 { 173 *fLog << err << endl << endl << dbginf << "You are trying to calibrate the data using a Camera file produced with added noise. Please use a noiseless file for calibration. Aborting..." << endl << endl; 174 return kFALSE; 175 } 176 } 177 167 178 // 168 179 // FIXME: Check that the relevant parameters in the FADC header are the 169 // same for all the analyzed data !180 // same for all the analyzed data, both Calibration and Analyzed data! 170 181 // 171 182 … … 181 192 { 182 193 194 // 195 // Exclude events with some saturated pixel 196 // 183 197 if ( fNew->GetNumSaturatedPixels() > 0 ) 184 198 return kTRUE; 185 199 200 // 201 // Exclude events with low Size (larger fluctuations) 202 // FIXME? The present cut (1000 "inner-pixel-counts") is somehow arbitrary. 203 // Might it be optimized? 204 // 205 if ( fHillas->GetSize() < 1000 ) 206 return kTRUE; 207 186 208 fADC2Phot += fMcEvt->GetPassPhotCone() / fHillas->GetSize(); 187 209 fEvents ++; 188 210 189 fHistRatio->Fill( fMcEvt->GetPassPhotCone()/fHillas->GetSize());211 fHistRatio->Fill(log10(fMcEvt->GetPassPhotCone()/fHillas->GetSize())); 190 212 191 213 return kTRUE; … … 207 229 } 208 230 231 // 232 // For the calibration we no longer use the mean, but thepeak of the distribution: 233 // 234 235 Float_t summax = 0.; 236 Int_t mode = 0; 237 Int_t reach = 2; 238 for (Int_t ibin = 1+reach; ibin <= fHistRatio->GetNbinsX()-reach; ibin++) 239 { 240 Float_t sum = 0; 241 for(Int_t k = ibin-reach; k <= ibin+reach; k++) 242 sum += fHistRatio->GetBinContent(k); 243 if (sum > summax) 244 { 245 summax = sum; 246 mode = ibin; 247 } 248 } 249 250 fADC2Phot = pow(10., fHistRatio->GetXaxis()->GetBinCenter(mode)); 251 209 252 const int num = fCalCam->GetSize(); 210 253 -
trunk/MagicSoft/Mars/mcalib/MMcCalibrationCalc.h
r2885 r2886 28 28 Long_t fEvents; 29 29 30 TH1F* fHistRatio; 30 TH1F* fHistRatio; // Histogram for monitoring the calibration. 31 31 32 32 Bool_t CheckRunType(MParList *pList) const; … … 39 39 MMcCalibrationCalc(const char *name=NULL, const char *title=NULL); 40 40 41 TH1F* GetHist() { return fHistRatio; } 42 41 43 ClassDef(MMcCalibrationCalc, 0) // Task which obtains, for MC files, the calibration factor from ADC counts to photons. 42 44 };
Note:
See TracChangeset
for help on using the changeset viewer.