DbEntry

DbEntryBinSize

SiPixelCPEGenericErrorParm

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
#ifndef CondFormats_SiPixelObjects_SiPixelCPEGenericErrorParm_h
#define CondFormats_SiPixelObjects_SiPixelCPEGenericErrorParm_h 1

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

#include <vector>
#include <iosfwd>

//--- Maybe should make this a class const, but that'd be too much work.
//--- This usage is not worth it, since in the debugger will be obvious
//--- what this is! ;)
#define NONSENSE -99999.9
#define NONSENSE_I -99999

class SiPixelCPEGenericErrorParm {
public:
  //! A struct to hold information for a given (alpha,beta,size)
  struct DbEntry {
    float sigma;
    float rms;
    float bias;        // For irradiated pixels
    float pix_height;  // For decapitation
    float ave_Qclus;   // Average cluster charge, For
    DbEntry() : sigma(NONSENSE), rms(NONSENSE), bias(NONSENSE), pix_height(NONSENSE), ave_Qclus(NONSENSE) {}
    ~DbEntry() {}

    COND_SERIALIZABLE;
  };
  typedef std::vector<DbEntry> DbVector;

  //! A struct to hold the binning information for (part, size, alpha, beta)
  struct DbEntryBinSize {
    int partBin_size;
    int sizeBin_size;
    int alphaBin_size;
    int betaBin_size;
    DbEntryBinSize()
        : partBin_size(NONSENSE_I), sizeBin_size(NONSENSE_I), alphaBin_size(NONSENSE_I), betaBin_size(NONSENSE_I) {}
    ~DbEntryBinSize() {}

    COND_SERIALIZABLE;
  };
  typedef std::vector<DbEntryBinSize> DbBinSizeVector;

  SiPixelCPEGenericErrorParm() : errors_(), errorsBinSize_() {}
  virtual ~SiPixelCPEGenericErrorParm() {}

  //!  Function to output the contents of the db object
  friend std::ostream& operator<<(std::ostream& s, const SiPixelCPEGenericErrorParm& genericErrors);

  //!  Function to fill the db object given a filename
  void fillCPEGenericErrorParm(double version, std::string file);

  //!  Accessors for the vectors -- non-const version
  inline DbVector& errors() { return errors_; }
  inline DbBinSizeVector& errorsBin() { return errorsBinSize_; }
  inline double& version() { return version_; }

  //!  Accessors for the vectors -- const version
  inline const DbVector& errors() const { return errors_; }
  inline const DbBinSizeVector& errorsBinSize() const { return errorsBinSize_; }
  inline const double& version() const { return version_; }

  //!  Reserve some reasonable sizes for the vectors.
  inline void reserve() {
    errors_.reserve(1000);
    errorsBinSize_.reserve(4);
  }
  //  &&& Should these sizes be computed on the fly from other
  //  &&& variables (which are currently not stored in this object,
  //  &&& but maybe should be?)

  //inline void push_back( DbEntry e) {errors_.push_back(e);}
  //	inline void push_back_bin( DbEntryBinSize e) {errorsBinSize_.push_back(e);}
  inline void set_version(double v) { version_ = v; }

  // &&& Should we be able to read this from an iostream?  See PxCPEdbUploader...

private:
  DbVector errors_;
  DbBinSizeVector errorsBinSize_;
  double version_;

  COND_SERIALIZABLE;
};

#endif