FrameConversion

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
#ifndef SiPixelObjects_FrameConversion_H
#define SiPixelObjects_FrameConversion_H

#include "CondFormats/SiPixelObjects/interface/LinearConversion.h"

class PixelEndcapName;
class PixelBarrelName;
class TrackerTopology;

namespace sipixelobjects {

  class FrameConversion {
  public:
    FrameConversion() {}
    FrameConversion(const PixelEndcapName& name, int rocIdInDetUnit);
    FrameConversion(const PixelBarrelName& name, int rocIdInDetUnit);
    FrameConversion(int rowOffset, int rowSlopeSign, int colOffset, int colSlopeSign)
        : theRowConversion(LinearConversion(rowOffset, rowSlopeSign)),
          theCollumnConversion(LinearConversion(colOffset, colSlopeSign)) {}
    // for phase1
    FrameConversion(bool bpix, int side, int layer, int rocIdInDetUnit);
    // Frame conversion compatible with CMSSW_9_0_X Monte Carlo samples
    FrameConversion(bool bpix, int side, int rocIdInDetUnit);

    const sipixelobjects::LinearConversion& row() const { return theRowConversion; }
    const sipixelobjects::LinearConversion& collumn() const { return theCollumnConversion; }

  private:
    sipixelobjects::LinearConversion theRowConversion;
    sipixelobjects::LinearConversion theCollumnConversion;
  };

}  // namespace sipixelobjects
#endif