1 #ifndef CROSSING_FRAME_H
2 #define CROSSING_FRAME_H
93 typename std::vector<const T*>::const_iterator&
last)
const {
98 typename std::vector<const T*>::const_iterator&
last)
const;
116 throw cms::Exception(
"BadIndex") <<
"CrossingFrame::getObject called with an invalid index- index was " << ip
162 std::vector<std::shared_ptr<edm::Wrapper<std::vector<T> >
const> >
shPtrPileups_;
181 : firstCrossing_(minb), lastCrossing_(maxb), bunchSpace_(bunchsp), subdet_(subdet), maxNbSources_(maxNbSources) {
190 template <
typename T>
206 pileupOffsetsSource_.resize(maxNbSources_);
207 for (
unsigned int i = 0;
i < pileupOffsetsSource_.size(); ++
i) {
212 template <
typename T>
221 typename std::vector<const T*>::const_iterator&
last)
const {
222 first = pileups_.begin();
223 last = pileups_.end();
234 unsigned int bcr = getBunchCrossing(ip) - firstCrossing_;
235 for (
unsigned int i = 0;
i < pileupOffsetsSource_.size() - 1; ++
i) {
236 if (ip >= (pileupOffsetsSource_[
i])[bcr] && ip < (pileupOffsetsSource_[i + 1])[bcr])
239 return pileupOffsetsSource_.size() - 1;
245 for (
unsigned int ii = 1;
ii < pileupOffsetsBcr_.size();
ii++) {
246 if (ip >= pileupOffsetsBcr_[
ii - 1] && ip < pileupOffsetsBcr_[
ii])
247 return ii + firstCrossing_ - 1;
249 if (ip < pileups_.size())
250 return lastCrossing_;
256 template <
typename T>
265 std::ostream& operator<<(std::ostream& o, const CrossingFrame<T>& cf) {
266 std::pair<int, int>
range = cf.getBunchRange();
267 o <<
"\nCrossingFrame for subdet " << cf.getEventID() <<
", bunchrange = " << range.first <<
"," << range.second
268 <<
", bunchSpace " << cf.getBunchSpace();
276 shPtrPileupsPCF_ = shPtr;
282 pileups_.push_back(&product);
288 for (
auto const&
item : product) {
289 pileups_.push_back(&
item);
298 for (
unsigned int i = 0;
i < vec->size(); ++
i) {
299 signals_.push_back(&((*vec)[
i]));
307 signals_.push_back(product);
void addSignals(const std::vector< T > *vec, edm::EventID id)
void addPileups(std::vector< T > const &vec)
const std::vector< std::vector< unsigned int > > & getPileupOffsetsSource() const
void setEventID(edm::EventID evId)
uint16_t *__restrict__ id
void print(int level=0) const
const std::vector< unsigned int > & getPileupOffsetsBcr() const
unsigned int getMaxNbSources() const
void setPileups(const std::vector< const T * > &p)
unsigned int getNrPileups(int bcr) const
void setPileupPtr(std::shared_ptr< edm::Wrapper< std::vector< T > > const > shPtr)
int getSourceType(unsigned int ip) const
void setMaxNbSources(unsigned int mNbS)
void setPileupFileNr(unsigned int pFileNr)
void setIdFirstPileup(edm::EventID idFP)
void setPileupPtr(std::shared_ptr< edm::Wrapper< T > const > shPtr)
void setSubDet(std::string det)
unsigned int maxNbSources_
void swap(Association< C > &lhs, Association< C > &rhs)
std::vector< std::shared_ptr< edm::Wrapper< T > const > > shPtrPileups2_
std::string getSubDet() const
const uint16_t range(const Frame &aFrame)
edm::EventID getEventID() const
const T & getObject(unsigned int ip) const
edm::EventID idFirstPileup_
void setBunchRange(std::pair< int, int > bunchRange)
std::vector< unsigned int > pileupOffsetsBcr_
void swap(edm::DataFrameContainer &lhs, edm::DataFrameContainer &rhs)
void setPileupOffsetsBcr(const std::vector< unsigned int > &pOffsetsBcr)
std::shared_ptr< edm::Wrapper< PCrossingFrame< T > > const > shPtrPileupsPCF_
void setBunchSpace(int bSpace)
int getBunchCrossing(unsigned int ip) const
void setPileupOffsetsSource(const std::vector< std::vector< unsigned int > > &pOffsetsS)
unsigned int getPileupFileNr() const
std::vector< std::vector< unsigned int > > pileupOffsetsSource_
void swap(CrossingFrame &other)
const std::vector< const T * > & getSignal() const
const std::vector< const T * > & getPileups() const
unsigned int getNrSignals() const
unsigned int pileupFileNr_
std::vector< const T * > pileups_
edm::EventID getIdFirstPileup() const
void setSourceOffset(const unsigned int s)
void getSignal(typename std::vector< const T * >::const_iterator &first, typename std::vector< const T * >::const_iterator &last) const
std::vector< const T * > signals_
CrossingFrame & operator=(CrossingFrame const &rhs)
std::vector< std::shared_ptr< edm::Wrapper< std::vector< T > > const > > shPtrPileups_
std::pair< int, int > getBunchRange() const
int getBunchSpace() const
unsigned int getNrPileups() const