Ignore:
Timestamp:
12/11/03 17:42:25 (21 years ago)
Author:
gaug
Message:
*** empty log message ***
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/manalysis/MCalibrationCalc.cc

    r2642 r2658  
    252252{
    253253
    254     fEvents++;
    255 
    256254    Int_t cosmicpix = 0;
    257255
     
    273271    while (pixel.Next())
    274272      {
    275 
    276         const Int_t pixid = pixel.GetPixelId();
    277 
    278         Int_t sum = pixel.GetSumHiGainSamples();
    279 
    280         MPedestalPix    &ped = (*fPedestals)[pixid];
    281  
    282         Float_t pedes  = ped.GetPedestal();
     273       
     274        const UInt_t pixid = pixel.GetPixelId();
     275       
     276        MExtractedSignalPix &sig =  (*fSignals)[pixid];
     277        MPedestalPix        &ped =  (*fPedestals)[pixid];
    283278        Float_t pedrms = ped.GetPedestalRms();
     279        Float_t sumhi  = sig.GetExtractedSignalHiGain();
    284280       
    285         if ((float)sum < ((pedes*fNumHiGainSamples)+(2.*fNumHiGainSamples*pedrms)) )
    286            cosmicpix++;
     281        if (sumhi < 15.*pedrms )   // cut at 3.5 sigma
     282          cosmicpix++;
    287283     }
    288284
    289 
    290     if (cosmicpix > 50.)
     285    if (cosmicpix > 100.)
    291286      {
    292287        fCosmics++;
     
    295290
    296291    pixel.Reset();
     292    fEvents++;
    297293
    298294    //
     
    304300
    305301        const UInt_t pixid = pixel.GetPixelId();
    306 
     302       
    307303        MExtractedSignalPix &sig =  (*fSignals)[pixid];
    308 
     304       
    309305        Float_t sumhi  = sig.GetExtractedSignalHiGain();
    310306        Float_t sumlo  = sig.GetExtractedSignalLoGain();
    311307        Bool_t  logain = sig.IsLoGainUsed();
    312308
    313         Byte_t mid;
    314 
    315         if (logain)
    316             mid  = pixel.GetIdxMaxLoGainSample();
    317         else
    318             mid  = pixel.GetIdxMaxHiGainSample();
     309        Float_t mtime  = sig.GetMeanArrivalTime();
    319310
    320311        MCalibrationPix &pix = (*fCalibrations)[pixid];
     
    329320                "Overflow or Underflow occurred filling Blind Pixel sum = " << sumhi << endl;
    330321
    331             if (!blindpixel.FillTime((int)mid))
     322            if (!blindpixel.FillTime((int)mtime))
    332323              *fLog << warn <<
    333                 "Overflow or Underflow occurred filling Blind Pixel time = " << (int)mid << endl;
     324                "Overflow or Underflow occurred filling Blind Pixel time = " << mtime << endl;
    334325           
    335326            if (!blindpixel.FillRChargevsTime(sumhi,fEvents))
    336327              *fLog << warn <<
    337328                "Overflow or Underflow occurred filling Blind Pixel eventnr = " << fEvents << endl;
     329            break;
    338330           
    339331          case gkCalibrationPINDiodeId:
     
    341333              *fLog << warn <<
    342334                "Overflow or Underflow occurred filling HCharge: means = " << sumhi << endl;
    343             if (!pindiode.FillTime((int)mid))
     335            if (!pindiode.FillTime((int)mtime))
    344336              *fLog << warn <<
    345                 "Overflow or Underflow occurred filling HTime: time = " << (int)mid << endl;
     337                "Overflow or Underflow occurred filling HTime: time = " << mtime << endl;
    346338            if (!pindiode.FillRChargevsTime(sumhi,fEvents))
    347339              *fLog << warn <<
    348340                "Overflow or Underflow occurred filling HChargevsN: eventnr = " << fEvents << endl;
     341            break;
    349342
    350343          default:
     
    359352                        << " signal = " << sumlo << endl;
    360353
    361                 if (!pix.FillTimeLoGain((int)mid))
     354                if (!pix.FillTimeLoGain((int)mtime))
    362355                  *fLog << warn << "Could not fill Lo Gain Time of pixel: "
    363                         << pixid << " time = " << (int)mid << endl;
     356                        << pixid << " time = " << mtime << endl;
    364357               
    365                 //
    366                 // Fill the reduced charge into the control histo for better visibility
    367                 //
    368358                if (!pix.FillRChargevsTimeLoGain(sumlo,fEvents))
    369359                  *fLog << warn << "Could not fill Lo Gain Charge vs. EvtNr of pixel: "
     
    377367                        << " signal = " << sumhi << endl;
    378368               
    379                 if (!pix.FillTimeHiGain((int)mid))
     369                if (!pix.FillTimeHiGain((int)mtime))
    380370                  *fLog << warn << "Could not fill Hi Gain Time of pixel: "
    381                         << pixid << " time = " << (int)mid << endl;
     371                        << pixid << " time = " << mtime << endl;
    382372               
    383373                if (!pix.FillRChargevsTimeHiGain(sumhi,fEvents))
     
    385375                        << pixid << " signal = " << sumhi  << " event Nr: " << fEvents << endl;
    386376              }
     377            break;
    387378           
    388379          } /* switch(pixid) */
     
    449440      pix.SetPedestal(ped,prms);
    450441
     442      pix.FitCharge();
     443
    451444      if (TESTBIT(fFlags,kUseTimeFits))
    452445        pix.FitTime();
    453446     
    454       pix.FitCharge();
    455447    }
    456448
Note: See TracChangeset for help on using the changeset viewer.