ATLASRECTS-5781: TRT_BaseElement MT issues Part I
ATLASRECTS-5781 (ATR-22378) : Breaking in parts as trying to do all thing together back fired ....
The main changes:
- CxxUtils::CachedUniquePtrT<
std::vector<std::unique_ptr<Trk::StraightLineSurface>>>
m_strawSurfaces{};
- CxxUtils::CachedUniquePtrT<std::vector<std::unique_ptr<SurfaceCache>>>
m_strawSurfacesCache{};
+ std::vector<CxxUtils::CachedUniquePtr<Trk::StraightLineSurface>> m_strawSurfaces{};
+ std::vector<CxxUtils::CachedUniquePtr<SurfaceCache>> m_strawSurfacesCache{};
This means we can and do eagerly initialize the vectors since we can not the size during constuctions of an object. so these go
TRT_BaseElement::createStrawSurfaces() const
{
auto strawSurfaces = std::make_unique<
std::vector<std::unique_ptr<Trk::StraightLineSurface>>>(nStraws());
m_strawSurfaces.set(std::move(strawSurfaces));
}
void
TRT_BaseElement::createStrawSurfacesCache() const
{
auto strawSurfacesCache =
std::make_unique<std::vector<std::unique_ptr<SurfaceCache>>>(nStraws());
m_strawSurfacesCache.set(std::move(strawSurfacesCache));
}
and we have
m_nstraws = m_descriptor->nStraws();
m_strawSurfaces.resize(m_nstraws);
m_strawSurfacesCache.resize(m_nstraws);
Due to discussion in !38322 (merged) and the JIRA we might want to be sure that the inner ptr are CachedUniquePtr
The above two combined give us
const Amg::Transform3D&
TRT_BaseElement::strawTransform(unsigned int straw) const
{
if (!m_strawSurfacesCache[straw]) {
Identifier id = m_idHelper->straw_id(identify(), straw);
createSurfaceCache(id);
}
// forward the transform of the cache
return *(m_strawSurfacesCache[straw]->transform());
}
instead of
const Amg::Transform3D& TRT_BaseElement::strawTransform(unsigned int straw) const
{
if (!m_strawSurfacesCache) {createStrawSurfacesCache();}
SurfaceCache* sCachePtr = (*m_strawSurfacesCache)[straw].get();
if (!sCachePtr) {
Identifier id = m_idHelper->straw_id(identify(), straw);
createSurfaceCache(id);
sCachePtr = (*m_strawSurfacesCache)[straw].get();
}
// forward the transform of the cache
return *(sCachePtr->transform());
}
I also used nullptr
, default
/delete
, used a bit more unique_ptr
Plus some other indentation aesthetic changes.
Mentiong @oda
Edited by Christos Anastopoulos