CSCReadBadChambersAnalyzer

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 98 99 100 101 102 103 104 105 106 107
#include <stdexcept>
#include <string>
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <bitset>

#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/MakerMacros.h"

#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Utilities/interface/ESGetToken.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"

#include "CondFormats/CSCObjects/interface/CSCBadChambers.h"
#include "CondFormats/DataRecord/interface/CSCBadChambersRcd.h"
#include "DataFormats/MuonDetId/interface/CSCDetId.h"
#include "DataFormats/MuonDetId/interface/CSCIndexer.h"

namespace edmtest {
  class CSCReadBadChambersAnalyzer : public edm::one::EDAnalyzer<> {
  public:
    explicit CSCReadBadChambersAnalyzer(edm::ParameterSet const& ps)
        : chambersToken_{esConsumes()},
          outputToFile_(ps.getParameter<bool>("outputToFile")),
          readBadChambers_(ps.getParameter<bool>("readBadChambers")),
          me42installed_(ps.getParameter<bool>("me42installed")) {}

    ~CSCReadBadChambersAnalyzer() override {}

    void analyze(const edm::Event& e, const edm::EventSetup& c) override;

  private:
    const edm::ESGetToken<CSCBadChambers, CSCBadChambersRcd> chambersToken_;
    const bool outputToFile_;
    const bool readBadChambers_;  // flag whether or not to even attempt reading bad channel info from db
    const bool me42installed_;    // flag whether ME42 chambers are installed in the geometry
  };

  void CSCReadBadChambersAnalyzer::analyze(const edm::Event& e, const edm::EventSetup& context) {
    using namespace edm::eventsetup;

    edm::LogSystem log("CSCBadChambers");

    int counter = 0;
    log << " RUN# " << e.id().run() << std::endl;
    log << " EVENT# " << e.id().event() << std::endl;

    auto theBadChambers = &context.getData(chambersToken_);

    CSCIndexer indexer;  // just to build a CSCDetId from chamber index

    log << "Bad Chambers:" << std::endl;

    int nbad = theBadChambers->numberOfChambers();
    log << "No. in list = " << nbad << std::endl;

    // Iterate over all chambers via their linear index

    int countbad = 0;
    int countgood = 0;

    // One more than total number of chambers
    // Last chamber is already in ME4 but could be 41 or 42
    int lastRing = 1;
    if (me42installed_)
      lastRing = 2;
    int totalc = indexer.startChamberIndexInEndcap(2, 4, lastRing) + indexer.chambersInRingOfStation(4, lastRing);

    for (int indexc = 1; indexc != totalc; ++indexc) {
      counter++;

      CSCDetId id = indexer.detIdFromChamberIndex(indexc);
      bool bbad = theBadChambers->isInBadChamber(id);
      std::string bbads = "LIVE";
      if (bbad) {
        bbads = "DEAD";
        ++countbad;
      } else {
        ++countgood;
      }
      log << counter << "  " << indexc << " " << id << " In bad list? " << bbads << std::endl;
    }

    log << "Total number of chambers      = " << counter << std::endl;
    log << "Total number of good chambers = " << countgood << std::endl;
    log << "Total number of bad chambers  = " << countbad << std::endl;

    if (outputToFile_) {
      std::ofstream BadChamberFile("dbBadChamber.dat", std::ios::app);
      std::vector<int> badChambers = theBadChambers->container();
      counter = 0;
      std::vector<int>::const_iterator itcham;

      for (itcham = badChambers.begin(); itcham != badChambers.end(); ++itcham) {
        counter++;
        BadChamberFile << counter << "  " << *itcham << std::endl;
      }
    }
  }

  DEFINE_FWK_MODULE(CSCReadBadChambersAnalyzer);
}  // namespace edmtest