CMS 3D CMS Logo

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

DDLPolyGenerator processes DDL XML Polycone and DDL XML Polyhedra elements. More...

#include <DDLPolyGenerator.h>

Inheritance diagram for DDLPolyGenerator:
DDLSolid DDXMLElement

Public Member Functions

 DDLPolyGenerator (DDLElementRegistry *myreg)
 Constructor. More...
 
void preProcessElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv)
 Called by loadAttributes AFTER attributes are loaded. More...
 
void processElement (const std::string &name, const std::string &nmspace, DDCompactView &cpv)
 Processing the element. More...
 
 ~DDLPolyGenerator (void)
 Destructor. More...
 
- Public Member Functions inherited from DDLSolid
 DDLSolid (DDLElementRegistry *myreg)
 Constructor. More...
 
void setReference (const std::string &nmspace, DDCompactView &cpv)
 
virtual ~DDLSolid (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...
 

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

DDLPolyGenerator processes DDL XML Polycone and DDL XML Polyhedra elements.

Author
Michael Case

DDLPolyGenerator.h - description

begin: Mon Aug 5 2002 email: case@.nosp@m.ucdh.nosp@m.ep.uc.nosp@m.davi.nosp@m.s.edu

The PolyGenerator element uses RZPoint elements. The DDLRZPoint can return the r and z std::vectors with the points needed to form the polycone. The RZPoint "accumulator" is also used by the Polyhedra and Polycone elements, and could be used anywhere a pair of std::vectors of r and z values are needed.

Definition at line 25 of file DDLPolyGenerator.h.

Constructor & Destructor Documentation

DDLPolyGenerator::DDLPolyGenerator ( DDLElementRegistry myreg)

Constructor.

Definition at line 22 of file DDLPolyGenerator.cc.

23  : DDLSolid( myreg )
24 {}
DDLSolid(DDLElementRegistry *myreg)
Constructor.
Definition: DDLSolid.cc:18
DDLPolyGenerator::~DDLPolyGenerator ( void  )

Destructor.

Definition at line 26 of file DDLPolyGenerator.cc.

27 {}

Member Function Documentation

void DDLPolyGenerator::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.

Definition at line 30 of file DDLPolyGenerator.cc.

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

31 {
32  myRegistry_->getElement("RZPoint")->clear();
33  myRegistry_->getElement("ZSection")->clear();
34 }
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:186
DDXMLElement * getElement(const std::string &name)
THE most important part. Getting the pointer to a given element type.
virtual void clear(void)
clear this element&#39;s contents.
Definition: DDXMLElement.cc:61
void DDLPolyGenerator::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.

Definition at line 40 of file DDLPolyGenerator.cc.

References DDXMLElement::clear(), DCOUT_V, ExprEvalInterface::eval(), DDXMLElement::getAttributeSet(), DDXMLElement::getDDName(), DDLElementRegistry::getElement(), i, DDI::Singleton< I >::instance(), lumiQueryAPI::msg, DDXMLElement::myRegistry_, mergeVDriftHistosByStation::name, DDSolidFactory::polycone(), DDSolidFactory::polyhedra(), alignCSCRings::r, DDLSolid::setReference(), DDXMLElement::size(), DDXMLElement::throwError(), and detailsBasic3DVector::z.

41 {
42  DCOUT_V('P', "DDLPolyGenerator::processElement started");
43 
44  DDXMLElement* myRZPoints = myRegistry_->getElement("RZPoint");
45  DDXMLElement* myZSection = myRegistry_->getElement("ZSection");
46 
48  DDXMLAttribute atts;
49 
50  // get z and r
51  std::vector<double> z, r;
52  for (size_t i = 0; i < myRZPoints->size(); ++i)
53  {
54  atts = myRZPoints->getAttributeSet(i);
55  z.push_back(ev.eval(nmspace, atts.find("z")->second));
56  r.push_back(ev.eval(nmspace, atts.find("r")->second));
57  }
58 
59  // if z is empty, then it better not have been a polycone defined
60  // by RZPoints, instead, it must be a ZSection defined polycone.
61  if (z.size() == 0 )
62  {
63  // get zSection information, note, we already have a z declared above
64  // and we will use r for rmin. In this case, no use "trying" because
65  // it better be there!
66  std::vector<double> rMax;
67 
68  for (size_t i = 0; i < myZSection->size(); ++i)
69  {
70  atts = myZSection->getAttributeSet(i);
71  z.push_back(ev.eval(nmspace, atts.find("z")->second));
72  r.push_back(ev.eval(nmspace, atts.find("rMin")->second));
73  rMax.push_back(ev.eval(nmspace, atts.find("rMax")->second));
74  }
75  atts = getAttributeSet();
76  if (name == "Polycone") // defined with ZSections
77  {
78  DDSolid ddpolycone =
80  , ev.eval(nmspace, atts.find("startPhi")->second)
81  , ev.eval(nmspace, atts.find("deltaPhi")->second)
82  , z
83  , r
84  , rMax);
85  }
86  else if (name == "Polyhedra") // defined with ZSections
87  {
88  DDSolid ddpolyhedra =
90  , int (ev.eval(nmspace, atts.find("numSide")->second))
91  , ev.eval(nmspace, atts.find("startPhi")->second)
92  , ev.eval(nmspace, atts.find("deltaPhi")->second)
93  , z
94  , r
95  , rMax);
96  }
97 
98  }
99  else if (name == "Polycone") // defined with RZPoints
100  {
101  atts = getAttributeSet();
102  DDSolid ddpolycone =
104  , ev.eval(nmspace, atts.find("startPhi")->second)
105  , ev.eval(nmspace, atts.find("deltaPhi")->second)
106  , z
107  , r);
108  }
109  else if (name == "Polyhedra") // defined with RZPoints
110  {
111  atts = getAttributeSet();
112  DDSolid ddpolyhedra =
114  , int (ev.eval(nmspace, atts.find("numSide")->second))
115  , ev.eval(nmspace, atts.find("startPhi")->second)
116  , ev.eval(nmspace, atts.find("deltaPhi")->second)
117  , z
118  , r);
119  }
120  else
121  {
122  std::string msg = "\nDDLPolyGenerator::processElement was called with incorrect name of solid: " + name;
123  throwError(msg);
124  }
125  DDLSolid::setReference(nmspace, cpv);
126 
127  // clear out RZPoint element accumulator and ZSections
128  myRZPoints->clear();
129  myZSection->clear();
130  clear();
131 
132  DCOUT_V('P', "DDLPolyGenerator::processElement completed");
133 }
int i
Definition: DBlmapReader.cc:9
DDLElementRegistry * myRegistry_
Definition: DDXMLElement.h:186
static DDSolid polycone(const DDName &name, double startPhi, double deltaPhi, const std::vector< double > &z, const std::vector< double > &rmin, const std::vector< double > &rmax)
Creates a polycone (refere to Geant3 or Geant4 documentation)
Definition: DDSolid.cc:656
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
void throwError(const std::string &keyMessage) const
format std::string for throw an error.
double double double z
std::map< std::string, std::string > DDXMLAttribute
Definition: DDXMLElement.h:55
A DDSolid represents the shape of a part.
Definition: DDSolid.h:35
DDXMLElement * getElement(const std::string &name)
THE most important part. Getting the pointer to a given element type.
static value_type & instance()
virtual size_t size(void) const
Number of elements accumulated.
Interface of an Expression Evaluator.
#define DCOUT_V(M_v_Y, M_v_S)
Definition: DDdebug.h:54
virtual double eval(const std::string &ns, const std::string &expr)=0
evaluate an expression expr inside the local namespace
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
virtual const DDName getDDName(const std::string &defaultNS, const std::string &attname=std::string("name"), size_t aIndex=0)
Definition: DDXMLElement.cc:86
void setReference(const std::string &nmspace, DDCompactView &cpv)
Definition: DDLSolid.cc:26
static DDSolid polyhedra(const DDName &name, int sides, double startPhi, double deltaPhi, const std::vector< double > &z, const std::vector< double > &rmin, const std::vector< double > &rmax)
Creates a polyhedra (refere to Geant3 or Geant4 documentation)
Definition: DDSolid.cc:673