Collections

HcalPacker

Macros

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 29 30 31 32 33 34 35 36 37 38 39 40 41 42
#ifndef EVENTFILTER_HCALRAWTODIGI_HCALPACKER_H
#define EVENTFILTER_HCALRAWTODIGI_HCALPACKER_H 1

#include "DataFormats/HcalDigi/interface/HcalDigiCollections.h"
#include "DataFormats/FEDRawData/interface/FEDRawData.h"
#include "CondFormats/HcalObjects/interface/HcalElectronicsMap.h"

/** \class HcalPacker
  *  
  * \author J. Mans - Minnesota
  */
class HcalPacker {
public:
  struct Collections {
    Collections();
    const HBHEDigiCollection* hbhe;
    const HODigiCollection* hoCont;
    const HFDigiCollection* hfCont;
    const HcalCalibDigiCollection* calibCont;
    const ZDCDigiCollection* zdcCont;
    const HcalTrigPrimDigiCollection* tpCont;
  };

  void pack(int fedid,
            int dccnumber,
            int nl1a,
            int orbitn,
            int bcn,
            const Collections& inputs,
            const HcalElectronicsMap& emap,
            FEDRawData& output) const;

private:
  int findSamples(const DetId& did,
                  const Collections& inputs,
                  unsigned short* buffer,
                  int& presamples,
                  bool& zsUS,
                  bool& zsMP) const;
};

#endif