CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
FFTJetCorrectorDBReader Class Reference

#include <JetMETCorrections/FFTJetModules/plugins/FFTJetCorrectorDBReader.cc>

Inheritance diagram for FFTJetCorrectorDBReader:
edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

 FFTJetCorrectorDBReader (const edm::ParameterSet &)
 
 FFTJetCorrectorDBReader ()=delete
 
 FFTJetCorrectorDBReader (const FFTJetCorrectorDBReader &)=delete
 
FFTJetCorrectorDBReaderoperator= (const FFTJetCorrectorDBReader &)=delete
 
 ~FFTJetCorrectorDBReader () override
 
- Public Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzer ()
 
SerialTaskQueueglobalLuminosityBlocksQueue ()
 
SerialTaskQueueglobalRunsQueue ()
 
ModuleDescription const & moduleDescription () const
 
std::string workerType () const
 
 ~EDAnalyzer () override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
ESProxyIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
std::vector< ESProxyIndex > const & esGetTokenIndicesVector (edm::Transition iTrans) const
 
std::vector< ESRecordIndex > const & esGetTokenRecordIndicesVector (edm::Transition iTrans) const
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::array< std::vector< ModuleDescription const *> *, NumBranchTypes > &modulesAll, std::vector< ModuleProcessName > &modulesInPreviousProcesses, ProductRegistry const &preg, std::map< std::string, ModuleDescription const *> const &labelsToDesc, std::string const &processName) const
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void selectInputProcessBlocks (ProductRegistry const &productRegistry, ProcessBlockHelperBase const &processBlockHelperBase)
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Private Member Functions

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

Private Attributes

bool isArchiveCompressed
 
std::string outputFile
 
bool printAsString
 
bool readArchive
 
std::string record
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
static bool wantsGlobalLuminosityBlocks ()
 
static bool wantsGlobalRuns ()
 
static bool wantsInputProcessBlocks ()
 
static bool wantsProcessBlocks ()
 
static bool wantsStreamLuminosityBlocks ()
 
static bool wantsStreamRuns ()
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
template<BranchType B = InEvent>
EDConsumerBaseAdaptor< Bconsumes (edm::InputTag tag) noexcept
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
template<Transition Tr = Transition::Event>
constexpr auto esConsumes ()
 
template<Transition Tr = Transition::Event>
auto esConsumes (ESInputTag tag)
 
template<Transition Tr = Transition::Event>
ESGetTokenGeneric esConsumes (eventsetup::EventSetupRecordKey const &iRecord, eventsetup::DataKey const &iKey)
 Used with EventSetupRecord::doGet. More...
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
void resetItemsToGetFrom (BranchType iType)
 

Detailed Description

Description: writes a blob from a file into a database

Implementation: [Notes on implementation]

Definition at line 45 of file FFTJetCorrectorDBReader.cc.

Constructor & Destructor Documentation

◆ FFTJetCorrectorDBReader() [1/3]

FFTJetCorrectorDBReader::FFTJetCorrectorDBReader ( const edm::ParameterSet ps)
explicit

◆ FFTJetCorrectorDBReader() [2/3]

FFTJetCorrectorDBReader::FFTJetCorrectorDBReader ( )
delete

◆ FFTJetCorrectorDBReader() [3/3]

FFTJetCorrectorDBReader::FFTJetCorrectorDBReader ( const FFTJetCorrectorDBReader )
delete

◆ ~FFTJetCorrectorDBReader()

FFTJetCorrectorDBReader::~FFTJetCorrectorDBReader ( )
inlineoverride

Definition at line 51 of file FFTJetCorrectorDBReader.cc.

51 {}

Member Function Documentation

◆ analyze()

void FFTJetCorrectorDBReader::analyze ( const edm::Event iEvent,
const edm::EventSetup iSetup 
)
overrideprivatevirtual

Implements edm::EDAnalyzer.

Definition at line 70 of file FFTJetCorrectorDBReader.cc.

References submitPVResolutionJobs::count, gather_cfg::cout, MillePedeFileConverter_cfg::e, FFTJetCorrectorParameters::empty(), FFTJetCorrectorParameters::getBuffer(), triggerObjects_cff::id, StaticFFTJetRcdMapper< Mapper >::instance(), isArchiveCompressed, FFTJetCorrectorParameters::length(), haddnano::of, outputFile, printAsString, readArchive, record, and FFTJetCorrectorParameters::str().

70  {
72  StaticFFTJetCorrectorParametersLoader::instance().load(iSetup, record, JetCorParams);
73 
75  std::cout << "++++ FFTJetCorrectorDBReader: info for record \"" << record << '"' << std::endl;
76 
77  if (printAsString)
78  std::cout << "++++ String rep: \"" << JetCorParams->str() << '"' << std::endl;
79  else if (readArchive) {
80  CPP11_auto_ptr<gs::StringArchive> par;
81 
82  {
83  std::istringstream is(JetCorParams->str());
85  par = gs::read_compressed_item<gs::StringArchive>(is);
86  else
87  par = gs::read_item<gs::StringArchive>(is);
88  }
89 
90  const unsigned long long idSmall = par->smallestId();
91  if (!idSmall)
92  std::cout << "++++ No valid records in the archive" << std::endl;
93  else {
94  std::cout << "++++ Archive metadata begins" << std::endl;
95  const unsigned long long idLarge = par->largestId();
96  unsigned long long count = 0;
97  for (unsigned long long id = idSmall; id <= idLarge; ++id)
98  if (par->itemExists(id)) {
99  std::shared_ptr<const gs::CatalogEntry> e = par->catalogEntry(id);
100  std::cout << '\n';
101  e->humanReadable(std::cout);
102  ++count;
103  }
104  std::cout << "\n++++ Archive metadata ends, " << count << " items total" << std::endl;
105  }
106  }
107 
108  if (!outputFile.empty()) {
109  std::ofstream of(outputFile.c_str(), std::ios_base::binary);
110  if (!of.is_open())
111  throw cms::Exception("InvalidArgument") << "Failed to open file \"" << outputFile << '"' << std::endl;
112  if (!JetCorParams->empty()) {
113  of.write(JetCorParams->getBuffer(), JetCorParams->length());
114  if (of.fail())
115  throw cms::Exception("SystemError")
116  << "Output stream failure while writing file \"" << outputFile << '"' << std::endl;
117  }
118  }
119 }
const std::string & str() const
static const Mapper & instance()

◆ operator=()

FFTJetCorrectorDBReader& FFTJetCorrectorDBReader::operator= ( const FFTJetCorrectorDBReader )
delete

Member Data Documentation

◆ isArchiveCompressed

bool FFTJetCorrectorDBReader::isArchiveCompressed
private

Definition at line 60 of file FFTJetCorrectorDBReader.cc.

Referenced by analyze().

◆ outputFile

std::string FFTJetCorrectorDBReader::outputFile
private

Definition at line 57 of file FFTJetCorrectorDBReader.cc.

Referenced by analyze().

◆ printAsString

bool FFTJetCorrectorDBReader::printAsString
private

Definition at line 58 of file FFTJetCorrectorDBReader.cc.

Referenced by analyze().

◆ readArchive

bool FFTJetCorrectorDBReader::readArchive
private

Definition at line 59 of file FFTJetCorrectorDBReader.cc.

Referenced by analyze().

◆ record

std::string FFTJetCorrectorDBReader::record
private

Definition at line 56 of file FFTJetCorrectorDBReader.cc.

Referenced by analyze().