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
#include "DataFormats/Luminosity/interface/LumiInfoRunHeader.h"

LumiInfoRunHeader::LumiInfoRunHeader(std::string& lumiProvider,
                                     std::string& fillingSchemeName,
                                     std::bitset<LumiConstants::numBX>& fillingScheme)
    : lumiProvider_(lumiProvider), fillingSchemeName_(fillingSchemeName), fillingScheme_(fillingScheme) {
  setBunchSpacing();
}

bool LumiInfoRunHeader::isProductEqual(LumiInfoRunHeader const& o) const {
  return (lumiProvider_ == o.lumiProvider_ && fillingSchemeName_ == o.fillingSchemeName_ &&
          fillingScheme_ == o.fillingScheme_);
}

//==============================================================================

void LumiInfoRunHeader::setFillingScheme(const std::bitset<LumiConstants::numBX>& fillingScheme) {
  fillingScheme_ = fillingScheme;
  setBunchSpacing();
}

// This function determines the bunch spacing from the filling scheme
// and sets bunchSpacing_ accordingly.

void LumiInfoRunHeader::setBunchSpacing(void) {
  int lastFilledBunch = -1;
  int minimumSpacingFound = LumiConstants::numBX;

  for (unsigned int i = 0; i < LumiConstants::numBX; i++) {
    if (fillingScheme_[i]) {
      if (lastFilledBunch >= 0) {
        int thisSpacing = i - lastFilledBunch;
        if (thisSpacing < minimumSpacingFound)
          minimumSpacingFound = thisSpacing;
      }
      lastFilledBunch = i;
    }
  }

  // If no bunches are filled, then just leave bunchSpacing at 0
  if (lastFilledBunch == -1)
    bunchSpacing_ = 0;
  else
    bunchSpacing_ = LumiConstants::bxSpacingInt * minimumSpacingFound;
}