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 
3 #include "SiStripDigiToRaw.h"
4 
13 #include <cstdlib>
14 
15 namespace sistrip {
16 
17  // -----------------------------------------------------------------------------
22  inputModuleLabel_( pset.getParameter<std::string>( "InputModuleLabel" ) ),
23  inputDigiLabel_( pset.getParameter<std::string>( "InputDigiLabel" ) ),
24  mode_( fedReadoutModeFromString(pset.getParameter<std::string>( "FedReadoutMode" ))),
25  rawdigi_( false ),
26  digiToRaw_(0),
27  eventCounter_(0)
28  {
29  if ( edm::isDebugEnabled() ) {
30  LogDebug("DigiToRawModule")
31  << "[sistrip::DigiToRawModule::DigiToRawModule]"
32  << " Constructing object...";
33  }
34 
35 
36  switch(mode_) {
37  case READOUT_MODE_ZERO_SUPPRESSED: rawdigi_ = false; break;
38  case READOUT_MODE_ZERO_SUPPRESSED_FAKE: rawdigi_ = false; break;
39  //case READOUT_MODE_ZERO_SUPPRESSED_CMOVERRIDE: rawdigi_ = false; break;
40  case READOUT_MODE_ZERO_SUPPRESSED_LITE10: rawdigi_ = false; break;
42  case READOUT_MODE_ZERO_SUPPRESSED_LITE8: rawdigi_ = false; break;
48  case READOUT_MODE_PREMIX_RAW: rawdigi_ = false; break;
49  case READOUT_MODE_VIRGIN_RAW: rawdigi_ = true; break;
50  case READOUT_MODE_PROC_RAW: rawdigi_ = true; break;
51  case READOUT_MODE_SCOPE: rawdigi_ = true; break;
52  case READOUT_MODE_INVALID: {
53  if( edm::isDebugEnabled()) {
54  edm::LogWarning("DigiToRawModule")
55  << "[sistrip::DigiToRawModule::DigiToRawModule]"
56  << " UNKNOWN readout mode: " << pset.getParameter<std::string>("FedReadoutMode");
57  }} break;
58  case READOUT_MODE_SPY: {
59  if( edm::isDebugEnabled()) {
60  edm::LogWarning("DigiToRawModule")
61  << "[sistrip::DigiToRawModule::DigiToRawModule]"
62  << " Digi to raw is not supported for spy channel data";
63  }} break;
64  }
65  if(pset.getParameter<bool>("UseWrongDigiType")) {
66  rawdigi_ = !rawdigi_;
67  if( edm::isDebugEnabled()) {
68  edm::LogWarning("DigiToRawModule")
69  << "[sistrip::DigiToRawModule::DigiToRawModule]"
70  << " You are using the wrong type of digis!";
71  }
72  }
73 
74  // Create instance of DigiToRaw formatter
75  digiToRaw_ = new DigiToRaw( mode_, pset.getParameter<bool>("UseFedKey") );
76 
77  if (rawdigi_) {
78  tokenRawDigi = consumes< edm::DetSetVector<SiStripRawDigi> >(edm::InputTag(inputModuleLabel_, inputDigiLabel_));
79  } else {
80  tokenDigi = consumes< edm::DetSetVector<SiStripDigi> >(edm::InputTag(inputModuleLabel_, inputDigiLabel_));
81 
82  }
83 
84  produces<FEDRawDataCollection>();
85 
86  }
87 
88  // -----------------------------------------------------------------------------
91  if ( edm::isDebugEnabled() ) {
92  LogDebug("DigiToRaw")
93  << "[sistrip::DigiToRawModule::~DigiToRawModule]"
94  << " Destructing object...";
95  }
96  if ( digiToRaw_ ) delete digiToRaw_;
97  }
98 
99  // -----------------------------------------------------------------------------
107  const edm::EventSetup& iSetup ) {
108 
109  eventCounter_++;
110 
111  std::auto_ptr<FEDRawDataCollection> buffers( new FEDRawDataCollection );
112 
114  iSetup.get<SiStripFedCablingRcd>().get( cabling );
115 
116  if( rawdigi_ ) {
118  iEvent.getByToken( tokenRawDigi, rawdigis );
119  digiToRaw_->createFedBuffers( iEvent, cabling, rawdigis, buffers );
120  } else {
122  iEvent.getByToken( tokenDigi, digis );
123  digiToRaw_->createFedBuffers( iEvent, cabling, digis, buffers );
124  }
125 
126  iEvent.put( buffers );
127 
128  }
129 
130 }
131 
#define LogDebug(id)
T getParameter(std::string const &) const
bool isDebugEnabled()
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
virtual void produce(edm::Event &, const edm::EventSetup &)
FEDReadoutMode fedReadoutModeFromString(const std::string &readoutModeString)
DigiToRawModule(const edm::ParameterSet &)
int iEvent
Definition: GenABIO.cc:230
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:115
void createFedBuffers(edm::Event &, edm::ESHandle< SiStripFedCabling > &cabling, edm::Handle< edm::DetSetVector< SiStripDigi > > &digis, std::auto_ptr< FEDRawDataCollection > &buffers)
const T & get() const
Definition: EventSetup.h:55
edm::EDGetTokenT< edm::DetSetVector< SiStripDigi > > tokenDigi
volatile std::atomic< bool > shutdown_flag false
edm::EDGetTokenT< edm::DetSetVector< SiStripRawDigi > > tokenRawDigi