1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
18 #include "AliMUONDigitCalibrator.h"
20 #include "AliCDBEntry.h"
21 #include "AliCDBManager.h"
22 #include "AliCDBStorage.h"
24 #include "AliMUONCalibrationData.h"
25 #include "AliMUONConstants.h"
26 #include "AliMUONData.h"
27 #include "AliMUONDigit.h"
28 #include "AliMUONCalibParam.h"
29 #include "AliMpDEManager.h"
31 #include "AliMpPlaneType.h"
32 #include "AliMpStationType.h"
33 #include "AliMpVSegmentation.h"
34 #include "Riostream.h"
35 #include "TClonesArray.h"
37 ClassImp(AliMUONDigitCalibrator)
39 //_____________________________________________________________________________
40 AliMUONDigitCalibrator::AliMUONDigitCalibrator(AliMUONData* muonData,
41 AliMUONCalibrationData* calib)
42 : TTask("AliMUONDigitCalibrator","Subtract pedestal from digit charge"),
44 fCalibrationData(calib)
48 //_____________________________________________________________________________
49 AliMUONDigitCalibrator::~AliMUONDigitCalibrator()
53 //_____________________________________________________________________________
55 AliMUONDigitCalibrator::Exec(Option_t*)
57 for ( Int_t ch = 0; ch < AliMUONConstants::NTrackingCh(); ++ch )
59 TClonesArray* digitArray = fData->Digits(ch);
60 Int_t nDigits = digitArray->GetEntriesFast();
61 for ( Int_t d = 0; d < nDigits; ++d )
64 static_cast<AliMUONDigit*>(digitArray->UncheckedAt(d));
66 AliMUONCalibParam* pedestal = static_cast<AliMUONCalibParam*>
67 (fCalibrationData->Pedestal(digit->DetElemId(),
68 digit->ManuId(),digit->ManuChannel()));
70 AliMUONCalibParam* gain = static_cast<AliMUONCalibParam*>
71 (fCalibrationData->Gain(digit->DetElemId(),
72 digit->ManuId(),digit->ManuChannel()));
75 AliFatal(Form("Got a null ped object for DE,manu,channel=%d,%d,%d",
76 digit->DetElemId(),digit->ManuId(),digit->ManuChannel()));
81 AliFatal(Form("Got a null gain object for DE,manu,channel=%d,%d,%d",
82 digit->DetElemId(),digit->ManuId(),digit->ManuChannel()));
86 Int_t adc = digit->Signal();
87 Float_t padc = adc-pedestal->Mean();
88 if ( padc < 3.0*pedestal->Sigma() )
92 Float_t charge = padc*gain->Mean();
93 Int_t signal = TMath::Nint(charge);
94 digit->SetSignal(signal);