Key

PPSTimingCalibration

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
/****************************************************************************
 *
 * This is a part of CTPPS offline software.
 * Authors:
 *   Filip Dej
 *   Laurent Forthomme
 *
 ****************************************************************************/

#ifndef CondFormats_PPSObjects_PPSTimingCalibration_h
#define CondFormats_PPSObjects_PPSTimingCalibration_h

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

#include <map>
#include <vector>

class PPSTimingCalibration {
public:
  /// Helper structure for indexing calibration data
  struct Key {
    int db, sampic, channel, cell;

    /// Comparison operator
    bool operator<(const Key& rhs) const;
    friend std::ostream& operator<<(std::ostream& os, const Key& key);

    COND_SERIALIZABLE;
  };
  //--------------------------------------------------------------------------

  using ParametersMap = std::map<Key, std::vector<double> >;
  using TimingMap = std::map<Key, std::pair<double, double> >;

  PPSTimingCalibration() = default;
  PPSTimingCalibration(const std::string& formula, const ParametersMap& params, const TimingMap& timeinfo)
      : formula_(formula), parameters_(params), timeInfo_(timeinfo) {}
  ~PPSTimingCalibration() = default;

  std::vector<double> parameters(int key1, int key2, int key3, int key4) const;
  inline const std::string& formula() const { return formula_; }
  double timeOffset(int key1, int key2, int key3, int key4 = -1) const;
  double timePrecision(int key1, int key2, int key3, int key4 = -1) const;

  friend std::ostream& operator<<(std::ostream& os, const PPSTimingCalibration& data);

private:
  std::string formula_;
  ParametersMap parameters_;
  TimingMap timeInfo_;

  COND_SERIALIZABLE;
};

#endif