1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
#ifndef VECGEOM_VOLUMES_UTILITIES_GENERATION_UTILITIES_H
#define VECGEOM_VOLUMES_UTILITIES_GENERATION_UTILITIES_H
namespace vecgeom {
inline namespace VECGEOM_IMPL_NAMESPACE {
template <typename SpecializationT>
VECCORE_ATT_DEVICE
VPlacedVolume *CreateSpecializedWithPlacement(LogicalVolume const *const logical_volume,
Transformation3D const *const transformation,
#ifdef VECCORE_CUDA
const int id, const int copy_no, const int child_id,
#endif
VPlacedVolume *const placement)
{
if (placement) {
return new (placement) SpecializationT(logical_volume, transformation
#ifdef VECCORE_CUDA
,
id, copy_no, child_id
#endif
); // TODO: add bounding box?
}
return new SpecializationT(
#ifdef VECCORE_CUDA
logical_volume, transformation, id, copy_no, child_id);
#else
logical_volume, transformation);
#endif
}
} // namespace VECGEOM_IMPL_NAMESPACE
} // namespace vecgeom
#endif // VECGEOM_VOLUMES_UTILITIES_GENERATION_UTILITIES_H
|