9#include "GeoModelKernel/throwExcept.h"
21 std::regex word_regex(
"(.*)Tracks$");
22 std::smatch match_regex;
24 if ( not std::regex_search(tracks, match_regex, word_regex) or match_regex.size() < 2) {
25 throw std::runtime_error(
26 std::string(
"prefixFromTrackContainerName: key does not contain "
27 "Tracks in the name ") + tracks);
30 return match_regex[1].str();
33#define RECORD_xAOD(key, container, auxContainer, ctx) \
35 SG::WriteHandle handle{key, ctx}; \
36 if (!handle.record(std::move(container), \
37 std::move(auxContainer)).isSuccess()){ \
38 THROW_EXCEPTION("Cannot record "<<key.fullKey()<<" backend"); \
42#define INIT_CHECK(key) \
43 if (!key.initialize().isSuccess()) { \
44 THROW_EXCEPTION("Failed to initialize key "<<key.fullKey()); \
48 const std::string& prefix) {
55 prefix +
"MultiTrajectory";
73 return StatusCode::SUCCESS;
76std::unique_ptr<ActsTrk::MultiTrajectory>
83 auto statesInterface =
85 mmtj.trackStatesAux());
88 auto parametersInterface =
90 mmtj.trackParametersAux());
93 auto jacobiansInterface =
95 mmtj.trackJacobiansAux());
98 auto measurementsInterface =
100 mmtj.trackMeasurementsAux());
107 auto cmtj = std::make_unique<ActsTrk::MultiTrajectory>(
119 cmtj->moveSurfaces(&mmtj);
120 cmtj->moveLinks(&mmtj);
125std::unique_ptr<ActsTrk::PersistentTrackContainer>
130 std::unique_ptr<ActsTrk::MultiTrajectory> constMtj =
131 moveToConst(std::move(
tc.trackStateContainer()), evtContext);
134 if (constMtjHandle.record(std::move(constMtj)).isFailure()) {
135 throw std::runtime_error(
136 "MutableTrackContainerHandlesHelper::moveToConst, can't record "
137 "ConstMultiTrajectory");
140 auto trackSurfacesAux = std::make_unique<xAOD::TrackSurfaceAuxContainer>();
141 tc.container().encodeSurfaces(trackSurfacesAux.get(), geoContext);
143 auto interfaceTrackSummaryContainer =
145 tc.container().m_mutableTrackBackendAux.get());
149 trackSurfacesAux.get());
152 auto constTrackSummary = std::make_unique<ActsTrk::TrackSummaryContainer>(
155 constTrackSummary->restoreDecorations();
156 constTrackSummary->fillFrom(
tc.container());
159 if (constTrackSummaryHandle.record(std::move(constTrackSummary))
161 throw std::runtime_error(
162 "MutableTrackContainerHandlesHelper::moveToConst, can't record "
165 auto constTrack = std::make_unique<ActsTrk::PersistentTrackContainer>(
174 const std::string& prefix) {
180 m_mtjKey = prefix +
"MultiTrajectory";
197 return StatusCode::SUCCESS;
200std::unique_ptr<ActsTrk::MultiTrajectory>
202 const EventContext& evtContext)
const {
206 if (not statesLink.
isValid()) {
207 throw std::runtime_error(
208 "ConstMultiTrajectoryHandle::build, StatesLink is invalid");
218 if (not parametersLink.
isValid()) {
219 throw std::runtime_error(
220 "ConstMultiTrajectoryHandle::build, ParametersLink is invalid");
225 if (not jacobiansLink.
isValid()) {
226 throw std::runtime_error(
227 "ConstMultiTrajectoryHandle::build, JacobiansLink is invalid");
232 if (not measurementsLink.
isValid()) {
233 throw std::runtime_error(
234 "ConstMultiTrajectoryHandle::build, MeasurementsLink is invalid");
239 if (not surfacesLink.
isValid()) {
240 throw std::runtime_error(
241 "ConstMultiTrajectoryHandle::build, SurfacesLink is invalid");
245 auto cmtj = std::make_unique<ActsTrk::MultiTrajectory>(
246 statesLink, parametersLink, jacobiansLink, measurementsLink, surfacesLink);
247 cmtj->fillSurfaces(geo);
251std::unique_ptr<ActsTrk::PersistentTrackContainer>
253 const Acts::GeometryContext& ,
254 const EventContext& evtContext)
const {
256 std::unique_ptr<ActsTrk::MultiTrajectory> mtj =
buildMtj(geo,evtContext);
258 if (mtjHandle.record(std::move(mtj)).isFailure()) {
259 throw std::runtime_error(
260 "ConstTrackContainerHandle<C>::build failed recording MTJ");
264 if (not summaryLink.
isValid()) {
265 throw std::runtime_error(
266 "ConstTrackContainerHandle::build, SummaryLink is invalid");
270 if (not surfacesHandle.isValid()) {
271 throw std::runtime_error(
272 "ConstTrackContainerHandle::build, SurfaceHandle is invalid");
275 auto constTrackSummary = std::make_unique<ActsTrk::TrackSummaryContainer>(summaryLink);
276 constTrackSummary->decodeSurfaces( surfacesHandle.cptr());
279 if (summaryHandle.record(std::move(constTrackSummary)).isFailure()) {
280 throw std::runtime_error(
281 "MutableTrackContainerHandle::build, can't record "
285 auto constTrack = std::make_unique<ActsTrk::PersistentTrackContainer>(
295 template <
typename T>
296 using const_span = std::span<T const>;
299 template <
typename T>
301 const T *
data =
static_cast<const T *
>(aux_container.
getData (accessor.auxid()));
302 const_span<T> ret(
data, aux_container.
size() );
307 template <
typename T>
309 std::size_t
sz=aux_container.
size();
311 return std::span<T>(
data,
sz );
316 std::stringstream
msg;
317 msg <<
"Conflicting values for TrackState.uncalibratedMeasurement. Already set " <<
static_cast<const void *
>(is)
318 <<
" would set " <<
static_cast<const void *
>(should);
319 throw std::runtime_error(
msg.str());
328 const_span<link_t> elementLinks = getElementVector(statesLink, link_accessor);
331 decor(
"uncalibratedMeasurement");
333 std::span<const xAOD::UncalibratedMeasurement *> uncalibratedMeasurements
334 = createDecoration( statesLink, decor);
337 const link_t &el = elementLinks[
index];
340 if (uncalibratedMeasurements[
index] !=
nullptr && a_measurement != uncalibratedMeasurements[
index]) {
341 throwConflictingUncalibratedMeasurementPointerValue(uncalibratedMeasurements[
index], a_measurement);
343 uncalibratedMeasurements[
index]=a_measurement;
347 std::cerr <<
"WARNING no uncalibratedMeasurementLink aux data " << std::endl;
char data[hepevt_bytes_allocation_ATLAS]
Handle class for recording to StoreGate.
#define RECORD_xAOD(key, container, auxContainer, ctx)
#define ATLAS_THREAD_SAFE
SG::ReadHandleKey< xAOD::TrackMeasurementContainer > m_measurementsKey
std::unique_ptr< ActsTrk::PersistentTrackContainer > build(const Acts::TrackingGeometry *geo, const Acts::GeometryContext &geoContext, const EventContext &context) const
SG::ReadHandleKey< xAOD::TrackSurfaceContainer > m_surfacesKey
SG::WriteHandleKey< ActsTrk::MultiTrajectory > m_mtjKey
SG::ReadHandleKey< xAOD::TrackStateContainer > m_statesKey
void restoreUncalibMeasurementPtr(xAOD::TrackStateAuxContainer &statesLink) const
SG::ReadHandleKey< xAOD::TrackJacobianContainer > m_jacobiansKey
SG::WriteHandleKey< ActsTrk::TrackSummaryContainer > m_trackSummaryKey
SG::ReadHandleKey< xAOD::TrackParametersContainer > m_parametersKey
StatusCode initialize(const std::string &prefix)
Sets up the handles.
SG::ReadHandleKey< xAOD::TrackSurfaceContainer > m_trackSurfacesKey
SG::ReadHandleKey< xAOD::TrackSummaryContainer > m_xAODTrackSummaryKey
std::unique_ptr< ActsTrk::MultiTrajectory > buildMtj(const Acts::TrackingGeometry *geo, const EventContext &context) const
Athena implementation of ACTS::MultiTrajectory (ReadWrite version) The data is stored in 4 external b...
SG::WriteHandleKey< xAOD::TrackParametersContainer > m_parametersKey
std::unique_ptr< ActsTrk::PersistentTrackContainer > moveToConst(ActsTrk::MutablePersistentTrackContainer &&tc, const Acts::GeometryContext &geoContext, const EventContext &evtContext) const
produces ActsTrk::ConstTrackContainer with all backends stored in SG
SG::WriteHandleKey< xAOD::TrackMeasurementContainer > m_measurementsKey
SG::WriteHandleKey< xAOD::TrackSurfaceContainer > m_trackSurfacesKey
SG::WriteHandleKey< xAOD::TrackJacobianContainer > m_jacobiansKey
SG::WriteHandleKey< ActsTrk::MultiTrajectory > m_mtjKey
SG::WriteHandleKey< xAOD::TrackSummaryContainer > m_xAODTrackSummaryKey
StatusCode initialize(const std::string &prefix)
Sets up the handles.
SG::WriteHandleKey< ActsTrk::TrackSummaryContainer > m_trackSummaryKey
SG::WriteHandleKey< xAOD::TrackStateContainer > m_statesKey
SG::WriteHandleKey< xAOD::TrackSurfaceContainer > m_surfacesKey
bool test(bit_t bit) const
Test to see if a bit is set.
Object reference supporting deferred reading from StoreGate.
const_pointer getDataPtr() const
Return a pointer to the currently-referenced object.
bool isValid() const
Test to see if the link is dereferencable.
SG::Decorator< T, ALLOC > Decorator
Helper class to provide constant type-safe access to aux data.
SG::auxid_t auxid() const
Return the aux id for this variable.
Helper class to provide type-safe access to aux data.
SG::auxid_t auxid() const
Return the aux id for this variable.
Common base class for the auxiliary containers.
virtual const void * getData(auxid_t auxid) const override
Get a pointer to a given array.
virtual const auxid_set_t & getAuxIDs() const override
Get the types(names) of variables handled by this container.
virtual size_t size() const override
Get the size of the container.
virtual void * getDecoration(auxid_t auxid, size_t size, size_t capacity) override
Get a pointer to a given array, as a decoration.
The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout ge...
std::string prefixFromTrackContainerName(const std::string &tracks)
Parse TrackContainer name to get the prefix for backends The name has to contain XYZTracks,...
std::unique_ptr< IFACE > makeInterfaceContainer(const AUX *aux)
helper to construct interface container for already filled Aux container TODO maybe should be moved t...
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
TrackStateAuxContainer_v1 TrackStateAuxContainer
UncalibratedMeasurement_v1 UncalibratedMeasurement
Define the version of the uncalibrated measurement class.