CMS 3D CMS Logo

Public Member Functions | Private Attributes

ESRecHitSimAlgo Class Reference

#include <ESRecHitSimAlgo.h>

List of all members.

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 ESAngleCorrectionFactorsang_
const ESChannelStatuschannelStatus_
int gain_
double MIPGeV_
const ESIntercalibConstantsmips_
const ESPedestalspeds_
const ESRecHitRatioCutsratioCuts_
double w0_
double w1_
double w2_

Detailed Description

Definition at line 12 of file ESRecHitSimAlgo.h.


Constructor & Destructor Documentation

ESRecHitSimAlgo::ESRecHitSimAlgo ( )

Definition at line 7 of file ESRecHitSimAlgo.cc.

                                 {

}
ESRecHitSimAlgo::~ESRecHitSimAlgo ( ) [inline]

Definition at line 17 of file ESRecHitSimAlgo.h.

{}

Member Function Documentation

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().

void ESRecHitSimAlgo::setESGain ( const double &  value) [inline]

Definition at line 19 of file ESRecHitSimAlgo.h.

References gain_, and relativeConstraints::value.

Referenced by ESRecHitWorker::set().

{ gain_ = value; }
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().

{ MIPGeV_ = value; }
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().

{ w0_ = value; } 
void ESRecHitSimAlgo::setW1 ( const double &  value) [inline]

Definition at line 27 of file ESRecHitSimAlgo.h.

References relativeConstraints::value, and w1_.

Referenced by ESRecHitWorker::set().

{ w1_ = value; } 
void ESRecHitSimAlgo::setW2 ( const double &  value) [inline]

Definition at line 28 of file ESRecHitSimAlgo.h.

References relativeConstraints::value, and w2_.

Referenced by ESRecHitWorker::set().

{ w2_ = value; } 

Member Data Documentation

Definition at line 40 of file ESRecHitSimAlgo.h.

Referenced by reconstruct(), and setAngleCorrectionFactors().

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().

Definition at line 37 of file ESRecHitSimAlgo.h.

Referenced by reconstruct(), and setIntercalibConstants().

Definition at line 36 of file ESRecHitSimAlgo.h.

Referenced by reconstruct(), and setPedestals().

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().