CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Attributes
TestAlpakaAnalyzer Class Reference
Inheritance diagram for TestAlpakaAnalyzer:
edm::global::EDAnalyzer<> edm::global::EDAnalyzerBase edm::EDConsumerBase

Public Member Functions

void analyze (edm::StreamID sid, edm::Event const &event, edm::EventSetup const &) const override
 
 TestAlpakaAnalyzer (edm::ParameterSet const &config)
 
- Public Member Functions inherited from edm::global::EDAnalyzer<>
 EDAnalyzer ()=default
 
 EDAnalyzer (const EDAnalyzer &)=delete
 
const EDAnalyzeroperator= (const EDAnalyzer &)=delete
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
bool wantsInputProcessBlocks () const final
 
bool wantsProcessBlocks () const final
 
bool wantsStreamLuminosityBlocks () const final
 
bool wantsStreamRuns () const final
 
- Public Member Functions inherited from edm::global::EDAnalyzerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzerBase ()
 
ModuleDescription const & moduleDescription () const
 
 ~EDAnalyzerBase () 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
 
ESResolverIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
std::vector< ESResolverIndex > 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
 
void selectInputProcessBlocks (ProductRegistry const &productRegistry, ProcessBlockHelperBase const &processBlockHelperBase)
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProductResolverIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
- Static Public Member Functions inherited from edm::global::EDAnalyzerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 

Private Attributes

edm::EDGetTokenT< unsigned short > backendToken_
 
std::optional< cms::alpakatools::BackendexpectBackend_
 
const int expectSize_
 
const edm::InputTag source_
 
const edm::EDGetTokenT< portabletest::TestHostCollectiontoken_
 

Additional Inherited Members

- Public Types inherited from edm::global::EDAnalyzerBase
typedef EDAnalyzerBase ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- 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 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

Definition at line 83 of file TestAlpakaAnalyzer.cc.

Constructor & Destructor Documentation

◆ TestAlpakaAnalyzer()

TestAlpakaAnalyzer::TestAlpakaAnalyzer ( edm::ParameterSet const &  config)
inline

Definition at line 85 of file TestAlpakaAnalyzer.cc.

86  : source_{config.getParameter<edm::InputTag>("source")},
88  expectSize_{config.getParameter<int>("expectSize")} {
89  if (std::string const& eb = config.getParameter<std::string>("expectBackend"); not eb.empty()) {
92  }
93  }
const edm::EDGetTokenT< portabletest::TestHostCollection > token_
std::optional< cms::alpakatools::Backend > expectBackend_
Definition: config.py:1
std::string const & label() const
Definition: InputTag.h:36
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
const edm::InputTag source_
edm::EDGetTokenT< unsigned short > backendToken_
Backend toBackend(std::string_view name)
Definition: Backend.cc:13
std::string const & process() const
Definition: InputTag.h:40

Member Function Documentation

◆ analyze()

void TestAlpakaAnalyzer::analyze ( edm::StreamID  sid,
edm::Event const &  event,
edm::EventSetup const &   
) const
inlineoverridevirtual

Implements edm::global::EDAnalyzerBase.

Definition at line 95 of file TestAlpakaAnalyzer.cc.

References python.cmstools::all(), cms::cuda::assert(), jetsAK4_CHS_cff::backend, backendToken_, PortableHostCollection< T >::buffer(), PortableHostCollection< T >::const_view(), edm::InputTag::encode(), Exception, expectBackend_, expectSize_, HLT_2023v12_cff::flags, mps_fire::i, makeMuonMisalignmentScenario::matrix, mps_check::msg, source_, token_, cms::alpakatools::toString(), and PortableHostCollection< T >::view().

95  {
96  portabletest::TestHostCollection const& product = event.get(token_);
97  auto const& view = product.const_view();
98  auto& mview = product.view();
99  auto const& cmview = product.view();
100 
101  if (expectSize_ >= 0 and expectSize_ != view.metadata().size()) {
102  throw cms::Exception("Assert") << "Expected input collection size " << expectSize_ << ", got "
103  << view.metadata().size();
104  }
105 
106  {
107  edm::LogInfo msg("TestAlpakaAnalyzer");
108  msg << source_.encode() << ".size() = " << view.metadata().size() << '\n';
109  msg << " data @ " << product.buffer().data() << ",\n"
110  << " x @ " << view.metadata().addressOf_x() << " = " << Column(view.x(), view.metadata().size()) << ",\n"
111  << " y @ " << view.metadata().addressOf_y() << " = " << Column(view.y(), view.metadata().size()) << ",\n"
112  << " z @ " << view.metadata().addressOf_z() << " = " << Column(view.z(), view.metadata().size()) << ",\n"
113  << " id @ " << view.metadata().addressOf_id() << " = " << Column(view.id(), view.metadata().size())
114  << ",\n"
115  << " r @ " << view.metadata().addressOf_r() << " = " << view.r() << '\n'
116  << " flags @ " << view.metadata().addressOf_flags() << " = " << Column(view.flags(), view.metadata().size())
117  << ",\n"
118  << " m @ " << view.metadata().addressOf_m() << " = { ... {" << view[1].m()(1, Eigen::indexing::all)
119  << " } ... } \n";
120  msg << std::hex << " [y - x] = 0x"
121  << reinterpret_cast<intptr_t>(view.metadata().addressOf_y()) -
122  reinterpret_cast<intptr_t>(view.metadata().addressOf_x())
123  << " [z - y] = 0x"
124  << reinterpret_cast<intptr_t>(view.metadata().addressOf_z()) -
125  reinterpret_cast<intptr_t>(view.metadata().addressOf_y())
126  << " [id - z] = 0x"
127  << reinterpret_cast<intptr_t>(view.metadata().addressOf_id()) -
128  reinterpret_cast<intptr_t>(view.metadata().addressOf_z())
129  << " [r - id] = 0x"
130  << reinterpret_cast<intptr_t>(view.metadata().addressOf_r()) -
131  reinterpret_cast<intptr_t>(view.metadata().addressOf_id())
132  << " [flags - r] = 0x"
133  << reinterpret_cast<intptr_t>(view.metadata().addressOf_flags()) -
134  reinterpret_cast<intptr_t>(view.metadata().addressOf_r())
135  << " [m - flags] = 0x"
136  << reinterpret_cast<intptr_t>(view.metadata().addressOf_m()) -
137  reinterpret_cast<intptr_t>(view.metadata().addressOf_flags());
138  }
139 
140  checkViewAddresses(view);
141  checkViewAddresses(mview);
142  checkViewAddresses(cmview);
143 
144  const portabletest::Matrix matrix{{1, 2, 3, 4, 5, 6}, {2, 4, 6, 8, 10, 12}, {3, 6, 9, 12, 15, 18}};
145  const portabletest::Array flags{{6, 4, 2, 0}};
146  assert(view.r() == 1.);
147  for (int32_t i = 0; i < view.metadata().size(); ++i) {
148  auto vi = view[i];
149  assert(vi.x() == 0.);
150  assert(vi.y() == 0.);
151  assert(vi.z() == 0.);
152  assert(vi.id() == i);
153  assert(vi.flags() == flags);
154  assert(vi.m() == matrix * i);
155  }
156 
157  if (expectBackend_) {
158  auto backend = static_cast<cms::alpakatools::Backend>(event.get(backendToken_));
159  if (expectBackend_ != backend) {
160  throw cms::Exception("Assert") << "Expected input backend " << cms::alpakatools::toString(*expectBackend_)
161  << ", got " << cms::alpakatools::toString(backend);
162  }
163  }
164  }
const edm::EDGetTokenT< portabletest::TestHostCollection > token_
def all(container)
workaround iterator generators for ROOT classes
Definition: cmstools.py:25
std::string encode() const
Definition: InputTag.cc:159
Eigen::Matrix< double, 3, 6 > Matrix
Definition: TestSoA.h:19
std::optional< cms::alpakatools::Backend > expectBackend_
assert(be >=bs)
ConstView const & const_view() const
const edm::InputTag source_
std::string_view toString(Backend backend)
Definition: Backend.cc:24
edm::EDGetTokenT< unsigned short > backendToken_
tuple msg
Definition: mps_check.py:286

◆ fillDescriptions()

static void TestAlpakaAnalyzer::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
inlinestatic

Definition at line 166 of file TestAlpakaAnalyzer.cc.

References edm::ConfigurationDescriptions::addWithDefaultLabel(), submitPVResolutionJobs::desc, and AlCaHLTBitMon_QueryRunRegistry::string.

166  {
168  desc.add<edm::InputTag>("source");
169  desc.add<int>("expectSize", -1)
170  ->setComment("Expected size of the input collection. Values < 0 mean the check is not performed. Default: -1");
171  desc.add<std::string>("expectBackend", "")
172  ->setComment(
173  "Expected backend of the input collection. Empty value means to not perform the check. Default: empty "
174  "string");
175  descriptions.addWithDefaultLabel(desc);
176  }
void addWithDefaultLabel(ParameterSetDescription const &psetDescription)

Member Data Documentation

◆ backendToken_

edm::EDGetTokenT<unsigned short> TestAlpakaAnalyzer::backendToken_
private

Definition at line 181 of file TestAlpakaAnalyzer.cc.

Referenced by analyze().

◆ expectBackend_

std::optional<cms::alpakatools::Backend> TestAlpakaAnalyzer::expectBackend_
private

Definition at line 182 of file TestAlpakaAnalyzer.cc.

Referenced by analyze().

◆ expectSize_

const int TestAlpakaAnalyzer::expectSize_
private

Definition at line 183 of file TestAlpakaAnalyzer.cc.

Referenced by analyze().

◆ source_

const edm::InputTag TestAlpakaAnalyzer::source_
private

◆ token_

const edm::EDGetTokenT<portabletest::TestHostCollection> TestAlpakaAnalyzer::token_
private

Definition at line 180 of file TestAlpakaAnalyzer.cc.

Referenced by analyze().