#include <ESRecHitSimAlgo.h>
Public Member Functions | |
ESRecHitSimAlgo () | |
double * | EvalAmplitude (const ESDataFrame &digi, const double &ped, const double &w0, const double &w1, const double &w2) const |
EcalRecHit | reconstruct (const ESDataFrame &digi) const |
void | setAngleCorrectionFactors (const ESAngleCorrectionFactors *ang) |
void | setChannelStatus (const ESChannelStatus *status) |
void | setESGain (const double &value) |
void | setIntercalibConstants (const ESIntercalibConstants *mips) |
void | setMIPGeV (const double &value) |
void | setPedestals (const ESPedestals *peds) |
void | setRatioCuts (const ESRecHitRatioCuts *ratioCuts) |
void | setW0 (const double &value) |
void | setW1 (const double &value) |
void | setW2 (const double &value) |
~ESRecHitSimAlgo () | |
Private Attributes | |
const ESAngleCorrectionFactors * | ang_ |
const ESChannelStatus * | channelStatus_ |
int | gain_ |
double | MIPGeV_ |
const ESIntercalibConstants * | mips_ |
const ESPedestals * | peds_ |
const ESRecHitRatioCuts * | ratioCuts_ |
double | w0_ |
double | w1_ |
double | w2_ |
Definition at line 12 of file ESRecHitSimAlgo.h.
ESRecHitSimAlgo::ESRecHitSimAlgo | ( | ) |
Definition at line 7 of file ESRecHitSimAlgo.cc.
{ }
ESRecHitSimAlgo::~ESRecHitSimAlgo | ( | ) | [inline] |
Definition at line 17 of file ESRecHitSimAlgo.h.
{}
double * ESRecHitSimAlgo::EvalAmplitude | ( | const ESDataFrame & | digi, |
const double & | ped, | ||
const double & | w0, | ||
const double & | w1, | ||
const double & | w2 | ||
) | const |
Definition at line 11 of file ESRecHitSimAlgo.cc.
References ecalMGPA::adc(), ESSample::adc(), relval_parameters_module::energy, funct::exp(), ESRecHitRatioCuts::getR12High(), ESRecHitRatioCuts::getR23High(), i, funct::log(), LogDebug, n, funct::pow(), ratioCuts_, python::entryComment::results, ESDataFrame::sample(), ESDataFrame::size(), ntuplemaker::status, w(), and w2.
Referenced by reconstruct().
{ double *results = new double[4]; float energy = 0; double adc[3]; float pw[3]; pw[0] = w0; pw[1] = w1; pw[2] = w2; for (int i=0; i<digi.size(); i++) { energy += pw[i]*(digi.sample(i).adc()-ped); LogDebug("ESRecHitSimAlgo") << "ESRecHitSimAlgo : Digi "<<i<<" ADC counts "<<digi.sample(i).adc()<<" Ped "<<ped; //std::cout<<i<<" "<<digi.sample(i).adc()<<" "<<ped<<" "<<pw[i]<<std::endl; adc[i] = digi.sample(i).adc() - ped; } double status = 0; if (adc[0] > 20) status = 14; if (adc[1] <= 0 || adc[2] <= 0) status = 10; if (adc[0] > adc[1] && adc[0] > adc[2]) status = 8; if (adc[2] > adc[1] && adc[2] > adc[0]) status = 9; double r12 = (adc[1] != 0) ? adc[0]/adc[1] : 99; double r23 = (adc[2] != 0) ? adc[1]/adc[2] : 99; if (r12 > ratioCuts_->getR12High()) status = 5; if (r23 > ratioCuts_->getR23High()) status = 6; if (r23 < ratioCuts_->getR23Low()) status = 7; double A1 = adc[1]; double A2 = adc[2]; // t0 from analytical formula: double n = 1.798; double w = 0.07291; double DeltaT = 25.; double aaa = (A2 > 0 && A1 > 0) ? log(A2/A1)/n : 20.; // if A1=0, t0=20 double bbb = w/n*DeltaT; double ccc= exp(aaa+bbb); double t0 = (2.-ccc)/(1.-ccc) * DeltaT - 5; // A from analytical formula: double t1 = 20.; double A_1 = pow(w/n*(t1),n) * exp(n-w*(t1)); double AA1 = (A_1 != 0.) ? A1 / A_1 : 0.; if (adc[1] > 2800 && adc[2] > 2800) status = 11; else if (adc[1] > 2800) status = 12; else if (adc[2] > 2800) status = 13; results[0] = energy; // energy with weight method results[1] = t0; // timing results[2] = status; // hit status results[3] = AA1; // energy with analytic method return results; }
EcalRecHit ESRecHitSimAlgo::reconstruct | ( | const ESDataFrame & | digi | ) | const |
Definition at line 69 of file ESRecHitSimAlgo.cc.
References ang_, channelStatus_, funct::cos(), relval_parameters_module::energy, EvalAmplitude(), ESCondObjectContainer< T >::find(), ESCondObjectContainer< T >::getMap(), ESDataFrame::id(), EcalRecHit::kESBadRatioFor12, EcalRecHit::kESBadRatioFor23Lower, EcalRecHit::kESBadRatioFor23Upper, EcalRecHit::kESDead, EcalRecHit::kESGood, EcalRecHit::kESSaturated, EcalRecHit::kESTS13Sigmas, EcalRecHit::kESTS1Largest, EcalRecHit::kESTS2Saturated, EcalRecHit::kESTS3Largest, EcalRecHit::kESTS3Negative, EcalRecHit::kESTS3Saturated, LogDebug, MIPGeV_, mips_, peds_, python::entryComment::results, EcalRecHit::setOutOfTimeEnergy(), ntuplemaker::status, w0_, w1_, and w2_.
Referenced by ESRecHitWorker::run().
{ ESPedestals::const_iterator it_ped = peds_->find(digi.id()); ESIntercalibConstantMap::const_iterator it_mip = mips_->getMap().find(digi.id()); ESAngleCorrectionFactors::const_iterator it_ang = ang_->getMap().find(digi.id()); ESChannelStatusMap::const_iterator it_status = channelStatus_->getMap().find(digi.id()); double* results; results = EvalAmplitude(digi, it_ped->getMean(), w0_, w1_, w2_); double energy = results[0]; double t0 = results[1]; int status = (int) results[2]; double otenergy = results[3] * 1000000.; // set out-of-time energy to keV delete[] results; double mipCalib = (fabs(cos(*it_ang)) != 0.) ? (*it_mip)/fabs(cos(*it_ang)) : 0.; energy *= (mipCalib != 0.) ? MIPGeV_/mipCalib : 0.; otenergy *= (mipCalib != 0.) ? MIPGeV_/mipCalib : 0.; LogDebug("ESRecHitSimAlgo") << "ESRecHitSimAlgo : reconstructed energy "<<energy; EcalRecHit rechit(digi.id(), energy, t0); rechit.setOutOfTimeEnergy(otenergy); if (it_status->getStatusCode() == 1) { rechit.setFlag(EcalRecHit::kESDead); } else { if (status == 0) rechit.setFlag(EcalRecHit::kESGood); else if (status == 5) rechit.setFlag(EcalRecHit::kESBadRatioFor12); else if (status == 6) rechit.setFlag(EcalRecHit::kESBadRatioFor23Upper); else if (status == 7) rechit.setFlag(EcalRecHit::kESBadRatioFor23Lower); else if (status == 8) rechit.setFlag(EcalRecHit::kESTS1Largest); else if (status == 9) rechit.setFlag(EcalRecHit::kESTS3Largest); else if (status == 10) rechit.setFlag(EcalRecHit::kESTS3Negative); else if (status == 11) rechit.setFlag(EcalRecHit::kESSaturated); else if (status == 12) rechit.setFlag(EcalRecHit::kESTS2Saturated); else if (status == 13) rechit.setFlag(EcalRecHit::kESTS3Saturated); else if (status == 14) rechit.setFlag(EcalRecHit::kESTS13Sigmas); } return rechit; }
void ESRecHitSimAlgo::setAngleCorrectionFactors | ( | const ESAngleCorrectionFactors * | ang | ) | [inline] |
Definition at line 25 of file ESRecHitSimAlgo.h.
References ang_.
Referenced by ESRecHitWorker::set().
{ ang_ = ang; }
void ESRecHitSimAlgo::setChannelStatus | ( | const ESChannelStatus * | status | ) | [inline] |
Definition at line 23 of file ESRecHitSimAlgo.h.
References channelStatus_, and ntuplemaker::status.
Referenced by ESRecHitWorker::set().
{ channelStatus_ = status; }
void ESRecHitSimAlgo::setESGain | ( | const double & | value | ) | [inline] |
Definition at line 19 of file ESRecHitSimAlgo.h.
References gain_, and relativeConstraints::value.
Referenced by ESRecHitWorker::set().
void ESRecHitSimAlgo::setIntercalibConstants | ( | const ESIntercalibConstants * | mips | ) | [inline] |
Definition at line 22 of file ESRecHitSimAlgo.h.
References mips_.
Referenced by ESRecHitWorker::set().
{ mips_ = mips; }
void ESRecHitSimAlgo::setMIPGeV | ( | const double & | value | ) | [inline] |
Definition at line 20 of file ESRecHitSimAlgo.h.
References MIPGeV_, and relativeConstraints::value.
Referenced by ESRecHitWorker::set().
void ESRecHitSimAlgo::setPedestals | ( | const ESPedestals * | peds | ) | [inline] |
Definition at line 21 of file ESRecHitSimAlgo.h.
References peds_.
Referenced by ESRecHitWorker::set().
{ peds_ = peds; }
void ESRecHitSimAlgo::setRatioCuts | ( | const ESRecHitRatioCuts * | ratioCuts | ) | [inline] |
Definition at line 24 of file ESRecHitSimAlgo.h.
References ratioCuts_.
Referenced by ESRecHitWorker::set().
{ ratioCuts_ = ratioCuts; }
void ESRecHitSimAlgo::setW0 | ( | const double & | value | ) | [inline] |
Definition at line 26 of file ESRecHitSimAlgo.h.
References relativeConstraints::value, and w0_.
Referenced by ESRecHitWorker::set().
void ESRecHitSimAlgo::setW1 | ( | const double & | value | ) | [inline] |
Definition at line 27 of file ESRecHitSimAlgo.h.
References relativeConstraints::value, and w1_.
Referenced by ESRecHitWorker::set().
void ESRecHitSimAlgo::setW2 | ( | const double & | value | ) | [inline] |
Definition at line 28 of file ESRecHitSimAlgo.h.
References relativeConstraints::value, and w2_.
Referenced by ESRecHitWorker::set().
const ESAngleCorrectionFactors* ESRecHitSimAlgo::ang_ [private] |
Definition at line 40 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setAngleCorrectionFactors().
const ESChannelStatus* ESRecHitSimAlgo::channelStatus_ [private] |
Definition at line 38 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setChannelStatus().
int ESRecHitSimAlgo::gain_ [private] |
Definition at line 35 of file ESRecHitSimAlgo.h.
Referenced by setESGain().
double ESRecHitSimAlgo::MIPGeV_ [private] |
Definition at line 44 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setMIPGeV().
const ESIntercalibConstants* ESRecHitSimAlgo::mips_ [private] |
Definition at line 37 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setIntercalibConstants().
const ESPedestals* ESRecHitSimAlgo::peds_ [private] |
Definition at line 36 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setPedestals().
const ESRecHitRatioCuts* ESRecHitSimAlgo::ratioCuts_ [private] |
Definition at line 39 of file ESRecHitSimAlgo.h.
Referenced by EvalAmplitude(), and setRatioCuts().
double ESRecHitSimAlgo::w0_ [private] |
Definition at line 41 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setW0().
double ESRecHitSimAlgo::w1_ [private] |
Definition at line 42 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setW1().
double ESRecHitSimAlgo::w2_ [private] |
Definition at line 43 of file ESRecHitSimAlgo.h.
Referenced by reconstruct(), and setW2().