242 throw cms::Exception(
"TGeoMgrFromDdd::createShape * solid " + iName +
" is not declared * ");
244 throw cms::Exception(
"TGeoMgrFromDdd::createShape * solid " + defined.first->name() +
" is not defined *");
247 if (rSolid ==
nullptr) {
249 switch (iSolid.
shape()) {
254 rSolid =
new TGeoConeSeg(iName.c_str(),
265 rSolid =
new TGeoTubeSeg(iName.c_str(),
274 rSolid =
new TGeoCtub(iName.c_str(),
288 rSolid =
new TGeoTrap(iName.c_str(),
302 rSolid =
new TGeoPcon(iName.c_str(),
params[0] / deg,
params[1] / deg, (
params.size() - 2) / 3);
310 for (std::vector<double>::iterator it =
temp.begin() + 3; it !=
temp.end(); ++it) {
313 rSolid->SetDimensions(&(*(
temp.begin())));
317 rSolid =
new TGeoPgon(
326 for (std::vector<double>::iterator it =
temp.begin() + 4; it !=
temp.end(); ++it) {
329 rSolid->SetDimensions(&(*(
temp.begin())));
334 std::vector<double>
x = extrPgon.xVec();
336 std::vector<double>
y = extrPgon.yVec();
338 std::vector<double>
z = extrPgon.zVec();
339 std::vector<double> zx = extrPgon.zxVec();
340 std::vector<double> zy = extrPgon.zyVec();
341 std::vector<double> zscale = extrPgon.zscaleVec();
343 TGeoXtru* mySolid =
new TGeoXtru(
z.size());
344 mySolid->DefinePolygon(
x.size(), &(*
x.begin()), &(*
y.begin()));
346 mySolid->DefineSection(
i,
z[
i] / cm, zx[
i] / cm, zy[
i] / cm, zscale[
i]);
356 double r =
pt.radius();
357 bool atMinusZ =
pt.atMinusZ();
360 bool intersec =
false;
367 double halfOpeningAngle = asin(
x /
std::abs(
r)) / deg;
368 double displacement = 0;
377 h =
pt.y1() <
pt.y2() ?
pt.y2() :
pt.y1();
380 displacement = -
pt.halfZ() -
delta;
381 startPhi = 90. - halfOpeningAngle;
383 displacement =
pt.halfZ() +
delta;
384 startPhi = -90. - halfOpeningAngle;
388 displacement = -
pt.halfZ() +
delta;
389 startPhi = 270. - halfOpeningAngle;
392 displacement =
pt.halfZ() -
delta;
393 startPhi = 90. - halfOpeningAngle;
400 std::unique_ptr<TGeoShape> trap(
401 new TGeoTrd2(
name.c_str(),
pt.x1() / cm,
pt.x2() / cm,
pt.y1() / cm,
pt.y2() / cm,
pt.halfZ() / cm));
403 std::unique_ptr<TGeoShape> tubs(
new TGeoTubeSeg(
name.c_str(),
408 startPhi + halfOpeningAngle * 2.));
410 TGeoSubtraction* sub =
new TGeoSubtraction(
412 rSolid =
new TGeoCompositeShape(iName.c_str(), sub);
414 std::unique_ptr<TGeoShape> box(
new TGeoBBox(1.1 *
x / cm, 1.1 *
h / cm,
sqrt(
r *
r -
x *
x) / cm));
416 TGeoSubtraction* sub =
new TGeoSubtraction(
419 std::unique_ptr<TGeoShape> tubicCap(
new TGeoCompositeShape(iName.c_str(), sub));
421 TGeoUnion* boolS =
new TGeoUnion(
424 rSolid =
new TGeoCompositeShape(iName.c_str(), boolS);
431 rSolid =
new TGeoTorus(iName.c_str(),
435 solid.startPhi() / deg,
436 solid.deltaPhi() / deg);
442 throw cms::Exception(
"GeomConvert") <<
"conversion to DDBooleanSolid failed";
445 std::string nameA =
m_fullname ? boolSolid.solidA().name().fullname() : boolSolid.solidA().name().name();
446 std::string nameB =
m_fullname ? boolSolid.solidB().name().fullname() : boolSolid.solidB().name().name();
447 std::unique_ptr<TGeoShape> left(
createShape(nameA, boolSolid.solidA()));
448 std::unique_ptr<TGeoShape> right(
createShape(nameB, boolSolid.solidB()));
449 if (
nullptr != left.get() &&
nullptr != right.get()) {
450 TGeoSubtraction* sub =
451 new TGeoSubtraction(left.release(),
454 createPlacement(boolSolid.rotation().matrix(), boolSolid.translation()));
455 rSolid =
new TGeoCompositeShape(iName.c_str(), sub);
462 throw cms::Exception(
"GeomConvert") <<
"conversion to DDTruncTubs failed";
464 double rIn(
tt.rIn());
465 double rOut(
tt.rOut());
466 double zHalf(
tt.zHalf());
467 double startPhi(
tt.startPhi());
469 double cutAtStart(
tt.cutAtStart());
470 double cutAtDelta(
tt.cutAtDelta());
471 bool cutInside(
bool(
tt.cutInside()));
475 if (rIn <= 0 || rOut <= 0 || cutAtStart <= 0 || cutAtDelta <= 0) {
476 std::string s =
"TruncTubs " +
name +
": 0 <= rIn,cutAtStart,rOut,cutAtDelta,rOut violated!";
483 if (startPhi != 0.) {
489 double r(cutAtStart);
490 double R(cutAtDelta);
493 std::unique_ptr<TGeoShape> tubs(
494 new TGeoTubeSeg(
name.c_str(), rIn / cm, rOut / cm, zHalf / cm, startPhi,
deltaPhi / deg));
496 double boxX(rOut), boxY(rOut);
499 double boxZ(1.1 * zHalf);
504 double cos_alpha = cath / hypo;
505 double alpha = -acos(cos_alpha);
519 std::unique_ptr<TGeoShape> box(
new TGeoBBox(
name.c_str(), boxX / cm, boxZ / cm, boxY / cm));
521 TGeoTranslation trans(xBox / cm, 0., 0.);
523 TGeoSubtraction* sub =
524 new TGeoSubtraction(tubs.release(), box.release(),
nullptr,
new TGeoCombiTrans(trans,
rot));
526 rSolid =
new TGeoCompositeShape(iName.c_str(), sub);
532 throw cms::Exception(
"GeomConvert") <<
"conversion to DDBooleanSolid failed";
535 std::string nameA =
m_fullname ? boolSolid.solidA().name().fullname() : boolSolid.solidA().name().name();
536 std::string nameB =
m_fullname ? boolSolid.solidB().name().fullname() : boolSolid.solidB().name().name();
537 std::unique_ptr<TGeoShape> left(
createShape(nameA, boolSolid.solidA()));
538 std::unique_ptr<TGeoShape> right(
createShape(nameB, boolSolid.solidB()));
541 if (
nullptr != left.get() &&
nullptr != right.get()) {
542 TGeoUnion* boolS =
new TGeoUnion(left.release(),
545 createPlacement(boolSolid.rotation().matrix(), boolSolid.translation()));
546 rSolid =
new TGeoCompositeShape(iName.c_str(), boolS);
553 throw cms::Exception(
"GeomConvert") <<
"conversion to DDBooleanSolid failed";
556 std::string nameA =
m_fullname ? boolSolid.solidA().name().fullname() : boolSolid.solidA().name().name();
557 std::string nameB =
m_fullname ? boolSolid.solidB().name().fullname() : boolSolid.solidB().name().name();
558 std::unique_ptr<TGeoShape> left(
createShape(nameA, boolSolid.solidA()));
559 std::unique_ptr<TGeoShape> right(
createShape(nameB, boolSolid.solidB()));
560 if (
nullptr != left.get() &&
nullptr != right.get()) {
561 TGeoIntersection* boolS =
562 new TGeoIntersection(left.release(),
565 createPlacement(boolSolid.rotation().matrix(), boolSolid.translation()));
566 rSolid =
new TGeoCompositeShape(iName.c_str(), boolS);
573 throw cms::Exception(
"GeomConvert") <<
"conversion to DDEllipticalTube failed";
583 if (rSolid ==
nullptr) {
584 edm::LogError(
"TGeoMgrFromDdd") <<
"COULD NOT MAKE " << iName <<
" of a shape " << iSolid;
587 edm::LogVerbatim(
"TGeoMgrFromDdd") <<
"solid " << iName <<
" has been created.";
Log< level::Info, true > LogVerbatim
A truncated tube section.
Sin< T >::type sin(const T &t)
const std::vector< double > & parameters(void) const
Give the parameters of the solid.
Log< level::Error, false > LogError
TGeoCombiTrans * createPlacement(const Rotation3D &iRot, const Position &iTrans)
ROOT::Math::Rotation3D DDRotationMatrix
A DDRotationMatrix is currently implemented with a ROOT Rotation3D.
Cos< T >::type cos(const T &t)
std::map< std::string, TGeoShape * > nameToShape_
Abs< T >::type abs(const T &t)
DDSolidShape shape(void) const
The type of the solid.
TGeoShape * createShape(const std::string &iName, const DDSolid &iSolid)
const std::string fullname() const
std::pair< const N *, bool > def_type
The Signals That Services Can Subscribe To This is based on ActivityRegistry h
Helper function to determine trigger accepts.
def_type isDefined() const
ROOT::Math::DisplacementVector3D< ROOT::Math::Cartesian3D< double > > DDTranslation