41 const EventContext& ctx)
const {
46 if (input ==
nullptr) {
48 return StatusCode::FAILURE;
52 const std::size_t nTracks = input->size();
57 auto output = std::make_unique<xAOD::TrackParticleContainer>();
58 auto outputAux = std::make_unique<xAOD::AuxContainerBase>();
60 ATH_CHECK(outputHandle.record(std::move(output), std::move(outputAux)));
61 return StatusCode::SUCCESS;
65 vecmem::host_memory_resource hostMR;
67 vecmem::cuda::device_memory_resource deviceMR;
69 vecmem::cuda::copy copy;
72 TrackParticleContainer::buffer inputHostBuffer(input->size(), hostMR);
73 TrackParticleContainer::buffer inputDeviceBuffer(input->size(), deviceMR);
76 static const SG::AuxElement::ConstAccessor<float> thetaAcc(
"theta");
77 static const SG::AuxElement::ConstAccessor<float> phiAcc(
"phi");
78 static const SG::AuxElement::ConstAccessor<float> qOverPAcc(
"qOverP");
79 std::memcpy(inputHostBuffer.get<0>().ptr(), thetaAcc.getDataArray(*input),
80 nTracks *
sizeof(
float));
81 std::memcpy(inputHostBuffer.get<1>().ptr(), phiAcc.getDataArray(*input),
82 nTracks *
sizeof(
float));
83 std::memcpy(inputHostBuffer.get<2>().ptr(), qOverPAcc.getDataArray(*input),
84 nTracks *
sizeof(
float));
87 copy(inputHostBuffer, inputDeviceBuffer)->wait();
90 TrackParticleContainer::buffer outputDeviceBuffer(input->size(), deviceMR);
91 TrackParticleContainer::buffer outputHostBuffer(input->size(), hostMR);
97 copy(outputDeviceBuffer, outputHostBuffer)->wait();
100 auto outputAux = std::make_unique<xAOD::AuxContainerBase>();
102 std::memcpy(outputAux->getData(thetaAcc.auxid(), nTracks, nTracks),
103 outputHostBuffer.get<0>().ptr(), nTracks *
sizeof(
float));
104 std::memcpy(outputAux->getData(phiAcc.auxid(), nTracks, nTracks),
105 outputHostBuffer.get<1>().ptr(), nTracks *
sizeof(
float));
106 std::memcpy(outputAux->getData(qOverPAcc.auxid(), nTracks, nTracks),
107 outputHostBuffer.get<2>().ptr(), nTracks *
sizeof(
float));
108 auto output = std::make_unique<xAOD::TrackParticleContainer>();
109 for (std::size_t i = 0; i < nTracks; ++i) {
112 output->setStore(outputAux.get());
116 ATH_CHECK(outputHandle.record(std::move(output), std::move(outputAux)));
119 return StatusCode::SUCCESS;
virtual StatusCode execute(const EventContext &ctx) const override
Function executing the algorithm.
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_inputKey
The input container.
SG::WriteHandleKey< xAOD::TrackParticleContainer > m_outputKey
The output container.
virtual StatusCode initialize() override
Function initialising the algorithm.
void copyAuxStoreThinned(const SG::IConstAuxStore &orig, SG::IAuxStore ©, const SG::ThinningInfo *info)
Helper to copy an aux store while applying thinning.