CMS 3D CMS Logo

Public Member Functions | Private Member Functions | Private Attributes

CaloMeanResponse Class Reference

#include <CaloMeanResponse.h>

List of all members.

Public Member Functions

 CaloMeanResponse (edm::ParameterSet const &p)
double getWeight (int genPID, double genP)
virtual ~CaloMeanResponse ()

Private Member Functions

void readResponse (std::string fName)

Private Attributes

int piLast
std::vector< double > pionMomentum
std::vector< double > pionTable
std::vector< int > pionTypes
int pLast
std::vector< double > protonMomentum
std::vector< double > protonTable
std::vector< int > protonTypes
double scale
bool useTable

Detailed Description

Definition at line 10 of file CaloMeanResponse.h.


Constructor & Destructor Documentation

CaloMeanResponse::CaloMeanResponse ( edm::ParameterSet const &  p)

Definition at line 12 of file CaloMeanResponse.cc.

References edm::FileInPath::fullPath(), edm::ParameterSet::getParameter(), readResponse(), scale, and useTable.

                                                            {

  edm::ParameterSet m_p = p.getParameter<edm::ParameterSet>("CaloResponse");
  edm::FileInPath fp    = m_p.getParameter<edm::FileInPath>("ResponseFile");
  std::string fName     = fp.fullPath();
  useTable              = m_p.getParameter<bool>("UseResponseTable");
  scale                 = m_p.getParameter<double>("ResponseScale");
  edm::LogInfo("CaloSim") << "CaloMeanResponse initialized with scale " 
                          << scale << " and use Table " << useTable 
                          << " from file " << fName;

  readResponse (fName);
}
CaloMeanResponse::~CaloMeanResponse ( ) [virtual]

Definition at line 26 of file CaloMeanResponse.cc.

{}

Member Function Documentation

double CaloMeanResponse::getWeight ( int  genPID,
double  genP 
)

Definition at line 28 of file CaloMeanResponse.cc.

References newFWLiteAna::found, i, LogDebug, piLast, pionMomentum, pionTable, pionTypes, pLast, protonMomentum, protonTable, protonTypes, scale, useTable, and CommonMethods::weight().

Referenced by CaloSD::getResponseWt().

                                                          {
  double weight = 1;
  bool   found=false;
  for (unsigned int i=0; i<pionTypes.size(); i++) {
    if (genPID == pionTypes[i]) {
      found = true;
      break;
    }
  }
  if (found) {
    weight = scale;
    if (useTable) {
      if (piLast >= 0) weight *= pionTable[piLast];
      for (unsigned int i=0; i<pionTable.size(); i++) {
        if (genP < pionMomentum[i]) {
          if (i == 0) weight = scale*pionTable[i];
          else        weight = scale*((pionTable[i-1]*(pionMomentum[i]-genP)+
                                       pionTable[i]*(genP-pionMomentum[i-1]))/
                                      (pionMomentum[i]-pionMomentum[i-1]));
          break;
        }
      }
    }
#ifdef DebugLog
    LogDebug("CaloSim") << "CaloMeanResponse::getWeight PID " << genPID
                        << " uses pion list and gets weight " << weight
                        << " for momentum " << genP/GeV << " GeV/c";
#endif
  } else {
    for (unsigned int i=0; i<protonTypes.size(); i++) {
      if (genPID == protonTypes[i]) {
        found = true;
        break;
      }
    }
    if (found) {
      weight = scale;
      if (useTable) {
        if (pLast >= 0) weight *= protonTable[pLast];
        for (unsigned int i=0; i<protonTable.size(); i++) {
          if (genP < protonMomentum[i]) {
            if (i == 0) weight = scale*protonTable[i];
            else        weight = scale*((protonTable[i-1]*(protonMomentum[i]-genP)+
                                         protonTable[i]*(genP-protonMomentum[i-1]))/
                                        (protonMomentum[i]-protonMomentum[i-1]));
            break;
          }
        }
      }
#ifdef DebugLog
      LogDebug("CaloSim") << "CaloMeanResponse::getWeight PID " << genPID
                          << " uses proton list and gets weight " << weight
                          << " for momentum " << genP/GeV << " GeV/c";
#endif
    } else {
#ifdef DebugLog
      LogDebug("CaloSim") << "CaloMeanResponse::getWeight PID " << genPID
                          << " is not in either lists and weight " << weight;
#endif
    }
  }
  return weight;
}
void CaloMeanResponse::readResponse ( std::string  fName) [private]

Definition at line 92 of file CaloMeanResponse.cc.

References i, recoMuon::in, EdgesToViz::infile, LogDebug, npart, evf::utils::pid, piLast, pionMomentum, pionTable, pionTypes, pLast, protonMomentum, protonTable, and protonTypes.

Referenced by CaloMeanResponse().

                                                    {

  std::ifstream infile;
  infile.open(fName.c_str(), std::ios::in);

  if (infile) {
    int    nene, npart, pid;
    double ene, responseData, responseMC, ratio;

    // First read the pion data
    infile >> nene >> npart;
    for (int i=0; i<npart; i++) {
      infile >> pid;
      pionTypes.push_back(pid);
    }
    for (int i=0; i<nene; i++) {
      infile >> ene >> responseData >> responseMC;
      if (responseMC > 0) ratio = responseData/responseMC;
      else                ratio = 1;
      pionMomentum.push_back(ene*GeV);
      pionTable.push_back(ratio);
    }

    // Then read the proton data
    infile >> nene >> npart;
    for (int i=0; i<npart; i++) {
      infile >> pid;
      protonTypes.push_back(pid);
    }
    for (int i=0; i<nene; i++) {
      infile >> ene >> responseData >> responseMC;
      if (responseMC > 0) ratio = responseData/responseMC;
      else                ratio = 1;
      protonMomentum.push_back(ene*GeV);
      protonTable.push_back(ratio);
    }
    infile.close();
  }

  piLast = (int)(pionTable.size()) - 1;
  pLast  = (int)(protonTable.size()) - 1;
#ifdef DebugLog
  LogDebug("CaloSim") << "CaloMeanResponse::readResponse finds "
                      << pionTypes.size() << " particles to use pion response"
                      << " map with a table of " << pionTable.size() 
                      << " data points " << piLast;
  for (unsigned int i=0; i<pionTypes.size(); i++) 
    LogDebug("CaloSim") << "Particle ID[" << i << "] = " << pionTypes[i];
  for (unsigned int i=0; i<pionTable.size(); i++) 
    LogDebug("CaloSim") << "Momentum[" << i << "] (" << pionMomentum[i]/GeV
                        << " GeV/c) --> " << pionTable[i];
  LogDebug("CaloSim") << "CaloMeanResponse::readResponse finds "
                      << protonTypes.size() << " particles to use proton "
                      << "response map with a table of " << protonTable.size()
                      << " data points " << pLast;
  for (unsigned int i=0; i<protonTypes.size(); i++) 
    LogDebug("CaloSim") << "Particle ID[" << i << "] = " << protonTypes[i];
  for (unsigned int i=0; i<protonTable.size(); i++) 
    LogDebug("CaloSim") << "Momentum[" << i << "] (" << protonMomentum[i]/GeV
                        << " GeV/c) --> " << protonTable[i];
#endif
}

Member Data Documentation

int CaloMeanResponse::piLast [private]

Definition at line 24 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<double> CaloMeanResponse::pionMomentum [private]

Definition at line 26 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<double> CaloMeanResponse::pionTable [private]

Definition at line 26 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<int> CaloMeanResponse::pionTypes [private]

Definition at line 25 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

int CaloMeanResponse::pLast [private]

Definition at line 24 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<double> CaloMeanResponse::protonMomentum [private]

Definition at line 27 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<double> CaloMeanResponse::protonTable [private]

Definition at line 27 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

std::vector<int> CaloMeanResponse::protonTypes [private]

Definition at line 25 of file CaloMeanResponse.h.

Referenced by getWeight(), and readResponse().

double CaloMeanResponse::scale [private]

Definition at line 23 of file CaloMeanResponse.h.

Referenced by CaloMeanResponse(), and getWeight().

Definition at line 22 of file CaloMeanResponse.h.

Referenced by CaloMeanResponse(), and getWeight().