CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
DDLRotationByAxis Class Reference

DDLRotationByAxis handles RotationByAxis elements. More...

#include <DDLRotationByAxis.h>

Inheritance diagram for DDLRotationByAxis:
DDXMLElement DDLRotationSequence

Public Member Functions

 DDLRotationByAxis (DDLElementRegistry *myreg)
 Constructor. More...
 
virtual void preProcessElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv)
 Called by loadAttributes AFTER attributes are loaded. More...
 
virtual void processElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv)
 Processing the element. More...
 
virtual DDRotationMatrix processOne (DDRotationMatrix R, std::string &axis, std::string &angle)
 
virtual ~DDLRotationByAxis (void)
 Destructor. 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)
 Destructor. More...
 

Private Attributes

std::string pName
 
std::string pNameSpace
 

Additional Inherited Members

- Static Public Member Functions inherited from DDXMLElement
static std::string itostr (int i)
 WARNING: abused by other classes in this system: yet another conversion from int to std::string... More...
 
- Protected Attributes inherited from DDXMLElement
DDLElementRegistrymyRegistry_
 

Detailed Description

DDLRotationByAxis handles RotationByAxis elements.

Author
Michael Case

DDLRotationByAxis.h - description

begin: Wed. Nov. 19, 2003 email: case@.nosp@m.ucdh.nosp@m.ep.uc.nosp@m.davi.nosp@m.s.edu

This is the RotationByAxis element which rotates around an axis.

Definition at line 27 of file DDLRotationByAxis.h.

Constructor & Destructor Documentation

DDLRotationByAxis::DDLRotationByAxis ( DDLElementRegistry myreg)

Constructor.

Definition at line 24 of file DDLRotationByAxis.cc.

25  : DDXMLElement( myreg )
26 {}
DDXMLElement(DDLElementRegistry *myreg)
Constructor.
Definition: DDXMLElement.cc:15
DDLRotationByAxis::~DDLRotationByAxis ( void  )
virtual

Destructor.

Definition at line 28 of file DDLRotationByAxis.cc.

29 {}

Member Function Documentation

void DDLRotationByAxis::preProcessElement ( const std::string &  name,
const std::string &  nmspace,
DDCompactView cpv 
)
virtual

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.

Reimplemented in DDLRotationSequence.

Definition at line 32 of file DDLRotationByAxis.cc.

References mergeVDriftHistosByStation::name, pName, and pNameSpace.

33 {
34  pNameSpace = nmspace;
35  pName = name;
36 }
std::string pNameSpace
void DDLRotationByAxis::processElement ( const std::string &  name,
const std::string &  nmspace,
DDCompactView cpv 
)
virtual

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.

Reimplemented in DDLRotationSequence.

Definition at line 39 of file DDLRotationByAxis.cc.

References angle(), DDXMLElement::clear(), DCOUT_V, DDrot(), DDXMLElement::getAttributeSet(), DDXMLElement::getDDName(), DDLElementRegistry::getElement(), DDXMLElement::loadAttributes(), DDXMLElement::myRegistry_, DDName::name(), cscdqm::h::names, DDXMLElement::parent(), pName, processOne(), dttmaxenums::R, makeMuonMisalignmentScenario::rot, AlCaHLTBitMon_QueryRunRegistry::string, and makeHLTPrescaleTable::values.

40 {
41  DCOUT_V('P', "DDLRotationByAxis::processElement started " << name);
42 
43  // std::cout << "my parent is : " << parent() << std::endl;
45  if (parent() != "RotationSequence")
46  {
47  std::string axis = atts.find("axis")->second;
48  std::string angle = atts.find("angle")->second;
49 
51  R = processOne(R, axis, angle);
52 
53  DDRotationMatrix* ddr = new DDRotationMatrix(R);
54  if (atts.find("name") == atts.end())
55  {
56  //how do we make up a ddname! damn_it!
57  // DDXMLElement * myRealParent = DDLElementRegistry::instance()->getElement(parent());
58  DDXMLElement * myRealParent = myRegistry_->getElement(parent());
59  DDName pName = myRealParent->getDDName(nmspace);
60  std::string tn = pName.name() + std::string("Rotation");
61  std::vector<std::string> names;
62  names.push_back("name");
63  //no need, used already names.push_back("axis");
64  //no need, used already names.push_back("angle");
65 
66  std::vector<std::string> values;
67  values.push_back(tn);
68  //no need, used already values.push_back(atts.find("axis")->second);
69  //no need, used already values.push_back(atts.find("angle")->second);
70  clear();
71  loadAttributes(name, names, values, nmspace, cpv);
72  }
73  DDRotation rot = DDrot(getDDName(nmspace), ddr);
74 
75  clear();
76  }
77  else { } //let the parent handle the clearing, etc.
78 
79  DCOUT_V('P', "DDLRotationByAxis::processElement completed");
80 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:186
static const HistoName names[]
virtual const DDXMLAttribute & getAttributeSet(size_t aIndex=0) const
Get a &quot;row&quot; of attributes, i.e. one attribute set.
Definition: DDXMLElement.cc:79
DDName is used to identify DDD entities uniquely.
Definition: DDName.h:18
const std::string & parent(void) const
access to parent element name
std::map< std::string, std::string > DDXMLAttribute
Definition: DDXMLElement.h:55
Represents a uniquely identifyable rotation matrix.
Definition: DDTransform.h:66
DDXMLElement * getElement(const std::string &name)
THE most important part. Getting the pointer to a given element type.
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.
Definition: DDXMLElement.cc:41
virtual DDRotationMatrix processOne(DDRotationMatrix R, std::string &axis, std::string &angle)
DDRotation DDrot(const DDName &name, DDRotationMatrix *rot)
Definition of a uniquely identifiable rotation matrix named by DDName name.
Definition: DDRotation.cc:90
#define DCOUT_V(M_v_Y, M_v_S)
Definition: DDdebug.h:54
This is a base class for processing XML elements in the DDD.
Definition: DDXMLElement.h:58
virtual void clear(void)
clear this element&#39;s contents.
Definition: DDXMLElement.cc:61
ROOT::Math::Rotation3D DDRotationMatrix
A DDRotationMatrix is currently implemented with a ROOT Rotation3D.
virtual const DDName getDDName(const std::string &defaultNS, const std::string &attname=std::string("name"), size_t aIndex=0)
Definition: DDXMLElement.cc:86
const std::string & name() const
Returns the name.
Definition: DDName.cc:87
T angle(T x1, T y1, T z1, T x2, T y2, T z2)
Definition: angle.h:11
DDRotationMatrix DDLRotationByAxis::processOne ( DDRotationMatrix  R,
std::string &  axis,
std::string &  angle 
)
virtual

Get the name, axis and angle of the RotationByAxis and do it.

Definition at line 83 of file DDLRotationByAxis.cc.

References ev, ClhepEvaluator::eval(), DDLElementRegistry::evaluator(), producerFileCleanner::msg, DDXMLElement::myRegistry_, pName, pNameSpace, dttmaxenums::R, AlCaHLTBitMon_QueryRunRegistry::string, and DDXMLElement::throwError().

Referenced by DDLRotationSequence::processElement(), and processElement().

84 {
89  double dAngle = ev.eval(pNameSpace, angle);
90  // CLHEP::HepRotation R;
91 
92  if ( axis == "x") {
93  R = ROOT::Math::RotationX(dAngle);
94  }
95  else if ( axis == "y" ) {
96  R = ROOT::Math::RotationY(dAngle);
97  }
98  else if ( axis =="z" ) {
99  R = ROOT::Math::RotationZ(dAngle);
100  }
101  else {
102  std::string msg = "\nDDLRotationByAxis invalid axis... you must not have validated XML sources! Element is ";
103  msg += pName;
104  throwError(msg);
105  }
106 
107  return R;
108 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:186
void throwError(const std::string &keyMessage) const
format std::string for throw an error.
bool ev
std::string pNameSpace
ClhepEvaluator & evaluator()
double eval(const std::string &ns, const std::string &expr)
T angle(T x1, T y1, T z1, T x2, T y2, T z2)
Definition: angle.h:11

Member Data Documentation

std::string DDLRotationByAxis::pName
private

Definition at line 45 of file DDLRotationByAxis.h.

Referenced by preProcessElement(), processElement(), and processOne().

std::string DDLRotationByAxis::pNameSpace
private

Definition at line 44 of file DDLRotationByAxis.h.

Referenced by preProcessElement(), and processOne().