DD4hep  1.30.0
Detector Description Toolkit for High Energy Physics
MultiLayerTracker_geo.cpp
Go to the documentation of this file.
1 //==========================================================================
2 // AIDA Detector description implementation
3 //--------------------------------------------------------------------------
4 // Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
5 // All rights reserved.
6 //
7 // For the licensing terms see $DD4hepINSTALL/LICENSE.
8 // For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
9 //
10 // Author : M.Frank
11 //
12 //==========================================================================
13 //
14 // Specialized generic detector constructor
15 //
16 //==========================================================================
18 
19 using namespace std;
20 using namespace dd4hep;
21 using namespace dd4hep::detail;
22 
23 static Ref_t create_detector(Detector& description, xml_h e, SensitiveDetector sens) {
24  xml_det_t x_det = e;
25  string det_name = x_det.nameStr();
26  Material air = description.air();
27  DetElement sdet (det_name,x_det.id());
28  Assembly assembly (det_name+"_assembly");
29  PlacedVolume pv;
30  int n = 0;
31 
32  for(xml_coll_t i(x_det,_U(layer)); i; ++i, ++n) {
33  xml_comp_t x_layer = i;
34  string l_name = det_name+_toString(n,"_layer%d");
35  double z = x_layer.outer_z();
36  double rmin = x_layer.inner_r();
37  double r = rmin;
38  DetElement layer(sdet,_toString(n,"layer%d"),x_layer.id());
39  Tube l_tub (rmin,2*rmin,z);
40  Volume l_vol(l_name,l_tub,air);
41  int im = 0;
42 
43  for(xml_coll_t j(x_layer,_U(slice)); j; ++j, ++im) {
44  xml_comp_t x_slice = j;
45  Material mat = description.material(x_slice.materialStr());
46  string s_name= l_name+_toString(im,"_slice%d");
47  double thickness = x_slice.thickness();
48  Tube s_tub(r,r+thickness,z,2*M_PI);
49  Volume s_vol(s_name, s_tub, mat);
50 
51  r += thickness;
52  if ( x_slice.isSensitive() ) {
53  sens.setType("tracker");
54  s_vol.setSensitiveDetector(sens);
55  }
56  // Set Attributes
57  s_vol.setAttributes(description,x_slice.regionStr(),x_slice.limitsStr(),x_slice.visStr());
58  pv = l_vol.placeVolume(s_vol);
59  // Slices have no extra id. Take the ID of the layer!
60  pv.addPhysVolID("slice",im);
61  }
62  l_tub.setDimensions(rmin,r,z);
63  //cout << l_name << " " << rmin << " " << r << " " << z << endl;
64  l_vol.setVisAttributes(description,x_layer.visStr());
65 
66  pv = assembly.placeVolume(l_vol);
67  pv.addPhysVolID("layer",n);
68  layer.setPlacement(pv);
69  }
70  if ( x_det.hasAttr(_U(combineHits)) ) {
71  sdet.setCombineHits(x_det.combineHits(),sens);
72  }
73 
74  pv = description.pickMotherVolume(sdet).placeVolume(assembly);
75  pv.addPhysVolID("system",sdet.id()).addPhysVolID("barrel",0);
76  sdet.setPlacement(pv);
77  return sdet;
78 }
79 
80 DECLARE_DETELEMENT(DD4hep_MultiLayerTracker,create_detector)
81 
dd4hep::xml::Collection_t
Class to support the access to collections of XmlNodes (or XmlElements)
Definition: XMLElements.h:636
dd4hep::SensitiveDetector
Handle class to hold the information of a sensitive detector.
Definition: DetElement.h:44
DECLARE_DETELEMENT
#define DECLARE_DETELEMENT(name, func)
Definition: Factories.h:339
M_PI
#define M_PI
Definition: Handle.h:33
dd4hep::PlacedVolume
Handle class holding a placed volume (also called physical volume)
Definition: Volumes.h:163
dd4hep::PlacedVolume::addPhysVolID
PlacedVolume & addPhysVolID(const std::string &name, int value)
Add identifier.
Definition: Volumes.cpp:501
dd4hep::Handle< NamedObject >
dd4hep::_toString
std::string _toString(bool value)
String conversions: boolean value to string.
Definition: Handle.cpp:332
dd4hep::Detector::pickMotherVolume
virtual Volume pickMotherVolume(const DetElement &sd) const =0
Access mother volume by detector element.
dd4hep::xml::Handle_t
Class to easily access the properties of single XmlElements.
Definition: XMLElements.h:380
dd4hep::Assembly
Implementation class extending the ROOT assembly volumes (TGeoVolumeAssembly)
Definition: Volumes.h:761
dd4hep::Volume::placeVolume
PlacedVolume placeVolume(const Volume &volume) const
Place daughter volume. The position and rotation are the identity.
Definition: Volumes.cpp:859
xml_comp_t
dd4hep::xml::Component xml_comp_t
Definition: XML.h:33
dd4hep::Material
Handle class describing a material.
Definition: Objects.h:272
dd4hep::Detector::material
virtual Material material(const std::string &name) const =0
Retrieve a matrial by its name from the detector description.
dd4hep::DetElement
Handle class describing a detector element.
Definition: DetElement.h:188
dd4hep::Detector::air
virtual Material air() const =0
Return handle to material describing air.
dd4hep::Volume
Handle class holding a placed volume (also called physical volume)
Definition: Volumes.h:370
dd4hep::detail
DD4hep internal namespace.
Definition: Alignments.h:32
xml_det_t
dd4hep::xml::DetElement xml_det_t
Definition: XML.h:32
_U
#define _U(a)
Definition: Tags.h:23
DetFactoryHelper.h
std
Definition: Plugins.h:30
dd4hep
Namespace for the AIDA detector description toolkit.
Definition: AlignmentsCalib.h:28
dd4hep::Detector
The main interface to the dd4hep detector description package.
Definition: Detector.h:90
dd4hep::Tube
Class describing a tube shape of a section of a tube.
Definition: Shapes.h:628
dd4hep::SensitiveDetector::setType
SensitiveDetector & setType(const std::string &typ)
Set detector type (structure, tracker, calorimeter, etc.).
Definition: DetElement.cpp:403