Changeset 3317


Ignore:
Timestamp:
02/26/04 04:21:51 (21 years ago)
Author:
gaug
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/Changelog

    r3314 r3317  
    66 
    77 2004/02/25: Markus Gaug
     8
     9  * mcalib/MHCalibrationRelTimeCam.cc
     10    - is now filled from MArrivalTimeCam instead of MArrivalTime
     11
     12  * macros/calibration.C
     13    - divided into two macros: calibration.C using the MJPedestal
     14      standard procedure and   pedestalstudies.C using the old procedures
     15   
     16  * macros/pedestalstudies.C
     17    - new macro containing the first previous part of calibration.C
     18
    819
    920   * mcalib/MCalibrationChargeBlindPix.h
  • trunk/MagicSoft/Mars/macros/calibration.C

    r3310 r3317  
    2222!
    2323\* ======================================================================== */
    24 
    25 //const TString pedfile = "/remote/home/pc2/operator/Crab20040214/20040215_16743_P_CrabOn_E.root";
    26 //const TString calfile = "/remote/home/pc2/operator/Crab20040214/20040215_16744_C_CrabOn_E.root";
    27 const TString pedfile = "../20040215_16770_P_OffCrab4_E.root";
    28 const TString calfile = "../20040215_16771_C_OffCrab4_E.root";
    29 
    30 //const TString pedfile = "/mnt/users/mdoro/Mars/Data/20040201_14418_P_OffMrk421-1_E.root";
    31 //const TString calfile = "/mnt/users/mdoro/Mars/Data/20040201_1441*_C_OffMrk421-1_E.root";
    32 
    33 //const TString pedfile = "/mnt/Data/rootdata/CrabNebula/2004_02_10/20040210_14607_P_CrabNebula_E.root";
    34 //const TString calfile = "/mnt/Data/rootdata/CrabNebula/2004_02_10/20040210_14608_C_CrabNebula_E.root";
    35 
    36 //const TString pedfile = "/mnt/Data/rootdata/CrabNebula/2004_01_26/20040125_10412_P_Crab-On_E.root";
    37 //const TString calfile = "/mnt/Data/rootdata/CrabNebula/2004_01_26/20040125_1041*_C_Crab-On_E.root";
    38 
    39 //const TString pedfile = "/mnt/Data/rootdata/Miscellaneous/2003_12_19/20031218_03522_P_Park_E.root";
    40 //const TString calfile = "/mnt/Data/rootdata/Miscellaneous/2003_12_19/20031218_03527_C_Park_E.root";
    41 
    42 void calibration(TString pedname=pedfile,
    43                  TString calname=calfile)
     24#include "MAGIC.h"
     25
     26
     27void calibration()
    4428{
     29
     30    const char *inpath = "/remote/home/pc2/operator/Crab20040214/";
     31    //const TString inpath = "/mnt/Data/rootdata/CrabNebula/2004_02_10/";
     32    //const TString inpath = "/mnt/Data/rootdata/CrabNebula/2004_01_26/";
     33    //const TString inpath = "/mnt/Data/rootdata/Miscellaneous/2003_12_19/";
     34
     35    MRunIter pruns;
     36    MRunIter cruns;
     37
     38    pruns.AddRuns(15487,15494,inpath);
     39    cruns.AddRuns(15495,15508,inpath);
    4540
    4641    gStyle->SetOptStat(1111);
     
    5146    display->Resize(850,700);
    5247
    53     //
    54     // Create a empty Parameter List and an empty Task List
    55     // The tasklist is identified in the eventloop by its name
     48    MJPedestal pedloop;
     49    pedloop.SetInput(&pruns);
     50    pedloop.SetDisplay(display);
     51
     52    if (!pedloop.Process())
     53        return;
     54
     55    //
     56    // Create a empty Parameter List and an empty Task List
    5657    //
    5758    MParList  plist;
    58 
    5959    MTaskList tlist;
    6060    plist.AddToList(&tlist);
    61 
    62     //
    63     // Now setup the tasks and tasklist for the pedestals:
    64     // ---------------------------------------------------
    65     //
    66 
    67     MReadMarsFile read("Events", pedname);
     61    plist.AddToList(&pedloop.GetPedestalCam());
     62
     63    gLog << endl;;
     64    gLog << "Calculate MCalibrationCam from Runs " << cruns.GetRunsAsString() << endl;
     65    gLog << endl;
     66
     67    MReadMarsFile read("Events");
    6868    read.DisableAutoScheme();
    69 
    70     MGeomApply      geomapl;
    71     MExtractSignal  sigcalc;
    72 
    73     //
    74     // Set the extraction range higher:
    75     //         
    76     //sigcalc.SetRange(1,14,1,14);
    77 
    78     MPedCalcPedRun pedcalc;
    79 
    80     //
    81     // Additionally to calculating the pedestals,
    82     // you can fill histograms and look at them
    83     //
    84     MFillH fill("MHPedestalCam", "MExtractedSignalCam");
    85 
    86     tlist.AddToList(&read);
    87     tlist.AddToList(&geomapl);
    88     tlist.AddToList(&sigcalc);
    89     tlist.AddToList(&pedcalc);
    90     tlist.AddToList(&fill);
    91 
    92     MGeomCamMagic  geomcam;
    93     MPedestalCam   pedcam;
    94     MHPedestalCam  hpedcam;
    95     plist.AddToList(&geomcam);
    96     plist.AddToList(&pedcam);
    97     plist.AddToList(&hpedcam);
    98 
    99     //
    100     // Create and setup the eventloop
    101     //
    102     MEvtLoop evtloop;
    103     evtloop.SetParList(&plist);
    104     evtloop.SetDisplay(display);
    105  
    106     //
    107     // Execute first analysis
    108     //
    109     if (!evtloop.Eventloop())
    110         return;
    111 
    112     tlist.PrintStatistics();
    113 
    114     //
    115     // Look at one specific pixel, after all the histogram manipulations:
    116     //
    117 //    hpedcam[9].DrawClone("fourierevents");
    118 
    119 
    120     MHCamera dispped0  (geomcam, "Ped;Pedestal",               "Mean per Slice");
    121     MHCamera dispped1  (geomcam, "Ped;PedestalErr",            "Mean Error per Slice");
    122     MHCamera dispped2  (geomcam, "Ped;PedestalRms",            "RMS per Slice");
    123     MHCamera dispped3  (geomcam, "Ped;PedestalRmsErr",         "RMS Error per Slice");
    124 
    125     MHCamera dispped4  (geomcam, "Ped;Mean",                   "Fitted Mean per Slice");
    126     MHCamera dispped5  (geomcam, "Ped;MeanErr",                "Fitted Error of Mean per Slice");
    127     MHCamera dispped6  (geomcam, "Ped;Sigma",                  "Fitted Sigma per Slice");
    128     MHCamera dispped7  (geomcam, "Ped;SigmaErr",               "Fitted Error of Sigma per Slice");
    129     MHCamera dispped8  (geomcam, "Ped;Prob",                   "Probability of Fit");
    130     MHCamera dispped9  (geomcam, "Ped;DeltaPedestalMean",      "Rel. Diff. Mean per Slice (Calc.-Fitte)");
    131     MHCamera dispped10 (geomcam, "Ped;DeltaPedestalMeanError", "Rel. Diff. Mean Error per Slice (Calc.-Fitted)");
    132     MHCamera dispped11  (geomcam, "Ped;DeltaRmsSigma",         "Rel. Diff. RMS per Slice (Calc.-Fitted)");
    133     MHCamera dispped12  (geomcam, "Ped;DeltaRmsSigmaError",    "Rel. Diff. RMS Error per Slice (Calc.-Fitted)");
    134     MHCamera dispped13  (geomcam, "Ped;FitOK",                 "Gaus Fit not OK");
    135     MHCamera dispped14  (geomcam, "Ped;FourierOK",             "Fourier Analysis not OK");
    136 
    137     dispped0.SetCamContent(  pedcam, 0);
    138     dispped0.SetCamError(    pedcam, 1);
    139     dispped1.SetCamContent(  pedcam, 1);
    140     dispped2.SetCamContent(  pedcam, 2);
    141     dispped2.SetCamError(    pedcam, 3);
    142     dispped3.SetCamContent(  pedcam, 3);
    143 
    144     dispped4.SetCamContent( hpedcam, 0);
    145     dispped4.SetCamError(   hpedcam, 1);
    146     dispped5.SetCamContent( hpedcam, 1);
    147     dispped6.SetCamContent( hpedcam, 2);
    148     dispped6.SetCamError(   hpedcam, 3);
    149     dispped7.SetCamContent( hpedcam, 3);
    150     dispped8.SetCamContent( hpedcam, 4);
    151     dispped9.SetCamContent( hpedcam, 5);
    152     dispped9.SetCamError(   hpedcam, 6);
    153     dispped10.SetCamContent(hpedcam, 7);
    154     dispped11.SetCamContent(hpedcam, 8);
    155     dispped11.SetCamError(  hpedcam, 9);
    156     dispped12.SetCamContent(hpedcam, 10);
    157     dispped13.SetCamContent(hpedcam, 11);
    158     dispped14.SetCamContent(hpedcam, 12);
    159 
    160     dispped0.SetYTitle("Calc. Pedestal per slice [FADC counts]");
    161     dispped1.SetYTitle("Calc. Pedestal Error per slice [FADC counts]");
    162     dispped2.SetYTitle("Calc. Pedestal RMS per slice [FADC counts]");
    163     dispped3.SetYTitle("Calc. Pedestal RMS Error per slice [FADC counts]");
    164     dispped4.SetYTitle("Fitted Mean per slice [FADC counts]");
    165     dispped5.SetYTitle("Error of Fitted Mean per slice [FADC counts]");
    166     dispped6.SetYTitle("Fitted Sigma per slice [FADC counts]");
    167     dispped7.SetYTitle("Error of Fitted Sigma per slice [FADC counts]");
    168     dispped8.SetYTitle("Fit Probability [1]");
    169     dispped9.SetYTitle("Rel. Diff. Pedestal Calc.-Fitted per slice [1]");
    170     dispped10.SetYTitle("Rel. Diff. Pedestal Error Calc.-Fitted per slice [1]");
    171     dispped11.SetYTitle("Rel. Diff. Pedestal RMS Calc.-Fitted per slice [1]");
    172     dispped12.SetYTitle("Rel. Diff. Pedestal RMS Error Calc.-Fitted per slice [1]");
    173     dispped13.SetYTitle("[1]");
    174     dispped14.SetYTitle("[1]");
    175    
    176     // Histogram values
    177     TCanvas &b1 = display->AddTab("Ped.Calc.");
    178     b1.Divide(4,3);
    179 
    180     CamDraw(b1,dispped0,pedcam,1,4,1);
    181     CamDraw(b1,dispped1,pedcam,2,4,2);
    182     CamDraw(b1,dispped2,pedcam,3,4,2);
    183     CamDraw(b1,dispped3,pedcam,4,4,2);
    184 
    185     // Fitted values
    186     TCanvas &b2 = display->AddTab("Ped.Fit");
    187     b2.Divide(4,3);
    188 
    189     CamDraw(b2,dispped4,hpedcam,1,4,1);
    190     CamDraw(b2,dispped5,hpedcam,2,4,2);
    191     CamDraw(b2,dispped6,hpedcam,3,4,2);
    192     CamDraw(b2,dispped7,hpedcam,4,4,2);
    193 
    194 
    195     // Fits Probability
    196     TCanvas &b3 = display->AddTab("Ped.Fit Prob.");
    197     b3.Divide(1,3);
    198 
    199     CamDraw(b3,dispped8,hpedcam,1,1,3);
    200 
    201     // Differences
    202     TCanvas &c4 = display->AddTab("Rel.Diff.Calc.-Fit");
    203     c4.Divide(4,3);
    204 
    205     CamDraw(c4,dispped9,hpedcam,1,4,1);
    206     CamDraw(c4,dispped10,hpedcam,2,4,1);
    207     CamDraw(c4,dispped11,hpedcam,3,4,1);
    208     CamDraw(c4,dispped12,hpedcam,4,4,1);
    209 
    210     // Defects
    211     TCanvas &c5 = display->AddTab("Defects");
    212     c5.Divide(2,2);
    213 
    214     CamDraw(c5,dispped13,hpedcam,1,2,0);
    215     CamDraw(c5,dispped14,hpedcam,2,2,0);
    216 
    217     //
    218     // Create a empty Parameter List and an empty Task List
    219     //
    220     MParList  plist2;
    221     MTaskList tlist2;
    222     plist2.AddToList(&tlist2);
    223 
     69    static_cast<MRead&>(read).AddFiles(cruns);
     70
     71    MGeomCamMagic              geomcam;
    22472    MExtractedSignalCam        sigcam;
    22573    MCalibrationChargeCam      calcam;
     
    23583    // we have to set the color of the pulser LED by hand
    23684    //
    237     blindpix.SetColor(MCalibrationChargeBlindPix::kECT1);
    238     pindiode.SetColor(MCalibrationChargePINDiode::kECT1);
     85    blindpix.SetColor(kCT1);
     86    pindiode.SetColor(kCT1);
    23987    //
    24088    // Get the previously created MPedestalCam into the new Parameter List
    24189    //
    242     plist2.AddToList(&geomcam);
    243     plist2.AddToList(&pedcam);
    244     plist2.AddToList(&sigcam);
    245     plist2.AddToList(&calcam);
    246     plist2.AddToList(&histtime);
    247     plist2.AddToList(&histcharge);
    248     plist2.AddToList(&histpin);
    249     plist2.AddToList(&histblind);
    250     //
    251     // Get the MAGIC geometry
    252     //
    253     tlist2.AddToList(&geomapl);
    254     //
    255     // Now setup the new tasks and tasklist for the calibration
    256     // ---------------------------------------------------
    257     //
    258 
    259     MReadMarsFile read2("Events", calname);
    260     read2.DisableAutoScheme();
     90    plist.AddToList(&geomcam);
     91    plist.AddToList(&sigcam);
     92    plist.AddToList(&calcam);
     93    plist.AddToList(&histtime);
     94    plist.AddToList(&histcharge);
     95    plist.AddToList(&histpin);
     96    plist.AddToList(&histblind);
    26197
    26298    //
     
    264100    // thus take the sliding window
    265101    //         
     102    MExtractSignal2        sigcalc2;
    266103    MExtractPINDiode       pincalc;
    267104    MExtractBlindPixel     blindcalc;
    268     MExtractSignal2        sigcalc2;
    269105    MArrivalTimeCalc2      timecalc;
    270106    MCalibrationChargeCalc calcalc;
    271 
    272     MFillH filltime ("MHCalibrationRelTimeCam"    , "MArrivalTime");
     107    MGeomApply             geomapl;
     108   
     109    MFillH filltime("MHCalibrationRelTimeCam", "MArrivalTime");
    273110    MFillH fillpin  ("MHCalibrationChargePINDiode", "MExtractedSignalPINDiode");
    274111    MFillH fillblind("MHCalibrationChargeBlindPix", "MExtractedSignalBlindPixel");
     
    276113
    277114    //
    278     // Set the range (other than default)
    279     // of FADC slices for the blind pixel
    280     //
    281     // calcalc.SetBlindPixelRange(10,25);
    282 
    283     //
    284     // Set the cut upon which a superposition of the blind pixel
    285     // FADC slices will be filled into the SinglePHE histogram
    286     //
    287     //    calcalc.SetBlindPixelSinglePheCut(500);
    288 
    289     //
    290115    // Skip the HiGain vs. LoGain calibration
    291116    //
    292117    calcalc.SkipHiLoGainCalibration();
    293118
    294     //
    295     // As long, as we don't have digital modules,
    296     // we have to set the color of the pulser LED by hand
    297     //
    298 //    calcalc.SetPulserColor(MCalibrationCalc::kECT1);
    299 
    300     //
    301     // In case, we want to exclude a pre-defined list of bad pixels:
    302     // (This is a preliminary feature)
    303     //
    304     // calcalc.ExcludePixelsFromAsciiFile("badpixels.dat");
    305    
    306     //
    307     // In case, we want to apply another fit function to the
    308     // blind pixel
    309     //
    310     //    MCalibrationBlindPix *bp = calcam.GetBlindPixel();
    311     //    bp->ChangeFitFunc(MHCalibrationBlindPixel::kEPoisson5);
    312 
    313119    //
    314120    // Apply a filter against cosmics
     
    318124    MContinue            cont(&cosmics);
    319125
    320     tlist2.AddToList(&read2);
    321     tlist2.AddToList(&blindcalc);
    322     tlist2.AddToList(&pincalc);
    323     tlist2.AddToList(&sigcalc2);
     126    tlist.AddToList(&read);
     127    tlist.AddToList(&geomapl);
     128    tlist.AddToList(&sigcalc2);
     129    tlist.AddToList(&blindcalc);
     130    tlist.AddToList(&pincalc);
    324131    //
    325132    // In case, you want to skip the cosmics rejection,
    326133    // uncomment the next line
    327134    //
    328     tlist2.AddToList(&cont);
     135    tlist.AddToList(&cont);
    329136    //
    330137    // In case, you want to skip the somewhat lengthy calculation
    331138    // of the arrival times using a spline, uncomment the next two lines
    332139    //
    333     tlist2.AddToList(&timecalc);
    334     tlist2.AddToList(&filltime);
    335     tlist2.AddToList(&fillpin);
    336     tlist2.AddToList(&fillblind);
    337     tlist2.AddToList(&fillcam);
    338     //
    339     tlist2.AddToList(&calcalc);
     140    tlist.AddToList(&timecalc);
     141    tlist.AddToList(&filltime);
     142    tlist.AddToList(&fillpin);
     143    tlist.AddToList(&fillblind);
     144    tlist.AddToList(&fillcam);
     145    //
     146    tlist.AddToList(&calcalc);
    340147    //
    341148    // Create and setup the eventloop
    342149    //
    343150    MEvtLoop evtloop2;
    344     evtloop2.SetParList(&plist2);
     151    evtloop2.SetParList(&plist);
    345152    evtloop2.SetDisplay(display);
    346153   
     
    351158        return;
    352159
    353     tlist2.PrintStatistics();
     160    tlist.PrintStatistics();
    354161
    355162    //
     
    361168    calcam.Print();
    362169    calcam.SetLogStream(&gLog);
    363 
    364170    //
    365171    // just one example how to get the plots of individual pixels
    366172    //
    367 //    histblind.DrawClone("all");
    368 //    histcharge[5].DrawClone("time");
     173    histblind.DrawClone("all");
     174    histcharge[5].DrawClone("time");
    369175
    370176    // Create histograms to display
     
    646452      TH1D *obj2 = (TH1D*)obj1->Projection();
    647453     
    648       obj2->Sumw2();
     454//      obj2->Sumw2();
    649455      obj2->Draw();
    650456      obj2->SetBit(kCanDelete);
  • trunk/MagicSoft/Mars/mcalib/MHCalibrationRelTimeCam.cc

    r3181 r3317  
    3939#include "MHCalibrationRelTimePix.h"
    4040
    41 #include "MArrivalTime.h"
     41#include "MArrivalTimeCam.h"
     42#include "MArrivalTimePix.h"
    4243
    4344ClassImp(MHCalibrationRelTimeCam);
     
    147148{
    148149
    149   MArrivalTime *arrtime = (MArrivalTime*)par;
     150  MArrivalTimeCam *arrtime = (MArrivalTimeCam*)par;
    150151  if (!arrtime)
    151152    {
     
    175176    }
    176177 
     178  const MArrivalTimePix &refpix = (*arrtime)[1];
     179  const Float_t reftime = refpix.IsLoGainUsed() ? refpix.GetArrivalTimeLoGain() : refpix.GetArrivalTimeHiGain();
     180
    177181  for (Int_t i=0; i<n; i++)
    178182    {
    179 
    180       const Float_t reltime = (*arrtime)[i] - (*arrtime)[1];
    181 
    182       MHCalibrationRelTimePix  &hist = (*this)[i];
    183       hist.FillHistAndArray(reltime);
     183        const MArrivalTimePix &pix = (*arrtime)[i];
     184        const Float_t time = pix.IsLoGainUsed() ? pix.GetArrivalTimeLoGain() : pix.GetArrivalTimeHiGain(); 
     185
     186        MHCalibrationRelTimePix  &hist = (*this)[i];
     187        hist.FillHistAndArray(time - reftime);
    184188    }
    185189 
Note: See TracChangeset for help on using the changeset viewer.