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 43 44 45 46 47 48 49 50 51 52 53 54 55 56
#include "DataFormats/ForwardDetId/interface/HFNoseDetId.h"
#include "FWCore/Utilities/interface/Exception.h"
#include <ostream>
#include <iostream>

const HFNoseDetId HFNoseDetId::Undefined(0, 0, 0, 0, 0, 0, 0);

HFNoseDetId::HFNoseDetId() : DetId() {}

HFNoseDetId::HFNoseDetId(uint32_t rawid) : DetId(rawid) {}

HFNoseDetId::HFNoseDetId(DetId::Detector det, int zp, int type, int layer, int waferU, int waferV, int cellU, int cellV)
    : DetId(det, HFNose) {
  int waferUabs(std::abs(waferU)), waferVabs(std::abs(waferV));
  int waferUsign = (waferU >= 0) ? 0 : 1;
  int waferVsign = (waferV >= 0) ? 0 : 1;
  int zside = (zp < 0) ? 1 : 0;
  int lay = std::max(layer - 1, 0);
  id_ |= (((cellU & kHFNoseCellUMask) << kHFNoseCellUOffset) | ((cellV & kHFNoseCellVMask) << kHFNoseCellVOffset) |
          ((waferUabs & kHFNoseWaferUMask) << kHFNoseWaferUOffset) |
          ((waferUsign & kHFNoseWaferUSignMask) << kHFNoseWaferUSignOffset) |
          ((waferVabs & kHFNoseWaferVMask) << kHFNoseWaferVOffset) |
          ((waferVsign & kHFNoseWaferVSignMask) << kHFNoseWaferVSignOffset) |
          ((lay & kHFNoseLayerMask) << kHFNoseLayerOffset) | ((zside & kHFNoseZsideMask) << kHFNoseZsideOffset) |
          ((type & kHFNoseTypeMask) << kHFNoseTypeOffset));
}

HFNoseDetId::HFNoseDetId(int zp, int type, int layer, int waferU, int waferV, int cellU, int cellV)
    : HFNoseDetId(Forward, zp, type, layer, waferU, waferV, cellU, cellV) {}

HFNoseDetId::HFNoseDetId(const DetId& gen) {
  if (!gen.null()) {
    if (!((gen.det() == Forward) && (gen.subdetId() == (int)(HFNose)))) {
      throw cms::Exception("Invalid DetId")
          << "Cannot initialize HFNoseDetId from " << std::hex << gen.rawId() << std::dec;
    }
  }
  id_ = gen.rawId();
}

HFNoseDetId& HFNoseDetId::operator=(const DetId& gen) {
  if (!gen.null()) {
    if (!((gen.det() == Forward) && (gen.subdetId() == (int)(HFNose)))) {
      throw cms::Exception("Invalid DetId") << "Cannot assign HFNoseDetId from " << std::hex << gen.rawId() << std::dec;
    }
  }
  id_ = gen.rawId();
  return (*this);
}

std::ostream& operator<<(std::ostream& s, const HFNoseDetId& id) {
  return s << " HFNoseDetId::EE:HE= " << id.isEE() << ":" << id.isHE() << " type= " << id.type() << " z= " << id.zside()
           << " layer= " << id.layer() << " wafer(u,v:x,y)= (" << id.waferU() << "," << id.waferV() << ":"
           << id.waferX() << "," << id.waferY() << ")"
           << " cell(u,v:x,y)= (" << id.cellU() << "," << id.cellV() << ":" << id.cellX() << "," << id.cellY() << ")";
}