VectorInputSource

Macros

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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
#ifndef FWCore_Sources_VectorInputSource_h
#define FWCore_Sources_VectorInputSource_h

/*----------------------------------------------------------------------
VectorInputSource: Abstract interface for vector input sources.
----------------------------------------------------------------------*/

#include "DataFormats/Common/interface/SecondaryEventIDAndFileInfo.h"
#include "DataFormats/Provenance/interface/ProcessHistoryRegistry.h"
#include "DataFormats/Provenance/interface/ProductRegistry.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/get_underlying_safe.h"

#include <memory>
#include <string>
#include <vector>

namespace CLHEP {
  class HepRandomEngine;
}

namespace edm {
  class EventPrincipal;
  struct VectorInputSourceDescription;
  class EventID;
  class ParameterSet;
  class VectorInputSource {
  public:
    explicit VectorInputSource(ParameterSet const& pset, VectorInputSourceDescription const& desc);
    virtual ~VectorInputSource();

    template <typename T>
    size_t loopOverEvents(EventPrincipal& cache,
                          size_t& fileNameHash,
                          size_t number,
                          T eventOperator,
                          CLHEP::HepRandomEngine* = nullptr,
                          EventID const* id = nullptr,
                          bool recycleFiles = true);

    template <typename T, typename Iterator>
    size_t loopSpecified(
        EventPrincipal& cache, size_t& fileNameHash, Iterator const& begin, Iterator const& end, T eventOperator);

    void dropUnwantedBranches(std::vector<std::string> const& wantedBranches);
    //
    /// Called at beginning of job
    void doBeginJob();

    /// Called at end of job
    void doEndJob();

    std::shared_ptr<ProductRegistry const> productRegistry() const { return get_underlying_safe(productRegistry_); }
    std::shared_ptr<ProductRegistry>& productRegistry() { return get_underlying_safe(productRegistry_); }
    ProductRegistry& productRegistryUpdate() { return *productRegistry_; }
    ProcessHistoryRegistry const& processHistoryRegistry() const { return *processHistoryRegistry_; }
    ProcessHistoryRegistry& processHistoryRegistryForUpdate() { return *processHistoryRegistry_; }

  private:
    void clearEventPrincipal(EventPrincipal& cache);

  private:
    virtual bool readOneEvent(
        EventPrincipal& cache, size_t& fileNameHash, CLHEP::HepRandomEngine*, EventID const* id, bool recycleFiles) = 0;
    virtual void readOneSpecified(EventPrincipal& cache,
                                  size_t& fileNameHash,
                                  SecondaryEventIDAndFileInfo const& event) = 0;
    void readOneSpecified(EventPrincipal& cache, size_t& fileNameHash, EventID const& event) {
      SecondaryEventIDAndFileInfo info(event, fileNameHash);
      readOneSpecified(cache, fileNameHash, info);
    }

    virtual void dropUnwantedBranches_(std::vector<std::string> const& wantedBranches) = 0;
    virtual void beginJob() = 0;
    virtual void endJob() = 0;

    void throwIfOverLimit(unsigned int consecutiveRejections) const;

    edm::propagate_const<std::shared_ptr<ProductRegistry>> productRegistry_;
    edm::propagate_const<std::unique_ptr<ProcessHistoryRegistry>> processHistoryRegistry_;
    unsigned int consecutiveRejectionsLimit_;
  };

  template <typename T>
  size_t VectorInputSource::loopOverEvents(EventPrincipal& cache,
                                           size_t& fileNameHash,
                                           size_t number,
                                           T eventOperator,
                                           CLHEP::HepRandomEngine* engine,
                                           EventID const* id,
                                           bool recycleFiles) {
    size_t i = 0U;
    unsigned int consecutiveRejections = 0U;
    while (i < number) {
      clearEventPrincipal(cache);
      bool found = readOneEvent(cache, fileNameHash, engine, id, recycleFiles);
      if (!found)
        break;
      bool used = eventOperator(cache, fileNameHash);
      if (used) {
        ++i;
        consecutiveRejections = 0U;
      } else if (consecutiveRejectionsLimit_ > 0) {
        ++consecutiveRejections;
        throwIfOverLimit(consecutiveRejections);
      }
    }
    return i;
  }

  template <typename T, typename Iterator>
  size_t VectorInputSource::loopSpecified(
      EventPrincipal& cache, size_t& fileNameHash, Iterator const& begin, Iterator const& end, T eventOperator) {
    size_t i = 0U;
    for (Iterator iter = begin; iter != end; ++iter) {
      clearEventPrincipal(cache);
      readOneSpecified(cache, fileNameHash, *iter);
      eventOperator(cache, fileNameHash);
      ++i;
    }
    return i;
  }
}  // namespace edm
#endif