Go to the documentation of this file. 1 #include "DD4hep/DetFactoryHelper.h"
17 double dx =
args.value<
double>(
"Dx");
18 double dz =
args.value<
double>(
"Dz");
19 double angwidth =
args.value<
double>(
"AngWidth");
20 int iaxis =
args.value<
int>(
"Axis");
21 std::vector<std::string>
names =
args.value<std::vector<std::string> >(
"Names");
24 edm::LogVerbatim(
"HCalGeom") <<
"DDHCalXtalAlgo::Parameters for positioning: Axis " << iaxis <<
"\tRadius "
27 <<
"\tNumbers " <<
names.size();
28 for (
unsigned int i = 0;
i <
names.size();
i++)
31 <<
" NameSpace " << idNameSpace;
39 theta[1 - iaxis] = 90._deg;
47 phi[2] = iaxis * 90._deg;
50 phi[2] = (2 - 3 * iaxis) * 90._deg;
61 static const double tol = 0.01_deg;
73 edm::LogVerbatim(
"HCalGeom") <<
"DDHCalXtalAlgo: " << glog.name() <<
" number " <<
i + 1 <<
" positioned in "
#define DECLARE_DDCMS_DETELEMENT(name, func)
constexpr NumType convertRadToDeg(NumType radians)
DDRotationMatrix makeRotation3D(double thetaX, double phiX, double thetaY, double phiY, double thetaZ, double phiZ)
Sin< T >::type sin(const T &t)
const std::string names[nVars_]
Geom::Theta< T > theta() const
constexpr NumType convert2mm(NumType length)
static constexpr long s_executed
Log< level::Info, true > LogVerbatim
T angle(T x1, T y1, T z1, T x2, T y2, T z2)
Abs< T >::type abs(const T &t)
static long algorithm(dd4hep::Detector &, cms::DDParsingContext &ctxt, xml_h e)
std::string_view name() const
dd4hep::Volume volume(const std::string &name, bool exc=true) const