Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
#include "CommonTools/RecoAlgos/interface/MassiveCandidateConverter.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "HepPDT/ParticleData.hh"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/ConsumesCollector.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include <algorithm>
using namespace edm;
using namespace std;
using namespace converter;

MassiveCandidateConverter::MassiveCandidateConverter(const edm::ParameterSet& cfg, edm::ConsumesCollector iC)
    : massSqr_(0),
      particle_(cfg.getParameter<PdtEntry>("particleType")),
      tableToken_(iC.esConsumes<edm::Transition::BeginRun>()) {}

void MassiveCandidateConverter::beginFirstRun(const EventSetup& es) {
  auto const& pdt = es.getData(tableToken_);
  particle_.setup(pdt);
  massSqr_ = particle_.data().mass();
  massSqr_ *= massSqr_;
}

void MassiveCandidateConverter::fillPSetDescription(edm::ParameterSetDescription& desc) {
  desc.addNode(edm::ParameterDescription<std::string>("particleType", std::string("pi+"), true) xor
               edm::ParameterDescription<int>("particleType", true))
      ->setComment("the PdtEntry can be specified as either an 'int' or via its name using a 'string'");
}