Key

SiPixelFedCablingMap

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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
#ifndef EventFilter_SiPixelRawToDigi_SiPixelFedCablingMap_H
#define EventFilter_SiPixelRawToDigi_SiPixelFedCablingMap_H

#include "CondFormats/Serialization/interface/Serializable.h"

#include "CondFormats/SiPixelObjects/interface/SiPixelFedCabling.h"
#include "CondFormats/SiPixelObjects/interface/PixelROC.h"

#include <string>
#include <map>
#include <memory>

#if !defined(__CINT__) && !defined(__MAKECINT__) && !defined(__REFLEX__)
#define NO_DICT
#endif

class SiPixelFedCablingTree;

class SiPixelFedCablingMap : public SiPixelFedCabling {
public:
  SiPixelFedCablingMap(const SiPixelFedCablingTree* cab);

  SiPixelFedCablingMap(const std::string& version = "") : theVersion(version) {}

  void initializeRocs();

  ~SiPixelFedCablingMap() override {}

#ifdef NO_DICT
  std::unique_ptr<SiPixelFedCablingTree> cablingTree() const;
#endif

  std::string version() const override { return theVersion; }

  const sipixelobjects::PixelROC* findItem(const sipixelobjects::CablingPathToDetUnit& path) const final;

  std::vector<sipixelobjects::CablingPathToDetUnit> pathToDetUnit(uint32_t rawDetId) const final;

  bool pathToDetUnitHasDetUnit(uint32_t rawDetId, unsigned int fedId) const final;

  std::unordered_map<uint32_t, unsigned int> det2fedMap() const final;
  std::map<uint32_t, std::vector<sipixelobjects::CablingPathToDetUnit> > det2PathMap() const final;

  std::vector<unsigned int> fedIds() const;

  struct Key {
    unsigned int fed, link, roc;
    bool operator<(const Key& other) const;
    COND_SERIALIZABLE;
  };

private:
  std::string theVersion;
  typedef std::map<Key, sipixelobjects::PixelROC> Map;
  Map theMap;

  COND_SERIALIZABLE;
};

#endif