CMS 3D CMS Logo

ESRawToDigi.cc
Go to the documentation of this file.
2 
5 
12 
13 #include <iostream>
14 
17  ESdigiCollection_ = ps.getParameter<std::string>("ESdigiCollection");
18  regional_ = ps.getUntrackedParameter<bool>("DoRegional", false);
19  edm::InputTag fedsListLabel =
20  ps.getUntrackedParameter<edm::InputTag>("ESFedsListLabel", edm::InputTag(":esfedslist"));
21  debug_ = ps.getUntrackedParameter<bool>("debugMode", false);
22 
23  ESUnpacker_ = new ESUnpacker(ps);
24 
25  produces<ESRawDataCollection>();
26  produces<ESLocalRawDataCollection>();
27  produces<ESDigiCollection>();
28  dataToken_ = consumes<FEDRawDataCollection>(sourceTag);
29  if (regional_) {
30  fedsToken_ = consumes<ESListOfFEDS>(fedsListLabel);
31  }
32 }
33 
35 
38  desc.add<edm::InputTag>("sourceTag", edm::InputTag("rawDataCollector"));
39  desc.addUntracked<bool>("debugMode", false);
40  desc.add<std::string>("InstanceES", "");
41  desc.add<edm::FileInPath>("LookupTable", edm::FileInPath("EventFilter/ESDigiToRaw/data/ES_lookup_table.dat"));
42  desc.add<std::string>("ESdigiCollection", "");
43  descriptions.add("esRawToDigi", desc);
44 }
45 
47  // Input
49  e.getByToken(dataToken_, rawdata);
50  if (!rawdata.isValid()) {
51  LogDebug("") << "ESRawToDigi : Error! can't get rawdata!" << std::endl;
52  }
53 
54  std::vector<int> esFeds_to_unpack;
55  if (regional_) {
57  e.getByToken(fedsToken_, fedslist);
58  esFeds_to_unpack = fedslist->GetList();
59  }
60 
61  // Output
62  auto productDCC = std::make_unique<ESRawDataCollection>();
63  auto productKCHIP = std::make_unique<ESLocalRawDataCollection>();
64  auto productDigis = std::make_unique<ESDigiCollection>();
65 
66  ESDigiCollection digis;
67 
68  if (regional_) {
69  for (unsigned int i = 0; i < esFeds_to_unpack.size(); ++i) {
70  const FEDRawData& fedRawData = rawdata->FEDData(esFeds_to_unpack[i]);
71  ESUnpacker_->interpretRawData(esFeds_to_unpack[i], fedRawData, *productDCC, *productKCHIP, *productDigis);
72 
73  if (debug_)
74  std::cout << "FED : " << esFeds_to_unpack[i] << " Data size : " << fedRawData.size() << " (Bytes)" << std::endl;
75  }
76  } else {
78  const FEDRawData& fedRawData = rawdata->FEDData(fedId);
79  ESUnpacker_->interpretRawData(fedId, fedRawData, *productDCC, *productKCHIP, *productDigis);
80 
81  if (debug_)
82  std::cout << "FED : " << fedId << " Data size : " << fedRawData.size() << " (Bytes)" << std::endl;
83  }
84  }
85 
86  e.put(std::move(productDCC));
87  e.put(std::move(productKCHIP));
88  e.put(std::move(productDigis), ESdigiCollection_);
89 }
ConfigurationDescriptions.h
FEDNumbering.h
mps_fire.i
i
Definition: mps_fire.py:428
ESRawToDigi::dataToken_
edm::EDGetTokenT< FEDRawDataCollection > dataToken_
Definition: ESRawToDigi.h:24
gather_cfg.cout
cout
Definition: gather_cfg.py:144
HLT_FULL_cff.InputTag
InputTag
Definition: HLT_FULL_cff.py:85964
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
ESRawToDigi::~ESRawToDigi
~ESRawToDigi() override
Definition: ESRawToDigi.cc:34
FEDNumbering::MINPreShowerFEDID
Definition: FEDNumbering.h:31
ESRawToDigi::ESUnpacker_
ESUnpacker * ESUnpacker_
Definition: ESRawToDigi.h:31
edm::ParameterSet::getUntrackedParameter
T getUntrackedParameter(std::string const &, T const &) const
ESUnpacker::interpretRawData
void interpretRawData(int fedId, const FEDRawData &rawData, ESRawDataCollection &dccs, ESLocalRawDataCollection &kchips, ESDigiCollection &digis)
Definition: ESUnpacker.cc:49
FEDRawData.h
edm::Handle
Definition: AssociativeIterator.h:50
FEDRawData
Definition: FEDRawData.h:19
edm::FileInPath
Definition: FileInPath.h:64
ESKCHIPBlock.h
l1t_dqm_sourceclient-live_cfg.fedRawData
fedRawData
Definition: l1t_dqm_sourceclient-live_cfg.py:188
edm::ConfigurationDescriptions::add
void add(std::string const &label, ParameterSetDescription const &psetDescription)
Definition: ConfigurationDescriptions.cc:57
ESRawToDigi::produce
void produce(edm::Event &e, const edm::EventSetup &es) override
Definition: ESRawToDigi.cc:46
ESRawToDigi::ESRawToDigi
ESRawToDigi(const edm::ParameterSet &ps)
Definition: ESRawToDigi.cc:15
EcalDigiCollections.h
ESRawToDigi::regional_
bool regional_
Definition: ESRawToDigi.h:27
ParameterSetDescription.h
FEDRawDataCollection::FEDData
const FEDRawData & FEDData(int fedid) const
retrieve data for fed
Definition: FEDRawDataCollection.cc:19
edm::ConfigurationDescriptions
Definition: ConfigurationDescriptions.h:28
ESDigiCollection
Definition: EcalDigiCollections.h:82
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
ESListOfFEDS::GetList
std::vector< int > GetList() const
Definition: ESListOfFEDS.h:10
ESRawToDigi::ESdigiCollection_
std::string ESdigiCollection_
Definition: ESRawToDigi.h:23
LogDebug
#define LogDebug(id)
Definition: MessageLogger.h:223
edm::ParameterSet
Definition: ParameterSet.h:47
FEDRawDataCollection.h
RawToDigi_cff.sourceTag
sourceTag
Definition: RawToDigi_cff.py:78
edm::EventSetup
Definition: EventSetup.h:57
FEDNumbering::MAXPreShowerFEDID
Definition: FEDNumbering.h:32
l1tstage2_dqm_sourceclient-live_cfg.fedId
fedId
Definition: l1tstage2_dqm_sourceclient-live_cfg.py:88
ESRawToDigi::fedsToken_
edm::EDGetTokenT< ESListOfFEDS > fedsToken_
Definition: ESRawToDigi.h:25
ESDCCHeaderBlock.h
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
eostools.move
def move(src, dest)
Definition: eostools.py:511
ESRawToDigi::fillDescriptions
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
Definition: ESRawToDigi.cc:36
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
ESRawToDigi.h
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
edm::Event
Definition: Event.h:73
ESRawToDigi::debug_
bool debug_
Definition: ESRawToDigi.h:29
edm::InputTag
Definition: InputTag.h:15
ESUnpacker
Definition: ESUnpacker.h:22
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37