Changeset 2422


Ignore:
Timestamp:
10/23/03 01:38:16 (21 years ago)
Author:
tbretz
Message:
*** empty log message ***
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/mimage/MImgCleanTGB.cc

    r2377 r2422  
    2929//  MImgCleanTGB
    3030//
    31 // The Image Cleaning task selects the pixels you use for the Hillas
    32 // parameters calculation.
    33 //
    34 // There are two methods to make the selection: the standard one, as done
    35 // in the analysis of CT1 data, and the democratic one, as suggested by
    36 // W.Wittek. The number of photo-electrons of a pixel is compared with the
    37 // pedestal RMS of the pixel itself (standard method) or with the average
    38 // RMS of the inner pixels (democratic method).
    39 // In both cases, the possibility to have a camera with pixels of
    40 // different area is taken into account.
    41 // The too noisy pixels can be recognized and eventally switched off
    42 // (Unmap: set blind pixels to UNUSED) separately, using the
    43 // MBlindPixelCalc Class. In the MBlindPixelCalc class there is also the
    44 // function to replace the value of the noisy pixels with the interpolation
    45 // of the content of the neighbors (SetUseInterpolation).
    46 //
    47 // Example:
    48 // ...
    49 // MBlindPixelCalc blind;
    50 // blind.SetUseInterpolation();
    51 // blind.SetUseBlindPixels();
    52 //
    53 // MImgCleanTGB clean;
    54 // ...
    55 // tlist.AddToList(&blind);
    56 // tlist.AddToList(&clean);
    57 //
    58 // Look at the MBlindPixelCalc Class for more details.
    59 //
    60 // Starting point: default values ----------------------------------------
    61 //
    62 // When an event is read, before the image cleaning, all the pixels that
    63 // are in MCerPhotEvt are set as USED and NOT CORE. All the pixels belong
    64 // to RING number 1 (like USED pixels).
    65 // Look at MCerPhotPix.h to see how these informations of the pixel are
    66 // stored.
    67 // The default  cleaning METHOD is the STANDARD one and the number of the
    68 // rings around the CORE pixel it analyzes is 1. Look at the Constructor
    69 // of the class in MImgCleanTGB.cc to see (or change) the default values.
    70 //
    71 // Example: To modify this setting, use the member functions
    72 // SetMethod(MImgCleanTGB::kDemocratic) and SetCleanRings(UShort_t n).
    73 //
    74 // MImgCleanTGB:CleanStep1 -----------------------------------------------
    75 //
    76 // The first step of cleaning defines the CORE pixels. The CORE pixels are
    77 // the ones which contain the informations about the core of the electro-
    78 // magnetic shower.
    79 // The ratio  (A_0/A_i) is calculated from fCam->GetPixRatio(i). A_0 is
    80 // the area of the central pixel of the camera, A_i is the area of the
    81 // examined pixel. In this way, if we have a MAGIC-like camera, with the
    82 // outer pixels bigger than the inner ones, the level of cleaning in the
    83 // two different regions is weighted.
    84 // This avoids problems of deformations of the shower images.
    85 // The signal S_i and the pedestal RMS Prms_i of the pixel are called from
    86 // the object MCerPhotPix.
    87 // If (default method = kStandard)
    88 //Begin_Html
    89 //&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<img src="images/MImgCleanTGB-f1.png">
    90 //End_Html
    91 // the pixel is set as CORE pixel. L_1 (n=1) is called "first level of
    92 // cleaning" (default: fCleanLvl1 = 3).
    93 // All the other pixels are set as UNUSED and belong to RING 0.
    94 // After this point, only the CORE pixels are set as USED, with RING
    95 // number 1.
    96 //
    97 // MImgCleanTGB:CleanStep2 ----------------------------------------------
    98 //
    99 // The second step of cleaning looks at the isolated CORE pixels and sets
    100 // them to UNUSED. An isolated pixel is a pixel without CORE neighbors.
    101 // At the end of this point, we have set as USED only CORE pixels with at
    102 // least one CORE neighbor.
    103 //
    104 // MImgCleanTGB:CleanStep3  ----------------------------------------------
    105 //
    106 // The third step of cleaning looks at all the pixels (USED or UNUSED) that
    107 // surround the USED pixels.
    108 // If the content of the analyzed pixel survives at the second level of
    109 // cleaning, i.e. if
    110 //Begin_Html
    111 //&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<img src="images/MImgCleanTGB-f1.png">
    112 //End_Html
    113 // the pixel is set as USED. L_2 (n=2) is called "second level of cleaning"
    114 // (default:fCleanLvl2 = 2.5).
    115 //
    116 // When the number of RINGS to analyze is 1 (default value), only the
    117 // pixels that have a neighbor CORE pixel are analyzed.
    118 //
    119 // There is the option to decide the number of times you want to repeat
    120 // this procedure (number of RINGS analyzed around the core pixels = n).
    121 // Every time the level of cleaning is the same (fCleanLvl2) and the pixel
    122 // will belong to ring r+1, 1 < r < n+1. This is described in
    123 // MImgCleanTGB:CleanStep4 .
    124 //
    125 // Dictionary and member functions ---------------------------------------
    126 //
    127 // Here there is the detailed description of the member functions and of
    128 // the terms commonly used in the class.
    129 //
    130 // STANDARD CLEANING:
    131 // =================
    132 // This is the method used for the CT1 data analysis. It is the default
    133 // method of the class.
    134 // The number of photo-electrons of a pixel (S_i) is compared to the
    135 // pedestal RMS of the pixel itself (Prms_i). To have the comparison to
    136 // the same photon density for all the pixels, taking into account they
    137 // can have different areas, we have to keep in mind that the number of
    138 // photons that hit each pixel, goes linearly with the area of the pixel.
    139 // The fluctuations of the LONS are proportional to sqrt(A_i), so when we
    140 // compare S_i with Prms_i, only a factor  sqrt(A_0/A_i) is missing to
    141 // have the same (N.photons/Area) threshold for all the pixels.
    142 //
    143 //              !!WARNING: if noise independent from the
    144 //         pixel size (example: electronic noise) is introduced,
    145 //         then the noise fluctuations are no longer proportional
    146 //         to sqrt(A_i), and then the cut value (for a camera with
    147 //         pixels of different sizes) resulting from the above
    148 //         procedure  would not be proportional to pixel size as we
    149 //         intend. In that case, democratic cleaning is preferred.
    150 //
    151 // If
    152 //Begin_Html
    153 //&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<img src="images/MImgCleanTGB-f1.png">
    154 //End_Html
    155 // the pixel survives the cleaning and it is set as CORE (when L_n is the
    156 // first level of cleaning, fCleanLvl1) or USED (when L_n is the second
    157 // level of cleaning, fCleanLvl2).
    158 //
    159 // Example:
    160 //
    161 // MImgCleanTGB clean;
    162 // //creates a default Cleaning object, with default setting
    163 // ...
    164 // tlist.AddToList(&clean);
    165 // // add the image cleaning to the main task list
    166 //
    167 // DEMOCRATIC CLEANING:
    168 // ===================
    169 // You use this cleaning method when you want to compare the number of
    170 // photo-electons of each pixel with the average pedestal RMS
    171 // (fInnerNoise = fSgb->GetSigmabarInner()) of the inner pixels (for the
    172 // MAGIC camera they are the smaller ones):
    173 //Begin_Html
    174 //&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<img src="images/MImgCleanTGB-f2.png">
    175 //End_Html
    176 // In this case, the simple ratio (A_0/A_i) is used to weight the level of
    177 // cleaning, because both the inner and the outer pixels (that in MAGIC
    178 // have a different area) are compared to the same pedestal RMS, coming
    179 // from the inner pixels.
    180 // To calculate the average pedestal RMS of the inner pixels, you have to
    181 // add to the main task list an object of type MSigmabarCalc before the
    182 // MImgCleanTGB object. To know how the calculation of fInnerNoise is done
    183 // look at the MSigmabarCalc Class.
    184 //
    185 // Example:
    186 //
    187 // MSigmabarCalc   sbcalc;
    188 // //creates an object that calcutates the average pedestal RMS
    189 // MImgCleanTGB clean;
    190 // ...
    191 // tlist.AddToList(&sbcalc);
    192 // tlist.AddToList(&clean);
    193 //
    194 // Member Function:  SetMethod()
    195 // ============================
    196 // When you call the MImgCleanTGB task, the default method is kStandard.
    197 //
    198 // If you want to switch to the kDemocratic method you have to
    199 // call this member function.
    200 //
    201 // Example:
    202 //
    203 // MImgCleanTGB clean;
    204 // //creates a default Cleaning object, with default setting
    205 //
    206 // clean.SetMethod(MImgCleanTGB::kDemocratic);
    207 // //now the method of cleaning is changed to Democratic
    208 //
    209 // FIRST AND SECOND CLEANING LEVEL
    210 // ===============================
    211 // When you call the MImgCleanTGB task, the default cleaning levels are
    212 // fCleanLvl1 = 3, fCleanLvl2 = 2.5. You can change them easily when you
    213 // create the MImgCleanTGB object.
    214 //
    215 // Example:
    216 //
    217 // MImgCleanTGB clean(Float_t lvl1,Float_t lvl2);
    218 // //creates a default cleaning object, but the cleaning levels are now
    219 // //lvl1 and lvl2.
    220 //
    221 // RING NUMBER
    222 // ===========
    223 // The standard cleaning procedure is such that it looks for the
    224 // informations of the boundary part of the shower only on the first
    225 // neighbors of the CORE pixels.
    226 // There is the possibility now to look not only at the firs neighbors
    227 // (first ring),but also further away, around the CORE pixels. All the new
    228 // pixels you can find with this method, are tested with the second level
    229 // of cleaning and have to have at least an USED neighbor.
    230 //
    231 // They will be also set as USED and will be taken into account during the
    232 // calculation of the image parameters.
    233 // The only way to distinguish them from the other USED pixels, is the
    234 // Ring number, that is bigger than 1.
    235 //
    236 // Example: You can decide how many rings you want to analyze using:
    237 //
    238 // MImgCleanTGB clean;
    239 // //creates a default cleaning object (default number of rings =1)
    240 // clean.SetCleanRings(UShort_t r);
    241 // //now it looks r times around the CORE pixels to find new pixels with
    242 // //signal.
    243 //
    24431//
    24532//  Input Containers:
Note: See TracChangeset for help on using the changeset viewer.