1#include "Tracking/geo/DetectorElement.h"
3#include "Framework/Exception/Exception.h"
4#include "Tracking/geo/GeometryContext.h"
8DetectorElement::~DetectorElement(){};
10const Acts::Transform3& DetectorElement::transform(
11 const Acts::GeometryContext& gctx)
const {
13 EXCEPTION_RAISE(
"BadGeometry",
14 "DetectorElement:: Sensor/Element ID not set");
24 if (element_id > 9999) {
29 auto ctx = gctx.get<GeometryContext*>();
32 if ((ctx->alignment_map_).count(element_id) > 0) {
33 const Acts::Transform3& c_transform = ctx->alignment_map_[element_id];
37 std::cout <<
"Aligned transform" << std::endl;
38 std::cout << c_transform.translation() << std::endl;
39 std::cout << c_transform.rotation() << std::endl;
40 std::cout <<
"Original transform" << std::endl;
41 std::cout << m_transform_.translation() << std::endl;
42 std::cout << m_transform_.rotation() << std::endl;
52const Acts::Surface& DetectorElement::surface()
const {
56 "DetectorElement::Attempted to return reference of null ptr");
59Acts::Surface& DetectorElement::surface() {
63 "DetectorElement::Attempted to return reference of null ptr");
69double DetectorElement::thickness()
const {
71 auto material =
static_cast<const Acts::HomogeneousSurfaceMaterial*
>(
72 m_surface_->surfaceMaterial());
73 return material->materialSlab(Acts::Vector2{0., 0.}).thickness();
unsigned int unpackGeometryIdentifier(const Acts::GeometryIdentifier &geoId)
The geometry identifier will return vol=0 and lay=0 when it is not valid.