CMS 3D CMS Logo

List of all members | Public Member Functions
DDLPosPart Class Referencefinal

DDLPosPart handles PosPart elements. More...

#include <DDLPosPart.h>

Inheritance diagram for DDLPosPart:
DDXMLElement

Public Member Functions

 DDLPosPart (DDLElementRegistry *myreg)
 
void preProcessElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv) override
 Called by loadAttributes AFTER attributes are loaded. More...
 
void processElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv) override
 Processing the element. More...
 
- Public Member Functions inherited from DDXMLElement
void appendText (const std::string &inText)
 append to the current (i.e. most recently added) More...
 
virtual std::vector< DDXMLAttribute >::const_iterator begin (void)
 
virtual void clear (void)
 clear this element's contents. More...
 
 DDXMLElement (DDLElementRegistry *myreg)
 Constructor. More...
 
 DDXMLElement (DDLElementRegistry *myreg, const bool &clearme)
 Constructor for autoClear element. More...
 
virtual std::vector< DDXMLAttribute >::const_iterator end (void)
 
virtual const std::string & get (const std::string &name, size_t aIndex=0) const
 Returns a specific value from the aIndex set of attributes. More...
 
virtual const std::string & getAttribute (const std::string &name) const
 Access to attributes by name. More...
 
virtual const DDXMLAttributegetAttributeSet (size_t aIndex=0) const
 Get a "row" of attributes, i.e. one attribute set. More...
 
virtual const DDName getDDName (const std::string &defaultNS, const std::string &attname=std::string("name"), size_t aIndex=0)
 
const std::string getText (size_t tindex=0) const
 retrieve the text blob. More...
 
virtual std::vector< std::string > getVectorAttribute (const std::string &name)
 Returns a set of values as a std::vector of strings, given the attribute name. More...
 
virtual bool gotText (void) const
 gotText()? kind of like gotMilk? Yes = text has already been encountered. More...
 
virtual bool isEmpty (void) const
 Have any elements of this type been encountered but not processed? More...
 
void loadAttributes (const std::string &elemName, const std::vector< std::string > &names, const std::vector< std::string > &values, const std::string &nmspace, DDCompactView &cpv)
 Load the element attributes. More...
 
void loadText (const std::string &inText)
 Used to load both text and XML comments into this object. More...
 
std::vector< DDXMLAttribute >::const_iterator & operator++ (int inc)
 Allow the elements of this type to be iterated over using ++ operator. More...
 
const std::string & parent (void) const
 access to parent element name More...
 
void setParent (const std::string &pename)
 Set parent element name to central list of names. More...
 
void setSelf (const std::string &sename)
 Set self element name to central list of names. More...
 
virtual size_t size (void) const
 Number of elements accumulated. More...
 
virtual void stream (std::ostream &os) const
 Allow for the elements to have their own streaming method, but also provide a default. More...
 
void throwError (const std::string &keyMessage) const
 format std::string for throw an error. More...
 
virtual ~DDXMLElement (void)=default
 Destructor. More...
 

Additional Inherited Members

- Protected Attributes inherited from DDXMLElement
DDLElementRegistrymyRegistry_
 

Detailed Description

DDLPosPart handles PosPart elements.

Author
Michael Case

DDLPosPart.h - description

begin: Tue Oct 30 2001 email: case@.nosp@m.ucdh.nosp@m.ep.uc.nosp@m.davi.nosp@m.s.edu

A PosPart (or Positioning Part or Part Positioner :-)) is used to position a LogicalPart somewhere inside it's parent. So, A PosPart needs two rLogicalParts (self and parent) on which to operate, a Translation and a Rotation.

Definition at line 27 of file DDLPosPart.h.

Constructor & Destructor Documentation

DDLPosPart::DDLPosPart ( DDLElementRegistry myreg)

Definition at line 17 of file DDLPosPart.cc.

18  : DDXMLElement( myreg )
19 {}
DDXMLElement(DDLElementRegistry *myreg)
Constructor.
Definition: DDXMLElement.cc:15

Member Function Documentation

void DDLPosPart::preProcessElement ( const std::string &  name,
const std::string &  nmspace,
DDCompactView cpv 
)
overridevirtual

Called by loadAttributes AFTER attributes are loaded.

The preProcessElement method can assume that the attributes are loaded and perform any code that is necessary at the start of an element.

This would allow users to call their own code to setup anything necessary for the continued processing of the child elements.

Reimplemented from DDXMLElement.

Definition at line 27 of file DDLPosPart.cc.

References DDLElementRegistry::getElement(), and DDXMLElement::myRegistry_.

28 {
29  // Clear out child elements.
30  myRegistry_->getElement("Rotation")->clear();
31  myRegistry_->getElement("ReflectionRotation")->clear();
32 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:172
std::shared_ptr< DDXMLElement > getElement(const std::string &name)
THE most important part. Getting the pointer to a given element type.
void DDLPosPart::processElement ( const std::string &  name,
const std::string &  nmspace,
DDCompactView cpv 
)
overridevirtual

Processing the element.

The processElement method completes any necessary work to process the XML element.

For example, this can be used to call the DDCore to make the geometry in memory. There is a default for this so that if not declared in the inheriting class, no processing is done.

Reimplemented from DDXMLElement.

Definition at line 38 of file DDLPosPart.cc.

References DDXMLElement::clear(), DDrot(), ev, ClhepEvaluator::eval(), DDLElementRegistry::evaluator(), DDXMLElement::getAttributeSet(), DDLElementRegistry::getElement(), DDBase< N, C >::isValid(), DDXMLElement::myRegistry_, DDName::name(), DDName::ns(), DDCompactView::position(), AlCaHLTBitMon_QueryRunRegistry::string, groupFilesInBlocks::temp, x, y, and z.

39 {
40  // get all internal elements.
41  auto myParent = myRegistry_->getElement("rParent");
42  auto myChild = myRegistry_->getElement("rChild");
43  auto myTranslation= myRegistry_->getElement("Translation");
44  auto myDDLRotation= myRegistry_->getElement("Rotation");
45  auto myrRotation = myRegistry_->getElement("rRotation");
46  auto myDDLRefl = myRegistry_->getElement("ReflectionRotation");
47  auto myrRefl = myRegistry_->getElement("rReflectionRotation");
48  // FIXME!!! add in the new RotationByAxis element...
49 
50  // At this time, PosPart is becoming the most complex of the elements.
51  // For simply reflections/rotations we have 4 possible internal "components"
52  // to the PosPart. We take them in the following order of priority
53  // rRotation, Rotation, rReflectionRotation, ReflectionRotation.
54  //
55  // The idea in the following if-else-if is that no matter
56  // what was used inside the PosPart element, the order in which we
57  // will look for and use an internal element is:
58  // rRotation, Rotation, ReflectionRotation, rReflectionRotation.
59  // If it falls through here, a default call will result in a nameless
60  // "identity" rotation being passed to DDCore.
61  DDName rotn;
62  if (myrRotation->size() > 0){
63  rotn = myrRotation->getDDName(nmspace);
64  }
65  else if (myDDLRotation->size() > 0) {
66  // The assumption here is that the Rotation element created
67  // a DDRotation already, and so we can use this as an rRotation
68  // just provide DDCore with the name of the one just added...
69  // How to handle name conflicts? OVERWRITTEN by DDCore for now.
70  rotn = myDDLRotation->getDDName(nmspace);
71  }
72  else if (myDDLRefl->size() > 0) {
73  // The assumption is that a ReflectionRotation has been created and therefore
74  // we can refer to it as the rotation associated with this PosPart.
75  // we can further assume that the namespace is the same as this PosPart.
76  rotn = myDDLRefl->getDDName(nmspace);
77  }
78  else if (myrRefl->size() > 0) {
79  rotn = myrRefl->getDDName(nmspace);
80  }
81 
83 
84  double x = 0.0, y = 0.0, z = 0.0;
85  if (myTranslation->size() > 0)
86  {
87  const DDXMLAttribute & atts = myTranslation->getAttributeSet();
88  x = ev.eval(nmspace, atts.find("x")->second);
89  y = ev.eval(nmspace, atts.find("y")->second);
90  z = ev.eval(nmspace, atts.find("z")->second);
91  }
92 
93  DDRotation* myDDRotation;
94  // if rotation is named ...
95  if ( rotn.name() != "" && rotn.ns() != "" ) {
96  DDRotation temp(rotn);
97  myDDRotation = &temp;
98  } else {
99  // rotn is not assigned a name anywhere therefore the DDPos assumes the identity matrix.
100  DDRotation temp(DDName(std::string("identity"),std::string("generatedForDDD")));
101  myDDRotation = &temp;
102  // if the identity is not yet defined, then...
103  if ( !myDDRotation->isValid() ) {
105  temp = DDrot(DDName(std::string("identity"),std::string("generatedForDDD")), dmr );
106  myDDRotation = &temp;
107  }
108  }
109 
110 
111  DDTranslation myDDTranslation(x, y, z);
112 
113  const DDXMLAttribute & atts = getAttributeSet();
114  std::string copyno = "";
115  if (atts.find("copyNumber") != atts.end())
116  copyno = atts.find("copyNumber")->second;
117 
118  cpv.position(DDLogicalPart(myChild->getDDName(nmspace))
119  , DDLogicalPart(myParent->getDDName(nmspace))
120  , copyno
121  , myDDTranslation
122  , *myDDRotation);
123 
124  // clear all "children" and attributes
125  myParent->clear();
126  myChild->clear();
127  myTranslation->clear();
128  myDDLRotation->clear();
129  myrRotation->clear();
130  myDDLRefl->clear();
131  myrRefl->clear();
132 
133  // after a pos part is done, we know we can clear it.
134  clear();
135 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:172
virtual const DDXMLAttribute & getAttributeSet(size_t aIndex=0) const
Get a "row" of attributes, i.e. one attribute set.
Definition: DDXMLElement.cc:73
void position(const DDLogicalPart &self, const DDLogicalPart &parent, std::string copyno, const DDTranslation &trans, const DDRotation &rot, const DDDivision *div=NULL)
const std::string & ns() const
Returns the namespace.
Definition: DDName.cc:104
DDName is used to identify DDD entities uniquely.
Definition: DDName.h:16
bool ev
std::map< std::string, std::string > DDXMLAttribute
Definition: DDXMLElement.h:45
ROOT::Math::DisplacementVector3D< ROOT::Math::Cartesian3D< double > > DDTranslation
Definition: DDTranslation.h:7
Represents a uniquely identifyable rotation matrix.
Definition: DDTransform.h:64
bool isValid() const
true, if the wrapped pointer is valid
Definition: DDBase.h:119
ClhepEvaluator & evaluator()
std::shared_ptr< DDXMLElement > getElement(const std::string &name)
THE most important part. Getting the pointer to a given element type.
A DDLogicalPart aggregates information concerning material, solid and sensitveness ...
Definition: DDLogicalPart.h:92
DDRotation DDrot(const DDName &name, DDRotationMatrix *rot)
Definition of a uniquely identifiable rotation matrix named by DDName name.
Definition: DDRotation.cc:90
double eval(const std::string &ns, const std::string &expr)
virtual void clear(void)
clear this element&#39;s contents.
Definition: DDXMLElement.cc:55
ROOT::Math::Rotation3D DDRotationMatrix
A DDRotationMatrix is currently implemented with a ROOT Rotation3D.
const std::string & name() const
Returns the name.
Definition: DDName.cc:90