1#include "Tracking/geo/TrackersTrackingGeometry.h"
3#include "Framework/Exception/Exception.h"
7const std::string TrackersTrackingGeometry::NAME =
"TrackersTrackingGeometry";
9TrackersTrackingGeometry::TrackersTrackingGeometry(
10 const Acts::GeometryContext& gctx,
const std::string& gdml,
11 double tracker_y_length,
double tracker_z_length)
12 : TrackingGeometry(NAME, gctx, gdml) {
13 tagger_ = findDaughterByName(f_world_phys_vol_,
"tagger_PV");
14 buildTaggerLayoutMap(tagger_,
"tagger");
15 Acts::CuboidVolumeBuilder::VolumeConfig tagger_volume_cfg = buildVolumeConfig(
16 tagger_, tagger_layout_, tracker_y_length, tracker_z_length,
"Tagger");
18 recoil_ = findDaughterByName(f_world_phys_vol_,
"recoil_PV");
19 buildRecoilLayoutMap(recoil_,
"recoil");
20 Acts::CuboidVolumeBuilder::VolumeConfig recoil_volume_cfg = buildVolumeConfig(
21 recoil_, recoil_layout_, tracker_y_length, tracker_z_length,
"Recoil");
23 std::vector<Acts::CuboidVolumeBuilder::VolumeConfig> vol_builder_configs{
24 tagger_volume_cfg, recoil_volume_cfg};
27 Acts::CuboidVolumeBuilder cvb;
29 Acts::CuboidVolumeBuilder::Config config;
30 config.position = {-200, 0., 0.};
35 config.length = {900, tracker_y_length, tracker_z_length};
36 config.volumeCfg = vol_builder_configs;
38 cvb.setConfig(config);
40 Acts::TrackingGeometryBuilder::Config tgb_cfg;
41 tgb_cfg.trackingVolumeBuilders.push_back(
42 [=](
const auto& cxt,
const auto& inner,
const auto&) {
43 return cvb.trackingVolume(cxt, inner,
nullptr);
46 Acts::TrackingGeometryBuilder tgb(tgb_cfg);
47 t_geometry_ = tgb.trackingGeometry(gctx_);
50 makeLayerSurfacesMap();
53void TrackersTrackingGeometry::buildRecoilLayoutMap(G4VPhysicalVolume* pvol,
54 std::string surfacename) {
55 ldmx_log(trace) <<
"Building layout for the " << pvol->GetName()
57 getAllDaughters(pvol);
60 Acts::Transform3 tracker_transform = getTransform(*pvol);
62 G4LogicalVolume* l_vol = pvol->GetLogicalVolume();
63 for (G4int i = 0; i < l_vol->GetNoDaughters(); i++) {
64 std::string sln = l_vol->GetDaughter(i)->GetName();
65 if (sln.find(surfacename) != std::string::npos) {
66 G4VPhysicalVolume* component0_volume{
nullptr};
67 G4VPhysicalVolume* active_sensor{
nullptr};
68 Acts::Transform3 ref1_transform = getTransform(*(l_vol->GetDaughter(i)));
69 int sensor_copy_nr = -999;
73 if (sln.find(
"axial") != std::string::npos ||
74 sln.find(
"stereo") != std::string::npos) {
76 findDaughterByName(l_vol->GetDaughter(i),
77 "LDMXRecoilL14ModuleVolume_component0_physvol");
78 if (!component0_volume)
79 EXCEPTION_RAISE(
"BadGeometry",
80 "Could not find component0 volume for L14 Recoil");
81 active_sensor = findDaughterByName(
83 "LDMXRecoilL14ModuleVolume_component0Sensor0_physvol");
89 else if (sln.find(
"l5_sensor") != std::string::npos ||
90 sln.find(
"l6_sensor") != std::string::npos) {
92 findDaughterByName(l_vol->GetDaughter(i),
93 "LDMXRecoilL56ModuleVolume_component0_physvol");
94 if (!component0_volume)
95 EXCEPTION_RAISE(
"BadGeometry",
96 "Could not find component0 volume for L56 Recoil");
97 active_sensor = findDaughterByName(
99 "LDMXRecoilL56ModuleVolume_component0Sensor0_physvol");
104 else if (sln.find(
"sensor_vol")) {
106 findDaughterByName(l_vol->GetDaughter(i),
"active_sensor");
107 sensor_copy_nr = l_vol->GetDaughter(i)->GetCopyNo();
111 EXCEPTION_RAISE(
"BadGeometry",
"Could not build recoil layout");
114 EXCEPTION_RAISE(
"BadGeometry",
115 "Could not find ActiveSensor for recoil volume");
117 Acts::Transform3 ref2_transform = Acts::Transform3::Identity();
119 if (component0_volume)
120 ref2_transform = getTransform(*(component0_volume));
122 std::shared_ptr<Acts::PlaneSurface> sensor_surface = getSurfacePtr(
123 active_sensor, tracker_transform * ref1_transform * ref2_transform);
126 if (sln ==
"recoil_l1_axial" || sln ==
"recoil_l1_stereo" ||
127 sensor_copy_nr == 10 || sensor_copy_nr == 20)
128 recoil_layout_[
"recoil_tracker_L1"].push_back(sensor_surface);
130 if (sln ==
"recoil_l2_axial" || sln ==
"recoil_l2_stereo" ||
131 sensor_copy_nr == 30 || sensor_copy_nr == 40)
132 recoil_layout_[
"recoil_tracker_L2"].push_back(sensor_surface);
134 if (sln ==
"recoil_l3_axial" || sln ==
"recoil_l3_stereo" ||
135 sensor_copy_nr == 50 || sensor_copy_nr == 60)
136 recoil_layout_[
"recoil_tracker_L3"].push_back(sensor_surface);
138 if (sln ==
"recoil_l4_axial" || sln ==
"recoil_l4_stereo" ||
139 sensor_copy_nr == 70 || sensor_copy_nr == 80)
140 recoil_layout_[
"recoil_tracker_L4"].push_back(sensor_surface);
142 if (sln ==
"recoil_l5_sensor1" || sln ==
"recoil_l5_sensor2" ||
143 sln ==
"recoil_l5_sensor3" || sln ==
"recoil_l5_sensor4" ||
144 sln ==
"recoil_l5_sensor5" || sln ==
"recoil_l5_sensor6" ||
145 sln ==
"recoil_l5_sensor7" || sln ==
"recoil_l5_sensor8" ||
146 sln ==
"recoil_l5_sensor9" || sln ==
"recoil_l5_sensor10" ||
147 (sensor_copy_nr >= 90 && sensor_copy_nr <= 99))
149 recoil_layout_[
"recoil_tracker_L5"].push_back(sensor_surface);
151 if (sln ==
"recoil_l6_sensor1" || sln ==
"recoil_l6_sensor2" ||
152 sln ==
"recoil_l6_sensor3" || sln ==
"recoil_l6_sensor4" ||
153 sln ==
"recoil_l6_sensor5" || sln ==
"recoil_l6_sensor6" ||
154 sln ==
"recoil_l6_sensor7" || sln ==
"recoil_l6_sensor8" ||
155 sln ==
"recoil_l6_sensor9" || sln ==
"recoil_l6_sensor10" ||
156 (sensor_copy_nr >= 100 && sensor_copy_nr <= 109))
157 recoil_layout_[
"recoil_tracker_L6"].push_back(sensor_surface);
166void TrackersTrackingGeometry::buildTaggerLayoutMap(G4VPhysicalVolume* pvol,
167 std::string surfacename) {
168 ldmx_log(trace) <<
"Building layout for the " << pvol->GetName()
173 Acts::Transform3 tracker_transform = getTransform(*pvol);
175 G4LogicalVolume* l_vol = pvol->GetLogicalVolume();
176 for (G4int i = 0; i < l_vol->GetNoDaughters(); i++) {
177 std::string sln = l_vol->GetDaughter(i)->GetName();
180 if (sln.find(surfacename) != std::string::npos) {
205 Acts::Transform3 ref1_transform = getTransform(*(l_vol->GetDaughter(i)));
207 G4VPhysicalVolume* component0_volume = findDaughterByName(
208 l_vol->GetDaughter(i),
"LDMXTaggerModuleVolume_component0_physvol");
210 Acts::Transform3 ref2_transform = Acts::Transform3::Identity();
211 G4VPhysicalVolume* active_sensor =
nullptr;
212 int sensor_copy_nr = -999;
215 if (component0_volume) {
216 ref2_transform = getTransform(*(component0_volume));
217 active_sensor = findDaughterByName(
219 "LDMXTaggerModuleVolume_component0Sensor0_physvol");
224 findDaughterByName(l_vol->GetDaughter(i),
"active_sensor");
225 sensor_copy_nr = (l_vol->GetDaughter(i))->GetCopyNo();
228 if (!active_sensor) {
229 ldmx_log(fatal) <<
"Could not find the ActiveSensor for tagger volume "
230 << l_vol->GetDaughter(i)->GetName();
234 std::shared_ptr<Acts::PlaneSurface> sensor_surface = getSurfacePtr(
235 active_sensor, tracker_transform * ref1_transform * ref2_transform);
237 if (sln ==
"LDMXTaggerModuleVolume_physvol1" ||
238 sln ==
"LDMXTaggerModuleVolume_physvol2" || sensor_copy_nr == 130 ||
239 sensor_copy_nr == 140)
240 tagger_layout_[
"tagger_tracker_L1"].push_back(sensor_surface);
242 if (sln ==
"LDMXTaggerModuleVolume_physvol3" ||
243 sln ==
"LDMXTaggerModuleVolume_physvol4" || sensor_copy_nr == 110 ||
244 sensor_copy_nr == 120)
245 tagger_layout_[
"tagger_tracker_L2"].push_back(sensor_surface);
247 if (sln ==
"LDMXTaggerModuleVolume_physvol5" ||
248 sln ==
"LDMXTaggerModuleVolume_physvol6" || sensor_copy_nr == 90 ||
249 sensor_copy_nr == 100)
250 tagger_layout_[
"tagger_tracker_L3"].push_back(sensor_surface);
252 if (sln ==
"LDMXTaggerModuleVolume_physvol7" ||
253 sln ==
"LDMXTaggerModuleVolume_physvol8" || sensor_copy_nr == 70 ||
254 sensor_copy_nr == 80)
255 tagger_layout_[
"tagger_tracker_L4"].push_back(sensor_surface);
257 if (sln ==
"LDMXTaggerModuleVolume_physvol9" ||
258 sln ==
"LDMXTaggerModuleVolume_physvol10" || sensor_copy_nr == 50 ||
259 sensor_copy_nr == 60)
260 tagger_layout_[
"tagger_tracker_L5"].push_back(sensor_surface);
262 if (sln ==
"LDMXTaggerModuleVolume_physvol11" ||
263 sln ==
"LDMXTaggerModuleVolume_physvol12" || sensor_copy_nr == 30 ||
264 sensor_copy_nr == 40)
265 tagger_layout_[
"tagger_tracker_L6"].push_back(sensor_surface);
267 if (sln ==
"LDMXTaggerModuleVolume_physvol13" ||
268 sln ==
"LDMXTaggerModuleVolume_physvol14" || sensor_copy_nr == 10 ||
269 sensor_copy_nr == 20)
270 tagger_layout_[
"tagger_tracker_L7"].push_back(sensor_surface);
276std::shared_ptr<Acts::PlaneSurface> TrackersTrackingGeometry::getSurfacePtr(
277 G4VPhysicalVolume* pvol, Acts::Transform3 ref_trans) {
279 ldmx_log(fatal) <<
"pvol is nullptr";
283 Acts::Transform3 surface_transform = getTransform(*pvol);
285 surface_transform = ref_trans * surface_transform;
288 Acts::Transform3 surface_transform_tracker = toTracker(surface_transform);
290 ldmx_log(trace) <<
"THE SENSOR TRANSFORM - TRANSLATION";
291 ldmx_log(trace) << surface_transform.translation()(0);
292 ldmx_log(trace) << surface_transform.translation()(1);
293 ldmx_log(trace) << surface_transform.translation()(2);
294 ldmx_log(trace) <<
"THE SENSOR TRANSFORM - ROTATION";
295 ldmx_log(trace) << surface_transform.rotation();
297 ldmx_log(trace) <<
"TO THE TRACKER FRAME";
298 ldmx_log(trace) << surface_transform_tracker.translation()(0);
299 ldmx_log(trace) << surface_transform_tracker.translation()(1);
300 ldmx_log(trace) << surface_transform_tracker.translation()(2);
301 ldmx_log(trace) <<
"THE SENSOR TRANSFORM - ROTATION";
302 ldmx_log(trace) << surface_transform_tracker.rotation();
328 Acts::Material silicon = Acts::Material::fromMassDensity(
329 95.7 * Acts::UnitConstants::mm, 465.2 * Acts::UnitConstants::mm, 28.03,
330 14., 2.32 * Acts::UnitConstants::g / Acts::UnitConstants::cm3);
333 G4Box* surface_solid = (G4Box*)(pvol->GetLogicalVolume()->GetSolid());
335 ldmx_log(trace) <<
"Sensor Dimensions";
336 ldmx_log(trace) << surface_solid->GetXHalfLength() <<
" "
337 << surface_solid->GetYHalfLength() <<
" "
338 << surface_solid->GetZHalfLength() <<
" ";
342 2 * surface_solid->GetZHalfLength() * Acts::UnitConstants::mm;
343 Acts::MaterialSlab silicon_slab(silicon, thickness);
346 std::shared_ptr<const Acts::RectangleBounds> rect_bounds =
347 std::make_shared<const Acts::RectangleBounds>(Acts::RectangleBounds(
348 surface_solid->GetXHalfLength() * Acts::UnitConstants::mm,
349 surface_solid->GetYHalfLength() * Acts::UnitConstants::mm));
352 std::shared_ptr<Acts::PlaneSurface> surface =
353 Acts::Surface::makeShared<Acts::PlaneSurface>(surface_transform_tracker,
355 surface->assignSurfaceMaterial(
356 std::make_shared<Acts::HomogeneousSurfaceMaterial>(silicon_slab));
361 auto det_element = std::make_shared<tracking::geo::DetectorElement>(
362 std::static_pointer_cast<Acts::Surface>(surface),
363 surface_transform_tracker, thickness);
369 surface->assignDetectorElement(std::move(*det_element));
370 det_elements_.push_back(det_element);
375Acts::CuboidVolumeBuilder::VolumeConfig
376TrackersTrackingGeometry::buildVolumeConfig(
377 const G4VPhysicalVolume* detector,
378 const std::map<std::string,
379 std::vector<std::shared_ptr<const Acts::Surface>>>
381 double tracker_y_length,
double tracker_z_length,
382 const std::string& volumeName) {
383 Acts::CuboidVolumeBuilder::VolumeConfig sub_det_volume_config;
386 Acts::Transform3 sub_det_transform = getTransform(*detector,
true);
389 Acts::Vector3 sub_det_position = {
390 sub_det_transform.translation()(0) - 1,
391 sub_det_transform.translation()(1),
392 sub_det_transform.translation()(2),
395 ldmx_log(trace) << sub_det_position;
397 G4Box* sub_det_box = (G4Box*)(detector->GetLogicalVolume()->GetSolid());
401 2 * (sub_det_box->GetZHalfLength() + 1) * Acts::UnitConstants::mm;
402 ldmx_log(info) <<
"x_length = " << x_length
403 <<
" y_length = " << tracker_y_length
404 <<
" z_length = " << tracker_z_length;
406 sub_det_volume_config.position = sub_det_position;
407 sub_det_volume_config.length = {x_length, tracker_y_length, tracker_z_length};
408 sub_det_volume_config.name = volumeName;
411 Acts::Material subdet_mat = Acts::Material();
412 sub_det_volume_config.volumeMaterial =
413 std::make_shared<Acts::HomogeneousVolumeMaterial>(subdet_mat);
415 std::vector<Acts::CuboidVolumeBuilder::LayerConfig> layer_config;
418 for (
auto& layer : layout) {
419 ldmx_log(trace) << layer.first <<
" : surfaces==>" << layer.second.size();
421 Acts::CuboidVolumeBuilder::LayerConfig lcfg;
422 lcfg.surfaces = layer.second;
425 double clearance = 0.01;
426 double thickness = layer.second.front()
428 ->materialSlab(Acts::Vector2{0., 0.})
431 lcfg.envelopeX = std::array<double, 2>{thickness / 2. + clearance,
432 thickness / 2. + clearance};
434 layer_config.push_back(lcfg);
437 sub_det_volume_config.layerCfg = layer_config;
439 return sub_det_volume_config;