CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
SiStripDigiToRawModule.cc
Go to the documentation of this file.
1 
15 #include <cstdlib>
16 
17 namespace sistrip {
18 
19  // -----------------------------------------------------------------------------
24  inputModuleLabel_( pset.getParameter<std::string>( "InputModuleLabel" ) ),
25  inputDigiLabel_( pset.getParameter<std::string>( "InputDigiLabel" ) ),
26  mode_( fedReadoutModeFromString(pset.getParameter<std::string>( "FedReadoutMode" ))),
27  rawdigi_( false ),
28  digiToRaw_(0),
29  eventCounter_(0)
30  {
31  if ( edm::isDebugEnabled() ) {
32  LogDebug("DigiToRawModule")
33  << "[sistrip::DigiToRawModule::DigiToRawModule]"
34  << " Constructing object...";
35  }
36 
37  switch(mode_) {
38  case READOUT_MODE_ZERO_SUPPRESSED_LITE: rawdigi_ = false; break;
39  case READOUT_MODE_ZERO_SUPPRESSED: rawdigi_ = false; break;
40  case READOUT_MODE_VIRGIN_RAW: rawdigi_ = true; break;
41  case READOUT_MODE_PROC_RAW: rawdigi_ = true; break;
42  case READOUT_MODE_SCOPE: rawdigi_ = true; break;
43  case READOUT_MODE_INVALID: {
44  if( edm::isDebugEnabled()) {
45  edm::LogWarning("DigiToRawModule")
46  << "[sistrip::DigiToRawModule::DigiToRawModule]"
47  << " UNKNOWN readout mode: " << pset.getParameter<std::string>("FedReadoutMode");
48  }} break;
49  case READOUT_MODE_SPY: {
50  if( edm::isDebugEnabled()) {
51  edm::LogWarning("DigiToRawModule")
52  << "[sistrip::DigiToRawModule::DigiToRawModule]"
53  << " Digi to raw is not supported for spy channel data";
54  }} break;
55  }
56  if(pset.getParameter<bool>("UseWrongDigiType")) {
57  rawdigi_ = !rawdigi_;
58  if( edm::isDebugEnabled()) {
59  edm::LogWarning("DigiToRawModule")
60  << "[sistrip::DigiToRawModule::DigiToRawModule]"
61  << " You are using the wrong type of digis!";
62  }
63  }
64 
65  // Create instance of DigiToRaw formatter
66  digiToRaw_ = new DigiToRaw( mode_, pset.getParameter<bool>("UseFedKey") );
67 
68  produces<FEDRawDataCollection>();
69 
70  }
71 
72  // -----------------------------------------------------------------------------
75  if ( edm::isDebugEnabled() ) {
76  LogDebug("DigiToRaw")
77  << "[sistrip::DigiToRawModule::~DigiToRawModule]"
78  << " Destructing object...";
79  }
80  if ( digiToRaw_ ) delete digiToRaw_;
81  }
82 
83  // -----------------------------------------------------------------------------
91  const edm::EventSetup& iSetup ) {
92 
93  eventCounter_++;
94 
95  std::auto_ptr<FEDRawDataCollection> buffers( new FEDRawDataCollection );
96 
98  iSetup.get<SiStripFedCablingRcd>().get( cabling );
99 
100  if( rawdigi_ ) {
102  iEvent.getByLabel( inputModuleLabel_, inputDigiLabel_, rawdigis );
103  digiToRaw_->createFedBuffers( iEvent, cabling, rawdigis, buffers );
104  } else {
106  iEvent.getByLabel( inputModuleLabel_, inputDigiLabel_, digis );
107  digiToRaw_->createFedBuffers( iEvent, cabling, digis, buffers );
108  }
109 
110  iEvent.put( buffers );
111 
112  }
113 
114 }
115 
#define LogDebug(id)
T getParameter(std::string const &) const
bool isDebugEnabled()
virtual void produce(edm::Event &, const edm::EventSetup &)
FEDReadoutMode fedReadoutModeFromString(const std::string &readoutModeString)
DigiToRawModule(const edm::ParameterSet &)
int iEvent
Definition: GenABIO.cc:243
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:116
void createFedBuffers(edm::Event &, edm::ESHandle< SiStripFedCabling > &cabling, edm::Handle< edm::DetSetVector< SiStripDigi > > &digis, std::auto_ptr< FEDRawDataCollection > &buffers)
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:390
const T & get() const
Definition: EventSetup.h:55
volatile std::atomic< bool > shutdown_flag false