CMS 3D CMS Logo

Public Member Functions | Private Attributes

CSCDCCUnpacker Class Reference

#include <CSCDCCUnpacker.h>

Inheritance diagram for CSCDCCUnpacker:
edm::EDProducer edm::ProducerBase edm::ProductRegistryHelper

List of all members.

Public Member Functions

 CSCDCCUnpacker (const edm::ParameterSet &pset)
 Constructor.
void produce (edm::Event &e, const edm::EventSetup &c)
 Produce digis out of raw data.
void visual_raw (int hl, int id, int run, int event, bool fedshort, bool fDump, short unsigned int *buf) const
 Visualization of raw data in FED-less events (Robert Harr and Alexander Sakharov)
virtual ~CSCDCCUnpacker ()
 Destructor.

Private Attributes

bool debug
unsigned int errorMask
unsigned int examinerMask
bool formatedEventDump
bool goodEvent
edm::InputTag inputObjectsTag
bool instantiateDQM
CSCMonitorInterfacemonitor
int numOfEvents
bool printEventNumber
bool SuppressZeroLCT
 Suppress zeros LCTs.
bool unpackStatusDigis
bool useExaminer
bool useFormatStatus
bool useSelectiveUnpacking
bool visualFEDInspect
 Visualization of raw data.
bool visualFEDShort

Detailed Description

Date:
2010/06/11 15:50:27
Revision:
1.25
Author:
Alex Tumanov

Definition at line 19 of file CSCDCCUnpacker.h.


Constructor & Destructor Documentation

CSCDCCUnpacker::CSCDCCUnpacker ( const edm::ParameterSet pset)

Constructor.

Selective unpacking mode will skip only troublesome CSC blocks and not whole DCC/DDU block

Enable Format Status Digis

Visualization of raw data

Suppress zeros LCTs

Definition at line 70 of file CSCDCCUnpacker.cc.

References debug, errorMask, examinerMask, formatedEventDump, edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), inputObjectsTag, instantiateDQM, monitor, cmsCodeRules::cppFunctionSkipper::operator, printEventNumber, CSCCLCTData::setDebug(), CSCTMBHeader::setDebug(), CSCEventData::setDebug(), CSCDDUEventData::setDebug(), CSCTMBData::setDebug(), CSCALCTHeader::setDebug(), CSCDCCEventData::setDebug(), CSCRPCData::setDebug(), CSCDDUEventData::setErrorMask(), SuppressZeroLCT, unpackStatusDigis, useExaminer, useFormatStatus, useSelectiveUnpacking, visualFEDInspect, and visualFEDShort.

                                                           :
  numOfEvents(0) {

  // Tracked

  inputObjectsTag       = pset.getParameter<edm::InputTag>("InputObjects");
  useExaminer           = pset.getParameter<bool>("UseExaminer");
  examinerMask          = pset.getParameter<unsigned int>("ExaminerMask");
  useSelectiveUnpacking = pset.getParameter<bool>("UseSelectiveUnpacking");
  errorMask             = pset.getParameter<unsigned int>("ErrorMask");
  unpackStatusDigis     = pset.getParameter<bool>("UnpackStatusDigis");
  useFormatStatus       = pset.getParameter<bool>("UseFormatStatus");

  // Untracked

  printEventNumber      = pset.getUntrackedParameter<bool>("PrintEventNumber", true);
  debug                 = pset.getUntrackedParameter<bool>("Debug", false);
  instantiateDQM        = pset.getUntrackedParameter<bool>("runDQM", false);
  
  visualFEDInspect      = pset.getUntrackedParameter<bool>("VisualFEDInspect", false);
  visualFEDShort        = pset.getUntrackedParameter<bool>("VisualFEDShort", false);
  formatedEventDump     = pset.getUntrackedParameter<bool>("FormatedEventDump", false);

  SuppressZeroLCT       = pset.getUntrackedParameter<bool>("SuppressZeroLCT", true);
    


  if(instantiateDQM)  {
    monitor = edm::Service<CSCMonitorInterface>().operator->();
  }
  
  produces<CSCWireDigiCollection>("MuonCSCWireDigi");
  produces<CSCStripDigiCollection>("MuonCSCStripDigi");
  produces<CSCComparatorDigiCollection>("MuonCSCComparatorDigi");
  produces<CSCALCTDigiCollection>("MuonCSCALCTDigi");
  produces<CSCCLCTDigiCollection>("MuonCSCCLCTDigi");
  produces<CSCRPCDigiCollection>("MuonCSCRPCDigi");
  produces<CSCCorrelatedLCTDigiCollection>("MuonCSCCorrelatedLCTDigi");
  
  if (unpackStatusDigis)  {
    produces<CSCCFEBStatusDigiCollection>("MuonCSCCFEBStatusDigi");
    produces<CSCTMBStatusDigiCollection>("MuonCSCTMBStatusDigi");
    produces<CSCDMBStatusDigiCollection>("MuonCSCDMBStatusDigi");
    produces<CSCALCTStatusDigiCollection>("MuonCSCALCTStatusDigi");
    produces<CSCDDUStatusDigiCollection>("MuonCSCDDUStatusDigi");
    produces<CSCDCCStatusDigiCollection>("MuonCSCDCCStatusDigi");
  }

  if (useFormatStatus) {
    produces<CSCDCCFormatStatusDigiCollection>("MuonCSCDCCFormatStatusDigi");
  }
  //CSCAnodeData::setDebug(debug);
  CSCALCTHeader::setDebug(debug);
  CSCCLCTData::setDebug(debug);
  CSCEventData::setDebug(debug);
  CSCTMBData::setDebug(debug);
  CSCDCCEventData::setDebug(debug);
  CSCDDUEventData::setDebug(debug);
  CSCTMBHeader::setDebug(debug);
  CSCRPCData::setDebug(debug);
  CSCDDUEventData::setErrorMask(errorMask);
  
}
CSCDCCUnpacker::~CSCDCCUnpacker ( ) [virtual]

Destructor.

Definition at line 138 of file CSCDCCUnpacker.cc.

                               { 
  //fill destructor here
}

Member Function Documentation

void CSCDCCUnpacker::produce ( edm::Event e,
const edm::EventSetup c 
) [virtual]

Produce digis out of raw data.

access database for mapping

Get a handle to the FED data collection

create the collections of CSC digis

uncomment this for regional unpacking if (id!=SOME_ID) continue;

Take a reference to this FED's data

if fed has data then unpack it

examine event for integrity

Visualization of raw data

get a pointer to data and pass it to constructor for unpacking

get a reference to dduData

set default detid to that for E=+z, S=1, R=1, C=1, L=1

DCC Trailer 2 added to dcc status product (to access TTS from DCC)

skip the DDU if its data has serious errors define a mask for serious errors

DDU Trailer 0 added to ddu status product (to access TTS from DDU)

get a reference to chamber data

first process chamber-wide digis such as LCT

default value for all digis not related to cfebs

layer=0 flags entire chamber

check alct data integrity

fill alct digi

check tmb data integrity

fill correlatedlct and clct digis

fill cscrpc digi

fill cfeb status digi

loop over status digis

fill dmb status digi

fill wire, strip and comparator digis...

set layer, dmb and vme are valid because already checked in line 240

Implements edm::EDProducer.

Definition at line 143 of file CSCDCCUnpacker.cc.

References CastorDataFrameFilter_impl::check(), CSCDCCExaminer::check(), CSCDCCExaminer::crcALCT(), CSCDCCExaminer::crcCFEB(), CSCDCCExaminer::crcTMB(), CSCDetId, FEDRawData::data(), AlCaHLTBitMon_QueryRunRegistry::data, debug, CSCCrateMap::detId(), CSCDCCExaminer::errName(), errorMask, CSCDCCExaminer::errors(), CSCDCCExaminer::errorsDetailed(), CSCDCCExaminer::errorsDetailedDDU(), edm::EventID::event(), examinerMask, formatedEventDump, edm::EventSetup::get(), edm::Event::getByLabel(), CSCDCCExaminer::getMask(), goodEvent, i, edm::EventBase::id(), inputObjectsTag, instantiateDQM, LogTrace, FEDNumbering::MAXCSCFEDID, FEDNumbering::MINCSCFEDID, monitor, CSCDCCExaminer::nERRORS, NULL, numOfEvents, CSCDCCExaminer::output1(), CSCDCCExaminer::output2(), CSCDCCExaminer::payloadDetailed(), printEventNumber, CSCMonitorInterface::process(), edm::ESHandle< T >::product(), edm::Event::put(), lumiPlot::rawdata, DetId::rawId(), edm::EventID::run(), CSCDCCExaminer::setMask(), FEDRawData::size(), CSCDCCExaminer::statusDetailed(), SuppressZeroLCT, unpackStatusDigis, useExaminer, useFormatStatus, useSelectiveUnpacking, visual_raw(), visualFEDInspect, and visualFEDShort.

                                                                {

  // Do we really have to do this every event???
  // ... Yes, because framework is more efficient than you are at caching :)
  // (But if you want to actually DO something specific WHEN the mapping changes, check out ESWatcher)
  edm::ESHandle<CSCCrateMap> hcrate;
  c.get<CSCCrateMapRcd>().get(hcrate); 
  const CSCCrateMap* pcrate = hcrate.product();


  if (printEventNumber) ++numOfEvents;

  edm::Handle<FEDRawDataCollection> rawdata;
  e.getByLabel(inputObjectsTag, rawdata);
    
  std::auto_ptr<CSCWireDigiCollection> wireProduct(new CSCWireDigiCollection);
  std::auto_ptr<CSCStripDigiCollection> stripProduct(new CSCStripDigiCollection);
  std::auto_ptr<CSCALCTDigiCollection> alctProduct(new CSCALCTDigiCollection);
  std::auto_ptr<CSCCLCTDigiCollection> clctProduct(new CSCCLCTDigiCollection);
  std::auto_ptr<CSCComparatorDigiCollection> comparatorProduct(new CSCComparatorDigiCollection);
  std::auto_ptr<CSCRPCDigiCollection> rpcProduct(new CSCRPCDigiCollection);
  std::auto_ptr<CSCCorrelatedLCTDigiCollection> corrlctProduct(new CSCCorrelatedLCTDigiCollection);
  std::auto_ptr<CSCCFEBStatusDigiCollection> cfebStatusProduct(new CSCCFEBStatusDigiCollection);
  std::auto_ptr<CSCDMBStatusDigiCollection> dmbStatusProduct(new CSCDMBStatusDigiCollection);
  std::auto_ptr<CSCTMBStatusDigiCollection> tmbStatusProduct(new CSCTMBStatusDigiCollection);
  std::auto_ptr<CSCDDUStatusDigiCollection> dduStatusProduct(new CSCDDUStatusDigiCollection);
  std::auto_ptr<CSCDCCStatusDigiCollection> dccStatusProduct(new CSCDCCStatusDigiCollection);
  std::auto_ptr<CSCALCTStatusDigiCollection> alctStatusProduct(new CSCALCTStatusDigiCollection);

  std::auto_ptr<CSCDCCFormatStatusDigiCollection> formatStatusProduct(new CSCDCCFormatStatusDigiCollection);
 

  // If set selective unpacking mode 
  // hardcoded examiner mask below to check for DCC and DDU level errors will be used first
  // then examinerMask for CSC level errors will be used during unpacking of each CSC block
  unsigned long dccBinCheckMask = 0x06080016;

  for (int id=FEDNumbering::MINCSCFEDID;
       id<=FEDNumbering::MAXCSCFEDID; ++id) { // loop over DCCs
    
    const FEDRawData& fedData = rawdata->FEDData(id);
    unsigned long length =  fedData.size();
  

    if (length>=32){ 
      CSCDCCExaminer* examiner = NULL;
      std::stringstream examiner_out, examiner_err;
      goodEvent = true;
      if (useExaminer) {
        // CSCDCCExaminer examiner;
        examiner = new CSCDCCExaminer();
        examiner->output1().redirect(examiner_out);
        examiner->output2().redirect(examiner_err);
        if( examinerMask&0x40000 ) examiner->crcCFEB(1);
        if( examinerMask&0x8000  ) examiner->crcTMB (1);
        if( examinerMask&0x0400  ) examiner->crcALCT(1);
        examiner->output1().show();
        examiner->output2().show();
        examiner->setMask(examinerMask);
        const short unsigned int *data = (short unsigned int *)fedData.data();

        LogTrace("badData") << "Length: "<<  length/2;
        // Event data hex dump
        /*
        short unsigned * buf = (short unsigned int *)fedData.data();
          std::cout <<std::endl<<length/2<<" words of data:"<<std::endl;
          for (short unsigned int i=0;i<length/2;i++) {
          printf("%04x %04x %04x %04x\n",buf[i+3],buf[i+2],buf[i+1],buf[i]);
          i+=3;
          }
         */

        int res = examiner->check(data,long(fedData.size()/2));
        if( res < 0 )   {
          goodEvent=false;
        } 
        else {    
          if (useSelectiveUnpacking)  goodEvent=!(examiner->errors()&dccBinCheckMask);
          else goodEvent=!(examiner->errors()&examinerMask);
        }

        /*
         std::cout << "FED" << id << " " << fedData.size() << " " << goodEvent << " " 
        << std::hex << examiner->errors() << std::dec << " " << status << std::endl;
        */

        // Fill Format status digis per FED
        // Remove examiner->errors() != 0 check if we need to put status digis for every event
        if (useFormatStatus && (examiner->errors() !=0))
          // formatStatusProduct->insertDigi(CSCDetId(1,1,1,1,1), CSCDCCFormatStatusDigi(id,examiner,dccBinCheckMask));
          formatStatusProduct->insertDigi(CSCDetId(1,1,1,1,1), 
                CSCDCCFormatStatusDigi(id,dccBinCheckMask,
                        examiner->getMask(), 
                        examiner->errors(),
                        examiner->errorsDetailedDDU(),
                        examiner->errorsDetailed(),
                        examiner->payloadDetailed(),
                        examiner->statusDetailed()));
        }       
     
      if(visualFEDInspect || formatedEventDump){
        if (!goodEvent || formatedEventDump){          
          short unsigned * buf = (short unsigned int *)fedData.data();
          visual_raw(length/2, id,(int)e.id().run(),(int)e.id().event(), 
                     visualFEDShort, formatedEventDump, buf);
        }
      }
                  
      if (goodEvent) {


        CSCDCCExaminer * ptrExaminer = examiner;
        if (!useSelectiveUnpacking) ptrExaminer = NULL;
                
        CSCDCCEventData dccData((short unsigned int *) fedData.data(), ptrExaminer);

        //std::cout << " DCC Size [UNPK] " << dccData.sizeInWords() << std::endl;
        
        if(instantiateDQM) monitor->process(examiner, &dccData);
        
        const std::vector<CSCDDUEventData> & dduData = dccData.dduData();
        
        CSCDetId layer(1, 1, 1, 1, 1);
        
        if (unpackStatusDigis) {

          short unsigned * bufForDcc = (short unsigned int *)fedData.data();
          
          //std::cout << "FED Length: " << std::dec << length/2 << 
          //" Trailer 2: " << std::hex << bufForDcc[length/2-4] << std::endl;
          
          dccStatusProduct->insertDigi(layer, CSCDCCStatusDigi(dccData.dccHeader().data(),
                                                               dccData.dccTrailer().data(),
                                                               examiner->errors(),
                                                               bufForDcc[length/2-4]));
         
        }

        for (unsigned int iDDU=0; iDDU<dduData.size(); ++iDDU) {  // loop over DDUs
          if (dduData[iDDU].trailer().errorstat()&errorMask) {
            LogTrace("CSCDCCUnpacker|CSCRawToDigi") << "DDU# " << iDDU << " has serious error - no digis unpacked! " <<
              std::hex << dduData[iDDU].trailer().errorstat();
            continue; // to next iteration of DDU loop
          }
                
          if (unpackStatusDigis) dduStatusProduct->
                                   insertDigi(layer, CSCDDUStatusDigi(dduData[iDDU].header().data(),
                                                                      dduData[iDDU].trailer().data(),
                                                                      dduData[iDDU].trailer0()));
          
          const std::vector<CSCEventData> & cscData = dduData[iDDU].cscData();


          for (unsigned int iCSC=0; iCSC<cscData.size(); ++iCSC) { // loop over CSCs

            int vmecrate = cscData[iCSC].dmbHeader()->crateID();
            int dmb = cscData[iCSC].dmbHeader()->dmbID();

            int icfeb = 0;  
            int ilayer = 0; 

            if (debug)
              LogTrace ("CSCDCCUnpacker|CSCRawToDigi") << "crate = " << vmecrate << "; dmb = " << dmb;
            
            if ((vmecrate>=1)&&(vmecrate<=60) && (dmb>=1)&&(dmb<=10)&&(dmb!=6)) {
              layer = pcrate->detId(vmecrate, dmb,icfeb,ilayer );
            } 
            else{
              LogTrace ("CSCDCCUnpacker|CSCRawToDigi") << " detID input out of range!!! ";
              LogTrace ("CSCDCCUnpacker|CSCRawToDigi")
                << " skipping chamber vme= " << vmecrate << " dmb= " << dmb;
              continue; // to next iteration of iCSC loop
            }


            int nalct = cscData[iCSC].dmbHeader()->nalct();
            bool goodALCT=false;
            //if (nalct&&(cscData[iCSC].dataPresent>>6&0x1)==1) {
            if (nalct&&cscData[iCSC].alctHeader()) {  
              if (cscData[iCSC].alctHeader()->check()){
                goodALCT=true;
              }
              else {
                LogTrace ("CSCDCCUnpacker|CSCRawToDigi") <<
                  "not storing ALCT digis; alct is bad or not present";
              }
            } else {
              if (debug) LogTrace ("CSCDCCUnpacker|CSCRawToDigi") << "nALCT==0 !!!";
            }

            if (goodALCT){
              std::vector <CSCALCTDigi>  alctDigis =
                cscData[iCSC].alctHeader()->ALCTDigis();
                if(SuppressZeroLCT){
                std::vector<CSCALCTDigi> alctDigis_0;
                  for (int unsigned i=0; i<alctDigis.size(); ++i){
                      if(alctDigis[i].isValid())
                      alctDigis_0.push_back(alctDigis[i]);
                  }
                alctProduct->put(std::make_pair(alctDigis_0.begin(), alctDigis_0.end()),layer);
                }
                else
                alctProduct->put(std::make_pair(alctDigis.begin(), alctDigis.end()),layer);
            }
                    
                  
            int nclct = cscData[iCSC].dmbHeader()->nclct();
            bool goodTMB=false;
            //      if (nclct&&(cscData[iCSC].dataPresent>>5&0x1)==1) {
            if (nclct&&cscData[iCSC].tmbData()) {
              if (cscData[iCSC].tmbHeader()->check()){
                if (cscData[iCSC].clctData()->check()) goodTMB=true; 
              }
              else {
                LogTrace ("CSCDCCUnpacker|CSCRawToDigi") <<
                  "one of TMB checks failed! not storing TMB digis ";
              }
            }
            else {
              if (debug) LogTrace ("CSCDCCUnpacker|CSCRawToDigi") << "nCLCT==0 !!!";
            }
                      
            if (goodTMB) { 
              std::vector <CSCCorrelatedLCTDigi>  correlatedlctDigis =
                cscData[iCSC].tmbHeader()->CorrelatedLCTDigis(layer.rawId());
                if(SuppressZeroLCT){
                  std::vector<CSCCorrelatedLCTDigi> correlatedlctDigis_0;
                    for (int unsigned i=0; i<correlatedlctDigis.size(); ++i){
                      if(correlatedlctDigis[i].isValid())
                    correlatedlctDigis_0.push_back(correlatedlctDigis[i]);
                  }
                corrlctProduct->put(std::make_pair(correlatedlctDigis_0.begin(),
                                                 correlatedlctDigis_0.end()),layer);
                }
                else
                  corrlctProduct->put(std::make_pair(correlatedlctDigis.begin(),
                                                 correlatedlctDigis.end()),layer);
                      
              std::vector <CSCCLCTDigi>  clctDigis =
                cscData[iCSC].tmbHeader()->CLCTDigis(layer.rawId());
                if(SuppressZeroLCT){
                  std::vector<CSCCLCTDigi> clctDigis_0;
                  for (int unsigned i=0; i<clctDigis.size(); ++i){
                    if(clctDigis[i].isValid())
                  clctDigis_0.push_back(clctDigis[i]);
                  }
                clctProduct->put(std::make_pair(clctDigis_0.begin(), clctDigis_0.end()),layer);
                }
                else
                clctProduct->put(std::make_pair(clctDigis.begin(), clctDigis.end()),layer);
                
              if (cscData[iCSC].tmbData()->checkSize()) {
                if (cscData[iCSC].tmbData()->hasRPC()) {
                  std::vector <CSCRPCDigi>  rpcDigis =
                    cscData[iCSC].tmbData()->rpcData()->digis();
                  rpcProduct->put(std::make_pair(rpcDigis.begin(), rpcDigis.end()),layer);
                }
              } 
              else LogTrace("CSCDCCUnpacker|CSCRawToDigi") <<" TMBData check size failed!";
            }
                    
                  
            if (unpackStatusDigis) {
              for ( icfeb = 0; icfeb < 5; ++icfeb ) {
                if ( cscData[iCSC].cfebData(icfeb) != NULL )
                  cfebStatusProduct->
                    insertDigi(layer, cscData[iCSC].cfebData(icfeb)->statusDigi());
              }
              dmbStatusProduct->insertDigi(layer, CSCDMBStatusDigi(cscData[iCSC].dmbHeader()->data(),
                                                                   cscData[iCSC].dmbTrailer()->data()));
              if (goodTMB)  tmbStatusProduct->
                              insertDigi(layer, CSCTMBStatusDigi(cscData[iCSC].tmbHeader()->data(),
                                                                 cscData[iCSC].tmbData()->tmbTrailer()->data()));
              if (goodALCT) alctStatusProduct->
                              insertDigi(layer, CSCALCTStatusDigi(cscData[iCSC].alctHeader()->data(),
                                                                  cscData[iCSC].alctTrailer()->data()));
            }
                

            for (int ilayer = 1; ilayer <= 6; ++ilayer) {
              // (You have to be kidding. Line 240 in whose universe?)

              // Allocate all ME1/1 wire digis to ring 1
              layer = pcrate->detId( vmecrate, dmb, 0, ilayer );

              std::vector <CSCWireDigi> wireDigis =  cscData[iCSC].wireDigis(ilayer);
              
              wireProduct->put(std::make_pair(wireDigis.begin(), wireDigis.end()),layer);
              
              for ( icfeb = 0; icfeb < 5; ++icfeb ) {
                layer = pcrate->detId( vmecrate, dmb, icfeb,ilayer );
                if (cscData[iCSC].cfebData(icfeb)) {
                  std::vector<CSCStripDigi> stripDigis;
                  cscData[iCSC].cfebData(icfeb)->digis(layer.rawId(),stripDigis);
                  stripProduct->put(std::make_pair(stripDigis.begin(), 
                                                   stripDigis.end()),layer);
                }
                              
                if (goodTMB){
                  std::vector <CSCComparatorDigi>  comparatorDigis =
                    cscData[iCSC].clctData()->comparatorDigis(layer.rawId(), icfeb);
                  // Set cfeb=0, so that ME1/a and ME1/b comparators go to
                  // ring 1.
                  layer = pcrate->detId( vmecrate, dmb, 0, ilayer );
                  comparatorProduct->put(std::make_pair(comparatorDigis.begin(), 
                                                        comparatorDigis.end()),layer);
                }
              } // end of loop over cfebs
            } // end of loop over layers
          } // end of loop over chambers
        } // endof loop over DDUs
      } // end of good event
      else   {
        LogTrace("CSCDCCUnpacker|CSCRawToDigi") <<
          "ERROR! Examiner rejected FED #" << id;
        if (examiner) {
          for (int i=0; i<examiner->nERRORS; ++i) {
            if (((examinerMask&examiner->errors())>>i)&0x1)
              LogTrace("CSCDCCUnpacker|CSCRawToDigi")<<examiner->errName(i);
          }
          if (debug) {
            LogTrace("CSCDCCUnpacker|CSCRawToDigi")
              << " Examiner errors:0x" << std::hex << examiner->errors()
              << " & 0x" << examinerMask
              << " = " << (examiner->errors()&examinerMask);
            if (examinerMask&examiner->errors()) {
              LogTrace("CSCDCCUnpacker|CSCRawToDigi")
                << "Examiner output: " << examiner_out.str();
              LogTrace("CSCDCCUnpacker|CSCRawToDigi")
                << "Examiner errors: " << examiner_err.str();
            }
          }
        }

        // dccStatusProduct->insertDigi(CSCDetId(1,1,1,1,1), CSCDCCStatusDigi(examiner->errors()));
        // if(instantiateDQM)  monitor->process(examiner, NULL);
      }
      if (examiner!=NULL) delete examiner;
    } // end of if fed has data
  } // end of loop over DCCs
  // put into the event
  e.put(wireProduct,          "MuonCSCWireDigi");
  e.put(stripProduct,         "MuonCSCStripDigi");
  e.put(alctProduct,          "MuonCSCALCTDigi");
  e.put(clctProduct,          "MuonCSCCLCTDigi");
  e.put(comparatorProduct,    "MuonCSCComparatorDigi");
  e.put(rpcProduct,           "MuonCSCRPCDigi");
  e.put(corrlctProduct,       "MuonCSCCorrelatedLCTDigi");

  if (useFormatStatus)  e.put(formatStatusProduct,    "MuonCSCDCCFormatStatusDigi");

  if (unpackStatusDigis)
    {
      e.put(cfebStatusProduct,    "MuonCSCCFEBStatusDigi");
      e.put(dmbStatusProduct,     "MuonCSCDMBStatusDigi");
      e.put(tmbStatusProduct,     "MuonCSCTMBStatusDigi");
      e.put(dduStatusProduct,     "MuonCSCDDUStatusDigi");
      e.put(dccStatusProduct,     "MuonCSCDCCStatusDigi");
      e.put(alctStatusProduct,    "MuonCSCALCTStatusDigi");
    }
  if (printEventNumber) LogTrace("CSCDCCUnpacker|CSCRawToDigi") 
   <<"[CSCDCCUnpacker]: " << numOfEvents << " events processed ";
}
void CSCDCCUnpacker::visual_raw ( int  hl,
int  id,
int  run,
int  event,
bool  fedshort,
bool  fDump,
short unsigned int *  buf 
) const

Visualization of raw data in FED-less events (Robert Harr and Alexander Sakharov)

Visualization of raw data.

Definition at line 535 of file CSCDCCUnpacker.cc.

References gather_cfg::cout, formatedEventDump, i, j, gen::k, and w().

Referenced by produce().

                                                                            {

        std::cout << std::endl << std::endl << std::endl;
        std::cout << "Run: "<< run << " Event: " << event << std::endl;
        std::cout << std::endl << std::endl;
        if(formatedEventDump)
           std::cout << "FED-" << id << "  " << "(scroll down to see summary)" << std::endl;
        else
           std::cout << "Problem seems in FED-" << id << "  " << "(scroll down to see summary)" << std::endl;
        std::cout <<"********************************************************************************" << std::endl;
        std::cout << hl <<" words of data:" << std::endl;
        
        //================================================
        // FED codes in DCC
        std::vector<int> dcc_id;
        int dcc_h1_id=0;
        // Current codes
        for (int i=750;i<758;i++)
            dcc_id.push_back(i);
        // Codes for upgrade    
         for (int i=830;i<838;i++)
            dcc_id.push_back(i);
        
        char dcc_common[]="DCC-";    

        //================================================
        // DDU codes per FED
        std::vector<int> ddu_id;
        int ddu_h1_12_13=0;
        for (int i=1;i<37;i++)
            ddu_id.push_back(i);
        // For DDU Headers and tarailers
        char ddu_common[]="DDU-";
        char ddu_header1[]="Header 1";
        char ddu_header2[]="Header 2";
        char ddu_header3[]="Header 3";
        char ddu_trail1[]="Trailer 1", ddu_trail2[]="Trailer 2", ddu_trail3[]="Trailer 3";
        // For Header 2
        char ddu_trailer1_bit[]={'8','0','0','0','f','f','f','f','8','0','0','0','8','0','0','0'};
        char ddu_trailer3_bit[]={'a'};
        // Corrupted Trailers
        char ddu_tr1_err_common[]="Incomplet";
        //====================================================
        
        //DMB
        char dmb_common[]="DMB", dmb_header1[]="Header 1", dmb_header2[]="Header 2";
        char dmb_common_crate[]="crate:", dmb_common_slot[]="slot:"; 
        char dmb_common_l1a[]="L1A:";
        char dmb_header1_bit[]={'9','9','9','9'};
        char dmb_header2_bit[]={'a','a','a','a'};
        char dmb_tr1[]="Trailer 1", dmb_tr2[]="Trailer 2";
        char dmb_tr1_bit[]={'f','f','f','f'}, dmb_tr2_bit[]={'e','e','e','e'};
        
        
        //=====================================================
        
        // ALCT
        char alct_common[]="ALCT", alct_header1[]="Header 1", alct_header2[]="Header 2";
        char alct_common_bxn[]="BXN:";
        char alct_common_wcnt2[]="| Actual word count:"; 
        char alct_common_wcnt1[]="Expected word count:";
        char alct_header1_bit[]={'d','d','d','d','b','0','a'};
        char alct_header2_bit[]={'0','0','0','0'};
        char alct_tr1[]="Trailer 1"; 
        
        //======================================================

        //TMB
        char tmb_common[]="TMB", tmb_header1[]="Header", tmb_tr1[]="Trailer";
        char tmb_header1_bit[]={'d','d','d','d','b','0','c'};
        char tmb_tr1_bit[]={'d','d','d','d','e','0','f'};
        
        //======================================================
        
        //CFEB 
        char cfeb_common[]="CFEB", cfeb_tr1[]="Trailer", cfeb_b[]="B-word";
        char cfeb_common_sample[]="sample:";
        
        //======================================================        
        
        //Auxiliary variables 
        
        // Bufers
        int word_lines=hl/4;
        char tempbuf[80];
        char tempbuf1[80];
        char tempbuf_short[17];
        char sign1[]="  --->| ";
        
        // Counters
        int word_numbering=0;
        int ddu_inst_i=0, ddu_inst_n=0, ddu_inst_l1a=0;
        int ddu_inst_bxn=0;
        int dmb_inst_crate=0, dmb_inst_slot=0, dmb_inst_l1a=0;
        int cfeb_sample=0;
        int alct_inst_l1a=0;
        int alct_inst_bxn=0;
        int alct_inst_wcnt1=0;
        int alct_inst_wcnt2=0;
        int alct_start=0;
        int alct_stop=0;
        int tmb_inst_l1a=0;
        int tmb_inst_wcnt1=0;
        int tmb_inst_wcnt2=0;
        int tmb_start=0;
        int tmb_stop=0;
        int dcc_h1_check=0;
        
        //Flags
        int ddu_h2_found=0;  //DDU Header 2 found
        int w=0;
        
        //Logic variables
        const int sz1=5;
        bool dcc_check=false;
        bool ddu_h2_check[sz1]={false};
        bool ddu_h1_check=false;
        bool dmb_h1_check[sz1]={false};
        bool dmb_h2_check[sz1]={false};
        bool ddu_h2_h1=false;
        bool ddu_tr1_check[sz1]={false};
        bool alct_h1_check[sz1]={false};
        bool alct_h2_check[sz1]={false};
        bool alct_tr1_check[sz1]={false};
        bool dmb_tr1_check[sz1]={false};
        bool dmb_tr2_check[sz1]={false};
        bool tmb_h1_check[sz1]={false};
        bool tmb_tr1_check[sz1]={false};
        bool cfeb_tr1_check[sz1]={false};
        bool cfeb_b_check[sz1]={false};
        bool ddu_tr1_bad_check[sz1]={false};
        bool extraction=fedshort;
        
        //Summary vectors
        //DDU
        std::vector<int> ddu_h1_coll;
        std::vector<int> ddu_h1_n_coll;
        std::vector<int> ddu_h2_coll;
        std::vector<int> ddu_h3_coll;
        std::vector<int> ddu_t1_coll;
        std::vector<int> ddu_t2_coll;
        std::vector<int> ddu_t3_coll;
        std::vector<int> ddu_l1a_coll;
        std::vector<int> ddu_bxn_coll;
        //DMB
        std::vector<int> dmb_h1_coll;
        std::vector<int> dmb_h2_coll;
        std::vector<int> dmb_t1_coll;
        std::vector<int> dmb_t2_coll;
        std::vector<int> dmb_crate_coll;
        std::vector<int> dmb_slot_coll;
        std::vector<int> dmb_l1a_coll;
        //ALCT
        std::vector<int> alct_h1_coll;
        std::vector<int> alct_h2_coll;
        std::vector<int> alct_t1_coll;
        std::vector<int> alct_l1a_coll;
        std::vector<int> alct_bxn_coll;
        std::vector<int> alct_wcnt1_coll;
        std::vector<int> alct_wcnt2_coll;
        std::vector<int> alct_wcnt2_id_coll;
        //TMB
        std::vector<int> tmb_h1_coll;
        std::vector<int> tmb_t1_coll;
        std::vector<int> tmb_l1a_coll;
        std::vector<int> tmb_wcnt1_coll;
        std::vector<int> tmb_wcnt2_coll;
        //CFEB
        std::vector<int> cfeb_t1_coll;
        
        //========================================================
        
        // DCC Header and Ttrailer information
        char dcc_header1[]="DCC Header 1";
        char dcc_header2[]="DCC Header 2";
        char dcc_trail1[]="DCC Trailer 1", dcc_trail1_bit[]={'e'};
        char dcc_trail2[]="DCC Trailer 2", dcc_trail2_bit[]={'a'};
        //=========================================================
        
        for (int i=0;i < hl; i++) {
        ++word_numbering;
          for(int j=-1; j<4; j++){
               
               sprintf(tempbuf_short,"%04x%04x%04x%04x",buf[i+4*(j-1)+3],buf[i+4*(j-1)+2],buf[i+4*(j-1)+1],buf[i+4*(j-1)]);

               // WARNING in 5_0_X for time being
               ddu_h2_found++; ddu_h2_found--;
                
                ddu_h2_check[j]=((buf[i+4*(j-1)+1]==0x8000)&&
                                 (buf[i+4*(j-1)+2]==0x0001)&&(buf[i+4*(j-1)+3]==0x8000));
                 
                 ddu_tr1_check[j]=((tempbuf_short[0]==ddu_trailer1_bit[0])&&(tempbuf_short[1]==ddu_trailer1_bit[1])&&
                                  (tempbuf_short[2]==ddu_trailer1_bit[2])&&(tempbuf_short[3]==ddu_trailer1_bit[3])&&
                                  (tempbuf_short[4]==ddu_trailer1_bit[4])&&(tempbuf_short[5]==ddu_trailer1_bit[5])&&
                                  (tempbuf_short[6]==ddu_trailer1_bit[6])&&(tempbuf_short[7]==ddu_trailer1_bit[7])&&
                                  (tempbuf_short[8]==ddu_trailer1_bit[8])&&(tempbuf_short[9]==ddu_trailer1_bit[9])&&
                                  (tempbuf_short[10]==ddu_trailer1_bit[10])&&(tempbuf_short[11]==ddu_trailer1_bit[11])&&
                                  (tempbuf_short[12]==ddu_trailer1_bit[12])&&(tempbuf_short[13]==ddu_trailer1_bit[13])&&
                                  (tempbuf_short[14]==ddu_trailer1_bit[14])&&(tempbuf_short[15]==ddu_trailer1_bit[15]));
                 
                 dmb_h1_check[j]=((tempbuf_short[0]==dmb_header1_bit[0])&&(tempbuf_short[4]==dmb_header1_bit[1])&&
                                 (tempbuf_short[8]==dmb_header1_bit[2])&&(tempbuf_short[12]==dmb_header1_bit[3]));
                
                 dmb_h2_check[j]=((tempbuf_short[0]==dmb_header2_bit[0])&&(tempbuf_short[4]==dmb_header2_bit[1])&&
                                 (tempbuf_short[8]==dmb_header2_bit[2])&&(tempbuf_short[12]==dmb_header2_bit[3]));
                 alct_h1_check[j]=((tempbuf_short[0]==alct_header1_bit[0])&&(tempbuf_short[4]==alct_header1_bit[1])&&
                                 (tempbuf_short[8]==alct_header1_bit[2])&&(tempbuf_short[12]==alct_header1_bit[3])&&
                                 (tempbuf_short[13]==alct_header1_bit[4])&&(tempbuf_short[14]==alct_header1_bit[5])&&
                                 (tempbuf_short[15]==alct_header1_bit[6]));              
                 alct_h2_check[j]=(((tempbuf_short[0]==alct_header2_bit[0])&&(tempbuf_short[1]==alct_header2_bit[1])&&
                                 (tempbuf_short[2]==alct_header2_bit[2])&&(tempbuf_short[3]==alct_header2_bit[3]))||
                                 ((tempbuf_short[4]==alct_header2_bit[0])&&(tempbuf_short[5]==alct_header2_bit[1])&&
                                 (tempbuf_short[6]==alct_header2_bit[2])&&(tempbuf_short[7]==alct_header2_bit[3]))||
                                 ((tempbuf_short[8]==alct_header2_bit[0])&&(tempbuf_short[9]==alct_header2_bit[1])&&
                                 (tempbuf_short[10]==alct_header2_bit[2])&&(tempbuf_short[11]==alct_header2_bit[3]))||
                                 ((tempbuf_short[12]==alct_header2_bit[0])&&(tempbuf_short[13]==alct_header2_bit[1])&&
                                 (tempbuf_short[14]==alct_header2_bit[2])&&(tempbuf_short[15]==alct_header2_bit[3]))
                                 //(tempbuf_short[4]==alct_header2_bit[4])&&(tempbuf_short[5]==alct_header2_bit[5])
                                 );
                                 // ALCT Trailers
                alct_tr1_check[j]=(((buf[i+4*(j-1)]&0xFFFF)==0xDE0D)&&((buf[i+4*(j-1)+1]&0xF800)==0xD000)&&
                                 ((buf[i+4*(j-1)+2]&0xF800)==0xD000)&&((buf[i+4*(j-1)+3]&0xF000)==0xD000));
                                 // DMB Trailers
                 dmb_tr1_check[j]=((tempbuf_short[0]==dmb_tr1_bit[0])&&(tempbuf_short[4]==dmb_tr1_bit[1])&&
                                 (tempbuf_short[8]==dmb_tr1_bit[2])&&(tempbuf_short[12]==dmb_tr1_bit[3]));
                 dmb_tr2_check[j]=((tempbuf_short[0]==dmb_tr2_bit[0])&&(tempbuf_short[4]==dmb_tr2_bit[1])&&
                                 (tempbuf_short[8]==dmb_tr2_bit[2])&&(tempbuf_short[12]==dmb_tr2_bit[3]));
                                 // TMB
                 tmb_h1_check[j]=((tempbuf_short[0]==tmb_header1_bit[0])&&(tempbuf_short[4]==tmb_header1_bit[1])&&
                                 (tempbuf_short[8]==tmb_header1_bit[2])&&(tempbuf_short[12]==tmb_header1_bit[3])&&
                                 (tempbuf_short[13]==tmb_header1_bit[4])&&(tempbuf_short[14]==tmb_header1_bit[5])&&
                                 (tempbuf_short[15]==tmb_header1_bit[6]));
                 tmb_tr1_check[j]=((tempbuf_short[0]==tmb_tr1_bit[0])&&(tempbuf_short[4]==tmb_tr1_bit[1])&&
                                 (tempbuf_short[8]==tmb_tr1_bit[2])&&(tempbuf_short[12]==tmb_tr1_bit[3])&&
                                 (tempbuf_short[13]==tmb_tr1_bit[4])&&(tempbuf_short[14]==tmb_tr1_bit[5])&&
                                 (tempbuf_short[15]==tmb_tr1_bit[6]));
                                 // CFEB
                 cfeb_tr1_check[j]=(((buf[i+4*(j-1)+1]&0xF000)==0x7000) &&  
                     ((buf[i+4*(j-1)+2]&0xF000)==0x7000) && 
                     (( buf[i+4*(j-1)+1]!= 0x7FFF) || (buf[i+4*(j-1)+2] != 0x7FFF)) &&
                     ((buf[i+4*(j-1)+3] == 0x7FFF) ||   
                     ((buf[i+4*(j-1)+3]&buf[i+4*(j-1)]) == 0x0&&(buf[i+4*(j-1)+3] + buf[i+4*(j-1)] == 0x7FFF ))) );
                 cfeb_b_check[j]=(((buf[i+4*(j-1)+3]&0xF000)==0xB000)&&((buf[i+4*(j-1)+2]&0xF000)==0xB000) && 
                                 ((buf[i+4*(j-1)+1]&0xF000)==0xB000)&&((buf[i+4*(j-1)]=3&0xF000)==0xB000) );   
                                 // DDU Trailers with errors
                 ddu_tr1_bad_check[j]=((tempbuf_short[0]!=ddu_trailer1_bit[0])&&
                                 //(tempbuf_short[1]!=ddu_trailer1_bit[1])&&(tempbuf_short[2]!=ddu_trailer1_bit[2])&&
                                 //(tempbuf_short[3]==ddu_trailer1_bit[3])&&
                                 (tempbuf_short[4]!=ddu_trailer1_bit[4])&&
                                 //(tempbuf_short[5]==ddu_trailer1_bit[5])&&
                                 //(tempbuf_short[6]==ddu_trailer1_bit[6])&&(tempbuf_short[7]==ddu_trailer1_bit[7])&&
                                 (tempbuf_short[8]==ddu_trailer1_bit[8])&&(tempbuf_short[9]==ddu_trailer1_bit[9])&&
                                 (tempbuf_short[10]==ddu_trailer1_bit[10])&&(tempbuf_short[11]==ddu_trailer1_bit[11])&&
                                 (tempbuf_short[12]==ddu_trailer1_bit[12])&&(tempbuf_short[13]==ddu_trailer1_bit[13])&&
                                 (tempbuf_short[14]==ddu_trailer1_bit[14])&&(tempbuf_short[15]==ddu_trailer1_bit[15])); 
          }

          // DDU Header 2 next to Header 1
          ddu_h2_h1=ddu_h2_check[2];
          
          sprintf(tempbuf_short,"%04x%04x%04x%04x",buf[i+3],buf[i+2],buf[i+1],buf[i]);
           
          // Looking for DDU Header 1
          ddu_h1_12_13=(buf[i]>>8);
          for (int kk=0; kk<36; kk++){        
              if(((buf[i+3]&0xF000)==0x5000)&&(ddu_h1_12_13==ddu_id[kk])&&ddu_h2_h1){
                ddu_h1_coll.push_back(word_numbering); ddu_h1_n_coll.push_back(ddu_id[kk]);
                ddu_inst_l1a=((buf[i+2]&0xFFFF)+((buf[i+3]&0x00FF)<<16));
                ddu_l1a_coll.push_back(ddu_inst_l1a);
                ddu_inst_bxn=(buf[i+1]&0xFFF0)>>4;
                ddu_bxn_coll.push_back(ddu_inst_bxn);
                sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s%s %s %i %s %i",
                word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                sign1,ddu_common,ddu_id[kk],ddu_header1,sign1,dmb_common_l1a,ddu_inst_l1a,alct_common_bxn,ddu_inst_bxn);
                std::cout << tempbuf1 << std::endl; w=0; ddu_h1_check=true; ddu_inst_l1a=0; 
                cfeb_sample=0;
              }
          }

                 

         // Looking for DCC Header 1
         dcc_h1_id=(((buf[i+1]<<12)&0xF000)>>4)+(buf[i]>>8);
         for(int dcci=0;dcci<16;dcci++){
                 if((dcc_id[dcci]==dcc_h1_id)&&(((buf[i+3]&0xF000)==0x5000)&&(!ddu_h1_check))){
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,dcc_common,dcc_h1_id,dcc_header1); dcc_h1_check=word_numbering; w=0;
                 dcc_check=true; 
                 std::cout << tempbuf1 << std::endl;
                 } 
             }      

          // Looking for DCC Header 2 and trailers
          if(((word_numbering-1)==dcc_h1_check)&&((buf[i+3]&0xFF00)==0xD900)) {
             sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
             sign1,dcc_header2);
             std::cout << tempbuf1 << std::endl; w=0; 
             }
          else if((word_numbering==word_lines-1)&&(tempbuf_short[0]==dcc_trail1_bit[0])){
             sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
             sign1,dcc_trail1);
             std::cout << tempbuf1 << std::endl; w=0;
               }
          else if((word_numbering==word_lines)&&(tempbuf_short[0]==dcc_trail2_bit[0])){
             sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
             sign1,dcc_trail2);
             std::cout << tempbuf1 << std::endl; w=0;
               }

             // DDU Header 2
          else if(ddu_h2_check[1]){
               ddu_inst_i = ddu_h1_n_coll.size(); //ddu_inst_n=ddu_h1_n_coll[0];
               if(ddu_inst_i>0){ 
                 ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
               }
               sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",
               word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,ddu_common,
               ddu_inst_n, ddu_header2);
               ddu_h2_coll.push_back(word_numbering);
               std::cout << tempbuf1 << std::endl; w=0;
               ddu_h2_found=1;
               }
               
             // DDU Header 3 (either between DDU Header 2 DMB Header or DDU Header 2 DDU Trailer1)  
          else if((ddu_h2_check[0]&&dmb_h1_check[2])||(ddu_h2_check[0]&&ddu_tr1_check[2])){
             ddu_inst_i = ddu_h1_n_coll.size(); 
             if(ddu_inst_i>0){ 
                 ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
               }
             sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
             sign1,ddu_common,ddu_inst_n,ddu_header3);
             ddu_h3_coll.push_back(word_numbering);
             std::cout << tempbuf1 << std::endl; w=0;
             ddu_h2_found=0;
             }
             
             // DMB Header 1,2
             
            else if(dmb_h1_check[1]){
                 dmb_inst_crate=0; dmb_inst_slot=0; dmb_inst_l1a=0;
                 dmb_inst_l1a=((buf[i]&0x0FFF)+((buf[i+1]&0xFFF)<<12));
                 dmb_l1a_coll.push_back(dmb_inst_l1a);
               if(dmb_h2_check[2]){
                 dmb_inst_crate=((buf[i+4+1]>>4)&0xFF); dmb_inst_slot=(buf[i+4+1]&0xF);
                 dmb_crate_coll.push_back(dmb_inst_crate); dmb_slot_coll.push_back(dmb_inst_slot);
               }
               sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i %s %i %s %i",
               word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
               sign1,dmb_common,dmb_header1,sign1,dmb_common_crate,dmb_inst_crate,
               dmb_common_slot,dmb_inst_slot,dmb_common_l1a,dmb_inst_l1a);
               dmb_h1_coll.push_back(word_numbering);
               std::cout << tempbuf1 << std::endl; w=0;
               ddu_h2_found=1;
               }
               
            else if(dmb_h2_check[1]){            
               dmb_inst_crate=((buf[i+1]>>4)&0xFF); dmb_inst_slot=(buf[i+1]&0xF);
               dmb_h2_coll.push_back(word_numbering);
               if(dmb_h1_check[0])
                  dmb_inst_l1a=((buf[i-4]&0x0FFF)+((buf[i-4+1]&0xFFF)<<12));
               sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i %s %i %s %i",
               word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
               sign1,dmb_common,dmb_header2,sign1,dmb_common_crate,dmb_inst_crate,
               dmb_common_slot,dmb_inst_slot,dmb_common_l1a,dmb_inst_l1a);
               std::cout << tempbuf1 << std::endl; w=0;
               ddu_h2_found=1;
               }
               
             //DDU Trailer 1

           else if(ddu_tr1_check[1]){
                 ddu_inst_i = ddu_h1_n_coll.size(); 
                 if(ddu_inst_i>0){ 
                    ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                  }
                 //ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,ddu_common,ddu_inst_n,ddu_trail1); 
                 ddu_t1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 }

                 //ALCT Header 1,2              
          else if(alct_h1_check[1]){
                 alct_start=word_numbering;
                 alct_inst_l1a=(buf[i+2]&0x0FFF);
                 alct_l1a_coll.push_back(alct_inst_l1a);
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s %s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,alct_common,alct_header1,sign1,dmb_common_l1a,alct_inst_l1a);
                 alct_h1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0; alct_inst_l1a=0;
                 }
                 
          else if((alct_h1_check[0])&&(alct_h2_check[2])) {
                 alct_inst_bxn=(buf[i]&0x0FFF);
                 alct_bxn_coll.push_back(alct_inst_bxn);
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,alct_common,alct_header2,sign1,alct_common_bxn,alct_inst_bxn);
                 alct_h2_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0; alct_inst_bxn=0;
                 } 
                 
                 //ALCT Trailer 1
          else if(alct_tr1_check[1]){
                 alct_stop=word_numbering;
                 if((alct_start!=0)&&(alct_stop!=0)&&(alct_stop>alct_start)) {
                        alct_inst_wcnt2=4*(alct_stop-alct_start+1);
                        alct_wcnt2_coll.push_back(alct_inst_wcnt2);
                        alct_wcnt2_id_coll.push_back(alct_start);
                        }
                 alct_inst_wcnt1=(buf[i+3]&0x7FF);
                 alct_wcnt1_coll.push_back(alct_inst_wcnt1);
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i %s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,alct_common,alct_tr1,sign1,alct_common_wcnt1,alct_inst_wcnt1,
                 alct_common_wcnt2,alct_inst_wcnt2);
                 alct_t1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0; alct_inst_wcnt1=0;
                 alct_inst_wcnt2=0;  
                 }
                 
                 //DDU Trailer 3
          else if((ddu_tr1_check[-1])&&(tempbuf_short[0]==ddu_trailer3_bit[0])){
          //&&(tempbuf_short[0]==ddu_trailer3_bit[0])){
                 ddu_inst_i = ddu_h1_n_coll.size();
                 if(ddu_inst_i>0){ 
                    ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                 } 
                 //ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];         
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,ddu_common,ddu_inst_n,ddu_trail3);
                 ddu_t3_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 }
                 //DDU Trailer 2
          else if((ddu_tr1_check[0])&&(tempbuf_short[0]!=ddu_trailer3_bit[0])){
          //&&(tempbuf_short[0]==ddu_trailer3_bit[0])){
                 ddu_inst_i = ddu_h1_n_coll.size(); 
                 if(ddu_inst_i>0){ 
                   ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                 }
                 //ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,ddu_common,ddu_inst_n,ddu_trail2);
                 ddu_t2_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 } 

                 //DMB Trailer 1,2
         else if(dmb_tr1_check[1]){
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,dmb_common,dmb_tr1);
                 dmb_t1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 cfeb_sample=0;
                 }
                 
         else if(dmb_tr2_check[1]){
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,dmb_common,dmb_tr2);
                 dmb_t2_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 }       
         // TMB  
         else if(tmb_h1_check[1]){
                 tmb_start=word_numbering;
                 tmb_inst_l1a=(buf[i+2]&0x000F);
                 tmb_l1a_coll.push_back(tmb_inst_l1a);
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,tmb_common,tmb_header1,
                 sign1,dmb_common_l1a,tmb_inst_l1a);
                 tmb_h1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0; tmb_inst_l1a=0; 
                 }
         else if(tmb_tr1_check[1]){
                 tmb_stop=word_numbering;
                 if((tmb_start!=0)&&(tmb_stop!=0)&&(tmb_stop>tmb_start)) {
                        tmb_inst_wcnt2=4*(tmb_stop-tmb_start+1);
                        tmb_wcnt2_coll.push_back(tmb_inst_wcnt2);
                        }
                 tmb_inst_wcnt1=(buf[i+3]&0x7FF);
                 tmb_wcnt1_coll.push_back(tmb_inst_wcnt1);
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s%s %i %s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,tmb_common,tmb_tr1,sign1,alct_common_wcnt1,tmb_inst_wcnt1,
                 alct_common_wcnt2,tmb_inst_wcnt2);
                 tmb_t1_coll.push_back(word_numbering);
                 std::cout << tempbuf1 << std::endl; w=0;
                 tmb_inst_wcnt2=0;
                 }
         // CFEB
         else if(cfeb_tr1_check[1]){
                 ++cfeb_sample;
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s%s %s %i",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],
                 sign1,cfeb_common,cfeb_tr1,sign1,cfeb_common_sample,cfeb_sample);
                 cfeb_t1_coll.push_back(word_numbering); w=0;
                 std::cout << tempbuf1 << std::endl; w=0;
                 }
        else if(cfeb_b_check[1]){
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,cfeb_common,cfeb_b);
                 std::cout << tempbuf1 << std::endl; w=0;
                 }                

        //ERRORS ddu_tr1_bad_check
                 
        else if(ddu_tr1_bad_check[1]){
                 ddu_inst_i = ddu_h1_n_coll.size(); ddu_inst_n=ddu_h1_n_coll[ddu_inst_i-1];
                 sprintf(tempbuf1,"%6i    %04x %04x %04x %04x%s%s%i %s %s",
                 word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i],sign1,ddu_common,ddu_inst_n,
                 ddu_trail1,ddu_tr1_err_common);
                 std::cout << tempbuf1 << std::endl; w=0;
                 }        
        
         else if(extraction&&(!ddu_h1_check)&&(!dcc_check)){
              if(w<3){
              sprintf(tempbuf,"%6i    %04x %04x %04x %04x",
              word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i]);
              std::cout << tempbuf << std::endl; w++;}
              if(w==3){
              std::cout << "..................................................." << std::endl; w++;}
          }       
                  
          else if((!ddu_h1_check)&&(!dcc_check)){   
          sprintf(tempbuf,"%6i    %04x %04x %04x %04x",word_numbering,buf[i+3],buf[i+2],buf[i+1],buf[i]);
          std::cout << tempbuf << std::endl;
          }
          
          i+=3; ddu_h1_check=false; dcc_check=false; 
      }
        //char sign[30]; //WARNING 5_0_X 
        std::cout <<"********************************************************************************" <<
         std::endl << std::endl;
        if(fedshort)
        std::cout << "For complete output turn off VisualFEDShort in muonCSCDigis configuration file." << std::endl;
        std::cout <<"********************************************************************************" <<
         std::endl << std::endl;
        std::cout << std::endl << std::endl; 
        std::cout <<"            Summary                " << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_h1_coll.size() <<"  "<< ddu_common << "  "<<ddu_header1 << "  "<< "found" << std::endl;
        /*
        std::cout << ddu_h1_coll.size() << " " << ddu_h1_n_coll.size() << " " << ddu_l1a_coll.size() <<
        " " << ddu_bxn_coll.size() << std::endl;        
        */
        for(unsigned int k=0; k<ddu_h1_coll.size();++k){
           /*
           sprintf(sign,"%s%6i%5s %s%i %s %i %s %i","Line: ",
           ddu_h1_coll[k],sign1,ddu_common,ddu_h1_n_coll[k],dmb_common_l1a,ddu_l1a_coll[k],
           alct_common_bxn,ddu_bxn_coll[k]);
           */
           std::cout << "Line: " << "    " << ddu_h1_coll[k] << " " << sign1 << " " << 
           ddu_common << " " << ddu_h1_n_coll[k] << " " << dmb_common_l1a << " " << ddu_l1a_coll[k] << " " << 
           alct_common_bxn << " " << ddu_bxn_coll[k] << std::endl;
        }

                       
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_h2_coll.size() <<"  "<< ddu_common << "  "<<ddu_header2 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<ddu_h2_coll.size();++k)
           std::cout << "Line:  " << ddu_h2_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_h3_coll.size() <<"  "<< ddu_common << "  "<<ddu_header3 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<ddu_h3_coll.size();++k)
           std::cout << "Line:  " << ddu_h3_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_t1_coll.size() <<"  "<< ddu_common << "  "<<ddu_trail1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<ddu_t1_coll.size();++k)
           std::cout << "Line:  " << ddu_t1_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_t2_coll.size() <<"  "<< ddu_common << "  "<<ddu_trail2 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<ddu_t2_coll.size();++k)
           std::cout << "Line:  " << ddu_t2_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << ddu_t3_coll.size() <<"  "<< ddu_common << "  "<<ddu_trail3 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<ddu_t3_coll.size();++k)
           std::cout << "Line:  " << ddu_t3_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << dmb_h1_coll.size() <<"  "<< dmb_common << "  "<<dmb_header1 << "  "<< "found" << std::endl;

        for(unsigned int k=0; k<dmb_h1_coll.size();++k){
           /*
           sprintf(sign,"%s%6i%5s %s %s %i %s %i %s %i","Line: ",
           dmb_h1_coll[k],sign1,dmb_common,dmb_common_crate,dmb_crate_coll[k],dmb_common_slot,
           dmb_slot_coll[k],dmb_common_l1a,dmb_l1a_coll[k]);
           */
           std::cout << "Line: " << "    " << dmb_h1_coll[k] << " " << sign1 << dmb_common 
           << " " << dmb_common_crate << " " << dmb_crate_coll[k] << " " << dmb_common_slot << " " << 
           dmb_slot_coll[k] << " " << dmb_common_l1a << " " << dmb_l1a_coll[k] << std::endl;
           }
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << dmb_h2_coll.size() <<"  "<< dmb_common << "  "<<dmb_header2 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<dmb_h2_coll.size();++k)
           std::cout << "Line:  " << dmb_h2_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << dmb_t1_coll.size() <<"  "<< dmb_common << "  "<<dmb_tr1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<dmb_t1_coll.size();++k)
           std::cout << "Line:  " << dmb_t1_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << dmb_t2_coll.size() <<"  "<< dmb_common << "  "<<dmb_tr2 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<dmb_t2_coll.size();++k)
           std::cout << "Line:  " << dmb_t2_coll[k] << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << alct_h1_coll.size() <<"  "<< alct_common << "  "<<alct_header1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<alct_h1_coll.size();++k){
           /*
           sprintf(sign,"%s%6i%5s %s %s %i","Line: ",
           alct_h1_coll[k],sign1,alct_common,
           dmb_common_l1a,alct_l1a_coll[k]);
           std::cout << sign << std::endl;
           */
           std::cout << "Line: " << "    " <<
           alct_h1_coll[k] << " " << sign1 << " " << alct_common << " " << 
           dmb_common_l1a << " " << alct_l1a_coll[k] << std::endl;
           }

        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << alct_h2_coll.size() <<"  "<< alct_common << "  "<<alct_header2 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<alct_h2_coll.size();++k){
           /*
           sprintf(sign,"%s%6i%5s %s %s %i","Line: ",
           alct_h1_coll[k],sign1,alct_common,
           alct_common_bxn,alct_bxn_coll[k]);
           std::cout << sign << std::endl;
           */
           std::cout << "Line: " << "    " <<
           alct_h1_coll[k] << " " << sign1 << " " << alct_common << " " << 
           alct_common_bxn << " " << alct_bxn_coll[k] << std::endl;
           }

        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << alct_t1_coll.size() <<"  "<< alct_common << "  "<<alct_tr1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<alct_t1_coll.size();++k){
         /*
                sprintf(sign,"%s%6i%5s %s %s %i %s %i","Line: ",
                alct_t1_coll[k],sign1,alct_common,
                alct_common_wcnt1,alct_wcnt1_coll[k],alct_common_wcnt2,alct_wcnt2_coll[k]);
                std::cout << sign << std::endl;
          */
           std::cout << "Line: " << "    " << alct_t1_coll[k] << " " << sign1 << " " << alct_common << " " << 
                alct_common_wcnt1 << " " << alct_wcnt1_coll[k] << " " << alct_common_wcnt2 << " " << 
                alct_wcnt2_coll[k] << std::endl;
           }
           
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << tmb_h1_coll.size() <<"  "<< tmb_common << "  "<<tmb_header1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<tmb_h1_coll.size();++k){
           /*
           sprintf(sign,"%s%6i%5s %s %s %i","Line: ",
           tmb_h1_coll[k],sign1,tmb_common,
           dmb_common_l1a,tmb_l1a_coll[k]);
           std::cout << sign << std::endl;
           */
           std::cout << "Line: " << "    " << tmb_h1_coll[k] << " " << sign1 << " " << tmb_common << " " << 
           dmb_common_l1a << " " << tmb_l1a_coll[k] << std::endl;
        }   

        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << tmb_t1_coll.size() <<"  "<< tmb_common << "  "<<tmb_tr1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<tmb_t1_coll.size();++k){
                /*
                sprintf(sign,"%s%6i%5s %s %s %i %s %i","Line: ",
                tmb_t1_coll[k],sign1,tmb_common,
                alct_common_wcnt1,tmb_wcnt1_coll[k],alct_common_wcnt2,tmb_wcnt2_coll[k]);                
           std::cout << sign << std::endl;
           */
           std::cout << "Line: " << "    " << tmb_t1_coll[k] << " " << sign1 << " " << tmb_common << " " << 
                alct_common_wcnt1 << " " << tmb_wcnt1_coll[k] << " " << alct_common_wcnt2 << " " << tmb_wcnt2_coll[k]
                << std::endl;
           }
         
        
        std::cout << std::endl << std::endl;
        std::cout << "||||||||||||||||||||" << std::endl;
        std::cout << std::endl << std::endl;
        std::cout << cfeb_t1_coll.size() <<"  "<< cfeb_common << "  "<<cfeb_tr1 << "  "<< "found" << std::endl;
        for(unsigned int k=0; k<cfeb_t1_coll.size();++k)
           std::cout << "Line:  " << cfeb_t1_coll[k] << std::endl;
         std::cout <<"********************************************************************************" << std::endl;
        
}

Member Data Documentation

bool CSCDCCUnpacker::debug [private]

Definition at line 35 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

unsigned int CSCDCCUnpacker::errorMask [private]

Definition at line 44 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

unsigned int CSCDCCUnpacker::examinerMask [private]

Definition at line 44 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 39 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), produce(), and visual_raw().

bool CSCDCCUnpacker::goodEvent [private]

Definition at line 35 of file CSCDCCUnpacker.h.

Referenced by produce().

Definition at line 47 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 45 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 46 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 43 of file CSCDCCUnpacker.h.

Referenced by produce().

Definition at line 35 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Suppress zeros LCTs.

Definition at line 41 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 35 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 35 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 36 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 36 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Visualization of raw data.

Definition at line 39 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().

Definition at line 39 of file CSCDCCUnpacker.h.

Referenced by CSCDCCUnpacker(), and produce().