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 88 89 90 91 92 93 94 95 96 97
#include <iostream>

#include "FWCore/ServiceRegistry/interface/Service.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"

#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include "DQMServices/Core/interface/DQMStore.h"

#include "DQM/EcalPreshowerMonitorModule/interface/ESDcsInfoTask.h"

using namespace cms;
using namespace edm;
using namespace std;

ESDcsInfoTask::ESDcsInfoTask(const ParameterSet& ps) {
  usesResource("DQMStore");
  dqmStore_ = Service<DQMStore>().operator->();

  prefixME_ = ps.getUntrackedParameter<string>("prefixME", "");

  mergeRuns_ = ps.getUntrackedParameter<bool>("mergeRuns", false);

  dcsStatustoken_ = consumes<DcsStatusCollection>(ps.getParameter<InputTag>("DcsStatusLabel"));

  meESDcsFraction_ = nullptr;
  meESDcsActiveMap_ = nullptr;
}

ESDcsInfoTask::~ESDcsInfoTask() {}

void ESDcsInfoTask::beginJob(void) {
  char histo[200];

  if (dqmStore_) {
    dqmStore_->setCurrentFolder(prefixME_ + "/EventInfo");

    sprintf(histo, "DCSSummary");
    meESDcsFraction_ = dqmStore_->bookFloat(histo);
    meESDcsFraction_->Fill(-1.0);

    sprintf(histo, "DCSSummaryMap");
    meESDcsActiveMap_ = dqmStore_->book1D(histo, histo, 2, 0., 2.);
    meESDcsActiveMap_->setAxisTitle("(ES+/ES-)", 1);
  }
}

void ESDcsInfoTask::endJob(void) {}

void ESDcsInfoTask::beginLuminosityBlock(const edm::LuminosityBlock& lumiBlock, const edm::EventSetup& iSetup) {
  this->reset();

  for (int i = 0; i < 2; i++) {
    meESDcsActiveMap_->setBinContent(i + 1, -1.0);
  }
}

void ESDcsInfoTask::endLuminosityBlock(const edm::LuminosityBlock&, const edm::EventSetup&) {}

void ESDcsInfoTask::reset(void) {
  if (meESDcsFraction_)
    meESDcsFraction_->Reset();

  if (meESDcsActiveMap_)
    meESDcsActiveMap_->Reset();
}

void ESDcsInfoTask::analyze(const Event& e, const EventSetup& c) {
  ievt_++;

  float ESpDcsStatus = 0;
  float ESmDcsStatus = 0;

  Handle<DcsStatusCollection> dcsStatus;
  e.getByToken(dcsStatustoken_, dcsStatus);
  if (dcsStatus.isValid()) {
    for (DcsStatusCollection::const_iterator dcsStatusItr = dcsStatus->begin(); dcsStatusItr != dcsStatus->end();
         ++dcsStatusItr) {
      ESpDcsStatus = dcsStatusItr->ready(DcsStatus::ESp);
      ESmDcsStatus = dcsStatusItr->ready(DcsStatus::ESm);
    }

    ESpDcsStatus = (ESpDcsStatus + float(ievt_ - 1) * meESDcsActiveMap_->getBinContent(1)) / float(ievt_);
    ESmDcsStatus = (ESmDcsStatus + float(ievt_ - 1) * meESDcsActiveMap_->getBinContent(2)) / float(ievt_);
  }

  meESDcsActiveMap_->setBinContent(1, ESpDcsStatus);
  meESDcsActiveMap_->setBinContent(2, ESmDcsStatus);

  meESDcsFraction_->Fill((ESpDcsStatus + ESmDcsStatus) / 2.);
}

//define this as a plug-in
DEFINE_FWK_MODULE(ESDcsInfoTask);