CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
HGCDataFrame.h
Go to the documentation of this file.
1 #ifndef DIGIHGCAL_HGCDATAFRAME_H
2 #define DIGIHGCAL_HGCDATAFRAME_H
3 
4 #include <vector>
5 #include <ostream>
6 #include <iostream>
7 
13 template <class D, class S>
14 class HGCDataFrame {
15 public:
19  typedef D key_type;
20 
25  HGCDataFrame(const D& id) : id_(id), maxSampleSize_(15) { data_.resize(maxSampleSize_); }
27 
31  const D& id() const { return id_; }
32 
36  int size() const { return data_.size() & 0xf; }
37 
41  void resize(size_t s) { data_.resize(s); }
42 
46  const S& operator[](int i) const { return data_[i]; }
47  const S& sample(int i) const { return data_[i]; }
48  void setSample(int i, const S& sample) {
49  if (i < (int)data_.size())
50  data_[i] = sample;
51  }
52  void print(std::ostream& out = std::cout) {
53  for (size_t i = 0; i < data_.size(); i++) {
54  out << "[" << i << "] ";
55  data_[i].print(out);
56  }
57  }
58  const std::vector<S>& data() const { return data_; }
59  void setData(const std::vector<S>& d) { data_ = d; }
60 
61 private:
62  //collection of samples
63  std::vector<S> data_;
64 
65  // det id for this data frame
66  D id_;
67 
68  //number of samples and maximum available
70 };
71 
72 #endif
const std::vector< S > & data() const
Definition: HGCDataFrame.h:58
size_t maxSampleSize_
Definition: HGCDataFrame.h:69
void print(std::ostream &out=std::cout)
Definition: HGCDataFrame.h:52
void resize(size_t s)
allow to set size
Definition: HGCDataFrame.h:41
const S & sample(int i) const
Definition: HGCDataFrame.h:47
tuple d
Definition: ztail.py:151
const S & operator[](int i) const
assess/set specific samples
Definition: HGCDataFrame.h:46
HGCDataFrame(const HGCDataFrame &o)
Definition: HGCDataFrame.h:26
D key_type
key to sort the collection
Definition: HGCDataFrame.h:19
HGCDataFrame(const D &id)
Definition: HGCDataFrame.h:25
std::vector< S > data_
Definition: HGCDataFrame.h:63
const D & id() const
det id
Definition: HGCDataFrame.h:31
DecomposeProduct< arg, typename Div::arg > D
Definition: Factorize.h:141
Readout digi for HGC.
Definition: HGCDataFrame.h:14
void setData(const std::vector< S > &d)
Definition: HGCDataFrame.h:59
void setSample(int i, const S &sample)
Definition: HGCDataFrame.h:48
tuple cout
Definition: gather_cfg.py:144
HGCDataFrame()
CTOR.
Definition: HGCDataFrame.h:24
int size() const
total number of samples in the digi
Definition: HGCDataFrame.h:36