DTRangeT0

DTRangeT0Data

DTRangeT0Id

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 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
#ifndef DTRangeT0_H
#define DTRangeT0_H
/** \class DTRangeT0
 *
 *  Description:
 *       Class to hold drift tubes T0 range
 *             ( SL by SL min - max T0 )
 *
 *  \author Paolo Ronchese INFN Padova
 *
 */

//----------------------
// Base Class Headers --
//----------------------

//------------------------------------
// Collaborating Class Declarations --
//------------------------------------
#include "CondFormats/Serialization/interface/Serializable.h"

#include "DataFormats/MuonDetId/interface/DTSuperLayerId.h"
#include "FWCore/Utilities/interface/ConstRespectingPtr.h"

//---------------
// C++ Headers --
//---------------
#include <string>
#include <vector>
#include <utility>

template <class Key, class Content>
class DTBufferTree;

//              ---------------------
//              -- Class Interface --
//              ---------------------

class DTRangeT0Id {
public:
  DTRangeT0Id();
  ~DTRangeT0Id();

  int wheelId;
  int stationId;
  int sectorId;
  int slId;

  COND_SERIALIZABLE;
};

class DTRangeT0Data {
public:
  DTRangeT0Data();
  ~DTRangeT0Data();

  int t0min;
  int t0max;

  COND_SERIALIZABLE;
};

class DTRangeT0 {
public:
  /** Constructor
   */
  DTRangeT0();
  DTRangeT0(DTRangeT0 const&) = delete;
  DTRangeT0& operator=(DTRangeT0 const&) = delete;
  DTRangeT0(const std::string& version);

  /** Destructor
   */
  ~DTRangeT0();

  /** Operations
   */
  /// get content
  int slRangeT0(int wheelId, int stationId, int sectorId, int slId, int& t0min, int& t0max) const {
    return get(wheelId, stationId, sectorId, slId, t0min, t0max);
  };
  int slRangeT0(const DTSuperLayerId& id, int& t0min, int& t0max) const { return get(id, t0min, t0max); };
  int get(int wheelId, int stationId, int sectorId, int slId, int& t0min, int& t0max) const;
  int get(const DTSuperLayerId& id, int& t0min, int& t0max) const;

  /// access version
  const std::string& version() const;
  std::string& version();

  /// reset content
  void clear();

  int setSLRangeT0(int wheelId, int stationId, int sectorId, int slId, int t0min, int t0max) {
    return set(wheelId, stationId, sectorId, slId, t0min, t0max);
  };
  int setSLRangeT0(const DTSuperLayerId& id, int t0min, int t0max) { return set(id, t0min, t0max); };
  int set(int wheelId, int stationId, int sectorId, int slId, int t0min, int t0max);
  int set(const DTSuperLayerId& id, int t0min, int t0max);

  /// Access methods to data
  typedef std::vector<std::pair<DTRangeT0Id, DTRangeT0Data> >::const_iterator const_iterator;
  const_iterator begin() const;
  const_iterator end() const;

  void initialize();

private:
  std::string dataVersion;

  std::vector<std::pair<DTRangeT0Id, DTRangeT0Data> > dataList;

  DTBufferTree<int, int>* dBuf COND_TRANSIENT;

  /// read and store full content
  std::string mapName() const;

  COND_SERIALIZABLE;
};
#endif  // DTRangeT0_H