DD4hep  1.30.0
Detector Description Toolkit for High Energy Physics
CylindricalBarrelCalorimeter_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  xml_dim_t dim = x_det.dimensions();
26  Material air = description.air();
27  string det_name = x_det.nameStr();
28  DetElement sdet (det_name,x_det.id());
29  double z = dim.outer_z();
30  double rmin = dim.inner_r();
31  double r = rmin;
32  int n = 0;
33  Tube envelope(rmin,2*rmin,2*z);
34  Volume envelopeVol(det_name+"_envelope",envelope,air);
35 
36  for(xml_coll_t c(x_det,_U(layer)); c; ++c) {
37  xml_comp_t x_layer = c;
38  for(int i=0, im=0, repeat=x_layer.repeat(); i<repeat; ++i, im=0) {
39  string layer_name = det_name + _toString(n,"_layer%d");
40  double rlayer = r;
41  Tube layer_tub(rmin,rlayer,2*z);
42  Volume layer_vol(layer_name,layer_tub,air);
43 
44  for(xml_coll_t l(x_layer,_U(slice)); l; ++l, ++im) {
45  xml_comp_t x_slice = l;
46  double router = r + x_slice.thickness();
47  Material slice_mat = description.material(x_slice.materialStr());
48  string slice_name = layer_name + _toString(im,"slice%d");
49  Tube slice_tube(r,router,z*2);
50  Volume slice_vol (slice_name,slice_tube,slice_mat);
51 
52  if ( x_slice.isSensitive() ) {
53  sens.setType("calorimeter");
54  slice_vol.setSensitiveDetector(sens);
55  }
56  r = router;
57  slice_vol.setAttributes(description,x_slice.regionStr(),x_slice.limitsStr(),x_slice.visStr());
58  // Instantiate physical volume
59  layer_vol.placeVolume(slice_vol);
60  }
61  layer_vol.setVisAttributes(description,x_layer.visStr());
62  layer_tub.setDimensions(rlayer,r,z*2,0,2*M_PI);
63 
64  PlacedVolume layer_physvol = envelopeVol.placeVolume(layer_vol);
65  layer_physvol.addPhysVolID("layer",n);
66  ++n;
67  }
68  }
69  envelope.setDimensions(rmin,r,2*z);
70  // Set region of slice
71  envelopeVol.setAttributes(description,x_det.regionStr(),x_det.limitsStr(),x_det.visStr());
72 
73  PlacedVolume physvol = description.pickMotherVolume(sdet).placeVolume(envelopeVol);
74  physvol.addPhysVolID("system",sdet.id()).addPhysVolID(_U(barrel),0);
75  sdet.setPlacement(physvol);
76  return sdet;
77 }
78 
79 DECLARE_DETELEMENT(DD4hep_CylindricalBarrelCalorimeter,create_detector)
80 
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:173
dd4hep::PlacedVolume::addPhysVolID
PlacedVolume & addPhysVolID(const std::string &name, int value)
Add identifier.
Definition: Volumes.cpp:485
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::Volume::placeVolume
PlacedVolume placeVolume(const Volume &volume) const
Place daughter volume. The position and rotation are the identity.
Definition: Volumes.cpp:830
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:378
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
xml_dim_t
dd4hep::xml::Dimension xml_dim_t
Definition: XML.h:31
dd4hep::SensitiveDetector::setType
SensitiveDetector & setType(const std::string &typ)
Set detector type (structure, tracker, calorimeter, etc.).
Definition: DetElement.cpp:403