-
Notifications
You must be signed in to change notification settings - Fork 4.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
LST followups: better work divisions, concrete kernel dimension, some cleanup and fixes #47084
base: master
Are you sure you want to change the base?
LST followups: better work divisions, concrete kernel dimension, some cleanup and fixes #47084
Conversation
cms-bot internal usage |
+code-checks Logs: https://cmssdt.cern.ch/SDT/code-checks/cms-sw-PR-47084/43263 |
A new Pull Request was created by @ariostas for master. It involves the following packages:
@cmsbuild, @jfernan2, @mandrenguyen can you please review it and eventually sign? Thanks. cms-bot commands are listed here |
Tagging @fwyzard since most (if not all) of the comments addressed were his |
test parameters:
|
@cmsbuild please test |
-1 Failed Tests: UnitTests RelVals-GPU Unit TestsI found 1 errors in the following unit tests: ---> test test-das-selected-lumis had ERRORS RelVals-GPU
Comparison SummarySummary:
|
there are a bunch of errors like
the same workflow step3 in the baseline ran OK. So, the crash seems related to this PR. |
assign heterogeneous |
ALPAKA_FN_ACC ALPAKA_FN_INLINE float computeRadiusFromThreeAnchorHits( | ||
TAcc const& acc, float x1, float y1, float x2, float y2, float x3, float y3, float& g, float& f) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
AFAICT this function does not use the passed-in values of g
and f
, i.e. they are purely out-parameters (rather than in-out). How about returning a std::tuple<float, float, float>
or a struct with named members by value instead?
|
||
return WorkDiv<typename Vec::Dim>(adjustedBlocks, adjustedThreads, elementsPerThreadArg); | ||
} | ||
ALPAKA_FN_HOST ALPAKA_FN_INLINE void lstWarning(std::string warning) { edm::LogWarning("LST") << warning; } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ALPAKA_FN_HOST ALPAKA_FN_INLINE void lstWarning(std::string warning) { edm::LogWarning("LST") << warning; } | |
ALPAKA_FN_HOST ALPAKA_FN_INLINE void lstWarning(const std::string& warning) { edm::LogWarning("LST") << warning; } |
to avoid a copy, or
ALPAKA_FN_HOST ALPAKA_FN_INLINE void lstWarning(std::string warning) { edm::LogWarning("LST") << warning; } | |
ALPAKA_FN_HOST ALPAKA_FN_INLINE void lstWarning(std::string_view warning) { edm::LogWarning("LST") << warning; } |
to further avoid constructing the string if e.g. a string literal is passed.
for (unsigned int iLSModule = connectedPixelIndex[i_pLS] + globalBlockIdx[0]; iLSModule < iLSModule_max; | ||
iLSModule += gridBlockExtent[0]) { | ||
for (unsigned int iLSModule : | ||
cms::alpakatools::uniform_elements_z(acc, connectedPixelIndex[i_pLS], iLSModule_max)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If there is a specific reason to use _y
in the outer loop and _z
in the inner (middle) loop, it could be good to document that.
This PR addresses some of the LST followups that we have listed in #46746.
Here is the list of fixes/changes:
cms::alpakatools::makeworkdiv
(instead of our customcreateWorkDiv
) and we now usecms::alpakatools::uniform_elements
for kernel loops.kVerticalModuleSlope
(previously namedlst_INF
). We're doing this in two steps instead of one since the data files also need to be updated. We ensure a smooth transition by first supporting both options and later removing the legacy one.c.c. @slava77 @VourMa