Geant4  10.01.p02
G4GDMLWriteSolids.cc
Go to the documentation of this file.
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 //
27 // $Id: G4GDMLWriteSolids.cc 90766 2015-06-09 10:13:41Z gcosmo $
28 //
29 // class G4GDMLWriteSolids Implementation
30 //
31 // Original author: Zoltan Torzsok, November 2007
32 //
33 // --------------------------------------------------------------------
34 
35 #include "G4GDMLWriteSolids.hh"
36 
37 #include "G4SystemOfUnits.hh"
38 #include "G4BooleanSolid.hh"
39 #include "G4Box.hh"
40 #include "G4Cons.hh"
41 #include "G4Ellipsoid.hh"
42 #include "G4EllipticalCone.hh"
43 #include "G4EllipticalTube.hh"
44 #include "G4ExtrudedSolid.hh"
45 #include "G4Hype.hh"
46 #include "G4Orb.hh"
47 #include "G4Para.hh"
48 #include "G4Paraboloid.hh"
49 #include "G4IntersectionSolid.hh"
50 #include "G4Polycone.hh"
51 #include "G4GenericPolycone.hh"
52 #include "G4Polyhedra.hh"
53 #include "G4ReflectedSolid.hh"
54 #include "G4Sphere.hh"
55 #include "G4SubtractionSolid.hh"
56 #include "G4GenericTrap.hh"
57 #include "G4TessellatedSolid.hh"
58 #include "G4Tet.hh"
59 #include "G4Torus.hh"
60 #include "G4Trap.hh"
61 #include "G4Trd.hh"
62 #include "G4Tubs.hh"
63 #include "G4CutTubs.hh"
64 #include "G4TwistedBox.hh"
65 #include "G4TwistedTrap.hh"
66 #include "G4TwistedTrd.hh"
67 #include "G4TwistedTubs.hh"
68 #include "G4UnionSolid.hh"
69 #include "G4OpticalSurface.hh"
70 #include "G4SurfaceProperty.hh"
71 
73  : G4GDMLWriteMaterials(), solidsElement(0)
74 {
75 }
76 
78 {
79 }
80 
82 MultiUnionWrite(xercesc::DOMElement* solElement,
83  const G4MultiUnion* const munionSolid)
84 {
85  G4int numSolids=munionSolid->GetNumberOfSolids();
86  G4String tag("multiUnion");
87 
88  G4VSolid* solid;
89  G4Transform3D* transform;
90 
91  const G4String& name = GenerateName(munionSolid->GetName(),munionSolid);
92  xercesc::DOMElement* multiUnionElement = NewElement(tag);
93  multiUnionElement->setAttributeNode(NewAttribute("name",name));
94 
95  for (G4int i=0; i<numSolids; ++i)
96  {
97  solid = munionSolid->GetSolid(i);
98  transform = munionSolid->GetTransformation(i);
99 
100  HepGeom::Rotate3D rot3d;
101  HepGeom::Translate3D transl ;
102  HepGeom::Scale3D scale;
103  transform->getDecomposition(scale,rot3d,transl);
104 
105  G4ThreeVector pos = transl.getTranslation();
107  rotm(CLHEP::HepRep3x3(rot3d.xx(), rot3d.xy(), rot3d.xz(),
108  rot3d.yx(), rot3d.yy(), rot3d.yz(),
109  rot3d.zx(), rot3d.zy(), rot3d.zz()));
110  G4ThreeVector rot = GetAngles(rotm);
111 
112  AddSolid(solid);
113  const G4String& solidref = GenerateName(solid->GetName(),solid);
114  std::ostringstream os; os << i+1;
115  const G4String& nodeName = "Node-" + G4String(os.str());
116  xercesc::DOMElement* solidElement = NewElement("solid");
117  solidElement->setAttributeNode(NewAttribute("ref",solidref));
118  xercesc::DOMElement* multiUnionNodeElement = NewElement("multiUnionNode");
119  multiUnionNodeElement->setAttributeNode(NewAttribute("name", nodeName));
120  multiUnionNodeElement->appendChild(solidElement); // Append solid to node
121  if ( (std::fabs(pos.x()) > kLinearPrecision)
122  || (std::fabs(pos.y()) > kLinearPrecision)
123  || (std::fabs(pos.z()) > kLinearPrecision) )
124  {
125  PositionWrite(multiUnionNodeElement,name+"_pos",pos);
126  }
127  if ( (std::fabs(rot.x()) > kAngularPrecision)
128  || (std::fabs(rot.y()) > kAngularPrecision)
129  || (std::fabs(rot.z()) > kAngularPrecision) )
130  {
131  RotationWrite(multiUnionNodeElement,name+"_rot",rot);
132  }
133  multiUnionElement->appendChild(multiUnionNodeElement); // Append node
134  }
135 
136  solElement->appendChild(multiUnionElement);
137  // Add the multiUnion solid AFTER the constituent nodes!
138 }
139 
141 BooleanWrite(xercesc::DOMElement* solElement,
142  const G4BooleanSolid* const boolean)
143 {
144  G4int displaced=0;
145 
146  G4String tag("undefined");
147  if (dynamic_cast<const G4IntersectionSolid*>(boolean))
148  { tag = "intersection"; } else
149  if (dynamic_cast<const G4SubtractionSolid*>(boolean))
150  { tag = "subtraction"; } else
151  if (dynamic_cast<const G4UnionSolid*>(boolean))
152  { tag = "union"; }
153 
154  G4VSolid* firstPtr = const_cast<G4VSolid*>(boolean->GetConstituentSolid(0));
155  G4VSolid* secondPtr = const_cast<G4VSolid*>(boolean->GetConstituentSolid(1));
156 
157  G4ThreeVector firstpos,firstrot,pos,rot;
158 
159  // Solve possible displacement of referenced solids!
160  //
161  while (true)
162  {
163  if ( displaced>8 )
164  {
165  G4String ErrorMessage = "The referenced solid '"
166  + firstPtr->GetName() +
167  + "in the Boolean shape '" +
168  + boolean->GetName() +
169  + "' was displaced too many times!";
170  G4Exception("G4GDMLWriteSolids::BooleanWrite()",
171  "InvalidSetup", FatalException, ErrorMessage);
172  }
173 
174  if (G4DisplacedSolid* disp = dynamic_cast<G4DisplacedSolid*>(firstPtr))
175  {
176  firstpos += disp->GetObjectTranslation();
177  firstrot += GetAngles(disp->GetObjectRotation());
178  firstPtr = disp->GetConstituentMovedSolid();
179  displaced++;
180  continue;
181  }
182  break;
183  }
184  displaced = 0;
185  while (true)
186  {
187  if ( displaced>maxTransforms )
188  {
189  G4String ErrorMessage = "The referenced solid '"
190  + secondPtr->GetName() +
191  + "in the Boolean shape '" +
192  + boolean->GetName() +
193  + "' was displaced too many times!";
194  G4Exception("G4GDMLWriteSolids::BooleanWrite()",
195  "InvalidSetup", FatalException, ErrorMessage);
196  }
197 
198  if (G4DisplacedSolid* disp = dynamic_cast<G4DisplacedSolid*>(secondPtr))
199  {
200  pos += disp->GetObjectTranslation();
201  rot += GetAngles(disp->GetObjectRotation());
202  secondPtr = disp->GetConstituentMovedSolid();
203  displaced++;
204  continue;
205  }
206  break;
207  }
208 
209  AddSolid(firstPtr); // At first add the constituent solids!
210  AddSolid(secondPtr);
211 
212  const G4String& name = GenerateName(boolean->GetName(),boolean);
213  const G4String& firstref = GenerateName(firstPtr->GetName(),firstPtr);
214  const G4String& secondref = GenerateName(secondPtr->GetName(),secondPtr);
215 
216  xercesc::DOMElement* booleanElement = NewElement(tag);
217  booleanElement->setAttributeNode(NewAttribute("name",name));
218  xercesc::DOMElement* firstElement = NewElement("first");
219  firstElement->setAttributeNode(NewAttribute("ref",firstref));
220  booleanElement->appendChild(firstElement);
221  xercesc::DOMElement* secondElement = NewElement("second");
222  secondElement->setAttributeNode(NewAttribute("ref",secondref));
223  booleanElement->appendChild(secondElement);
224  solElement->appendChild(booleanElement);
225  // Add the boolean solid AFTER the constituent solids!
226 
227  if ( (std::fabs(pos.x()) > kLinearPrecision)
228  || (std::fabs(pos.y()) > kLinearPrecision)
229  || (std::fabs(pos.z()) > kLinearPrecision) )
230  {
231  PositionWrite(booleanElement,name+"_pos",pos);
232  }
233 
234  if ( (std::fabs(rot.x()) > kAngularPrecision)
235  || (std::fabs(rot.y()) > kAngularPrecision)
236  || (std::fabs(rot.z()) > kAngularPrecision) )
237  {
238  RotationWrite(booleanElement,name+"_rot",rot);
239  }
240 
241  if ( (std::fabs(firstpos.x()) > kLinearPrecision)
242  || (std::fabs(firstpos.y()) > kLinearPrecision)
243  || (std::fabs(firstpos.z()) > kLinearPrecision) )
244  {
245  FirstpositionWrite(booleanElement,name+"_fpos",firstpos);
246  }
247 
248  if ( (std::fabs(firstrot.x()) > kAngularPrecision)
249  || (std::fabs(firstrot.y()) > kAngularPrecision)
250  || (std::fabs(firstrot.z()) > kAngularPrecision) )
251  {
252  FirstrotationWrite(booleanElement,name+"_frot",firstrot);
253  }
254 }
255 
257 BoxWrite(xercesc::DOMElement* solElement, const G4Box* const box)
258 {
259  const G4String& name = GenerateName(box->GetName(),box);
260 
261  xercesc::DOMElement* boxElement = NewElement("box");
262  boxElement->setAttributeNode(NewAttribute("name",name));
263  boxElement->setAttributeNode(NewAttribute("x",2.0*box->GetXHalfLength()/mm));
264  boxElement->setAttributeNode(NewAttribute("y",2.0*box->GetYHalfLength()/mm));
265  boxElement->setAttributeNode(NewAttribute("z",2.0*box->GetZHalfLength()/mm));
266  boxElement->setAttributeNode(NewAttribute("lunit","mm"));
267  solElement->appendChild(boxElement);
268 }
269 
271 ConeWrite(xercesc::DOMElement* solElement, const G4Cons* const cone)
272 {
273  const G4String& name = GenerateName(cone->GetName(),cone);
274 
275  xercesc::DOMElement* coneElement = NewElement("cone");
276  coneElement->setAttributeNode(NewAttribute("name",name));
277  coneElement->
278  setAttributeNode(NewAttribute("rmin1",cone->GetInnerRadiusMinusZ()/mm));
279  coneElement->
280  setAttributeNode(NewAttribute("rmax1",cone->GetOuterRadiusMinusZ()/mm));
281  coneElement->
282  setAttributeNode(NewAttribute("rmin2",cone->GetInnerRadiusPlusZ()/mm));
283  coneElement->
284  setAttributeNode(NewAttribute("rmax2",cone->GetOuterRadiusPlusZ()/mm));
285  coneElement->
286  setAttributeNode(NewAttribute("z",2.0*cone->GetZHalfLength()/mm));
287  coneElement->
288  setAttributeNode(NewAttribute("startphi",cone->GetStartPhiAngle()/degree));
289  coneElement->
290  setAttributeNode(NewAttribute("deltaphi",cone->GetDeltaPhiAngle()/degree));
291  coneElement->setAttributeNode(NewAttribute("aunit","deg"));
292  coneElement->setAttributeNode(NewAttribute("lunit","mm"));
293  solElement->appendChild(coneElement);
294 }
295 
297 ElconeWrite(xercesc::DOMElement* solElement,
298  const G4EllipticalCone* const elcone)
299 {
300  const G4String& name = GenerateName(elcone->GetName(),elcone);
301 
302  xercesc::DOMElement* elconeElement = NewElement("elcone");
303  elconeElement->setAttributeNode(NewAttribute("name",name));
304  elconeElement->setAttributeNode(NewAttribute("dx",elcone->GetSemiAxisX()/mm));
305  elconeElement->setAttributeNode(NewAttribute("dy",elcone->GetSemiAxisY()/mm));
306  elconeElement->setAttributeNode(NewAttribute("zmax",elcone->GetZMax()/mm));
307  elconeElement->setAttributeNode(NewAttribute("zcut",elcone->GetZTopCut()/mm));
308  elconeElement->setAttributeNode(NewAttribute("lunit","mm"));
309  solElement->appendChild(elconeElement);
310 }
311 
313 EllipsoidWrite(xercesc::DOMElement* solElement,
314  const G4Ellipsoid* const ellipsoid)
315 {
316  const G4String& name = GenerateName(ellipsoid->GetName(),ellipsoid);
317 
318  xercesc::DOMElement* ellipsoidElement = NewElement("ellipsoid");
319  ellipsoidElement->setAttributeNode(NewAttribute("name",name));
320  ellipsoidElement->
321  setAttributeNode(NewAttribute("ax",ellipsoid->GetSemiAxisMax(0)/mm));
322  ellipsoidElement->
323  setAttributeNode(NewAttribute("by",ellipsoid->GetSemiAxisMax(1)/mm));
324  ellipsoidElement->
325  setAttributeNode(NewAttribute("cz",ellipsoid->GetSemiAxisMax(2)/mm));
326  ellipsoidElement->
327  setAttributeNode(NewAttribute("zcut1",ellipsoid->GetZBottomCut()/mm));
328  ellipsoidElement->
329  setAttributeNode(NewAttribute("zcut2",ellipsoid->GetZTopCut()/mm));
330  ellipsoidElement->
331  setAttributeNode(NewAttribute("lunit","mm"));
332  solElement->appendChild(ellipsoidElement);
333 }
334 
336 EltubeWrite(xercesc::DOMElement* solElement,
337  const G4EllipticalTube* const eltube)
338 {
339  const G4String& name = GenerateName(eltube->GetName(),eltube);
340 
341  xercesc::DOMElement* eltubeElement = NewElement("eltube");
342  eltubeElement->setAttributeNode(NewAttribute("name",name));
343  eltubeElement->setAttributeNode(NewAttribute("dx",eltube->GetDx()/mm));
344  eltubeElement->setAttributeNode(NewAttribute("dy",eltube->GetDy()/mm));
345  eltubeElement->setAttributeNode(NewAttribute("dz",eltube->GetDz()/mm));
346  eltubeElement->setAttributeNode(NewAttribute("lunit","mm"));
347  solElement->appendChild(eltubeElement);
348 }
349 
351 XtruWrite(xercesc::DOMElement* solElement,
352  const G4ExtrudedSolid* const xtru)
353 {
354  const G4String& name = GenerateName(xtru->GetName(),xtru);
355 
356  xercesc::DOMElement* xtruElement = NewElement("xtru");
357  xtruElement->setAttributeNode(NewAttribute("name",name));
358  xtruElement->setAttributeNode(NewAttribute("lunit","mm"));
359  solElement->appendChild(xtruElement);
360 
361  const G4int NumVertex = xtru->GetNofVertices();
362 
363  for (G4int i=0;i<NumVertex;i++)
364  {
365  xercesc::DOMElement* twoDimVertexElement = NewElement("twoDimVertex");
366  xtruElement->appendChild(twoDimVertexElement);
367 
368  const G4TwoVector& vertex = xtru->GetVertex(i);
369 
370  twoDimVertexElement->setAttributeNode(NewAttribute("x",vertex.x()/mm));
371  twoDimVertexElement->setAttributeNode(NewAttribute("y",vertex.y()/mm));
372  }
373 
374  const G4int NumSection = xtru->GetNofZSections();
375 
376  for (G4int i=0;i<NumSection;i++)
377  {
378  xercesc::DOMElement* sectionElement = NewElement("section");
379  xtruElement->appendChild(sectionElement);
380 
381  const G4ExtrudedSolid::ZSection section = xtru->GetZSection(i);
382 
383  sectionElement->setAttributeNode(NewAttribute("zOrder",i));
384  sectionElement->setAttributeNode(NewAttribute("zPosition",section.fZ/mm));
385  sectionElement->
386  setAttributeNode(NewAttribute("xOffset",section.fOffset.x()/mm));
387  sectionElement->
388  setAttributeNode(NewAttribute("yOffset",section.fOffset.y()/mm));
389  sectionElement->
390  setAttributeNode(NewAttribute("scalingFactor",section.fScale));
391  }
392 }
393 
395 HypeWrite(xercesc::DOMElement* solElement, const G4Hype* const hype)
396 {
397  const G4String& name = GenerateName(hype->GetName(),hype);
398 
399  xercesc::DOMElement* hypeElement = NewElement("hype");
400  hypeElement->setAttributeNode(NewAttribute("name",name));
401  hypeElement->setAttributeNode(NewAttribute("rmin",
402  hype->GetInnerRadius()/mm));
403  hypeElement->setAttributeNode(NewAttribute("rmax",
404  hype->GetOuterRadius()/mm));
405  hypeElement->setAttributeNode(NewAttribute("inst",
406  hype->GetInnerStereo()/degree));
407  hypeElement->setAttributeNode(NewAttribute("outst",
408  hype->GetOuterStereo()/degree));
409  hypeElement->setAttributeNode(NewAttribute("z",
410  2.0*hype->GetZHalfLength()/mm));
411  hypeElement->setAttributeNode(NewAttribute("aunit","deg"));
412  hypeElement->setAttributeNode(NewAttribute("lunit","mm"));
413  solElement->appendChild(hypeElement);
414 }
415 
417 OrbWrite(xercesc::DOMElement* solElement, const G4Orb* const orb)
418 {
419  const G4String& name = GenerateName(orb->GetName(),orb);
420 
421  xercesc::DOMElement* orbElement = NewElement("orb");
422  orbElement->setAttributeNode(NewAttribute("name",name));
423  orbElement->setAttributeNode(NewAttribute("r",orb->GetRadius()/mm));
424  orbElement->setAttributeNode(NewAttribute("lunit","mm"));
425  solElement->appendChild(orbElement);
426 }
427 
429 ParaWrite(xercesc::DOMElement* solElement, const G4Para* const para)
430 {
431  const G4String& name = GenerateName(para->GetName(),para);
432 
433  const G4ThreeVector simaxis = para->GetSymAxis();
434  const G4double alpha = std::atan(para->GetTanAlpha());
435  const G4double phi = simaxis.phi();
436  const G4double theta = simaxis.theta();
437 
438  xercesc::DOMElement* paraElement = NewElement("para");
439  paraElement->setAttributeNode(NewAttribute("name",name));
440  paraElement->setAttributeNode(NewAttribute("x",
441  2.0*para->GetXHalfLength()/mm));
442  paraElement->setAttributeNode(NewAttribute("y",
443  2.0*para->GetYHalfLength()/mm));
444  paraElement->setAttributeNode(NewAttribute("z",
445  2.0*para->GetZHalfLength()/mm));
446  paraElement->setAttributeNode(NewAttribute("alpha",alpha/degree));
447  paraElement->setAttributeNode(NewAttribute("theta",theta/degree));
448  paraElement->setAttributeNode(NewAttribute("phi",phi/degree));
449  paraElement->setAttributeNode(NewAttribute("aunit","deg"));
450  paraElement->setAttributeNode(NewAttribute("lunit","mm"));
451  solElement->appendChild(paraElement);
452 }
453 
455 ParaboloidWrite(xercesc::DOMElement* solElement,
456  const G4Paraboloid* const paraboloid)
457 {
458  const G4String& name = GenerateName(paraboloid->GetName(),paraboloid);
459 
460  xercesc::DOMElement* paraboloidElement = NewElement("paraboloid");
461  paraboloidElement->setAttributeNode(NewAttribute("name",name));
462  paraboloidElement->setAttributeNode(NewAttribute("rlo",
463  paraboloid->GetRadiusMinusZ()/mm));
464  paraboloidElement->setAttributeNode(NewAttribute("rhi",
465  paraboloid->GetRadiusPlusZ()/mm));
466  paraboloidElement->setAttributeNode(NewAttribute("dz",
467  paraboloid->GetZHalfLength()/mm));
468  paraboloidElement->setAttributeNode(NewAttribute("lunit","mm"));
469  solElement->appendChild(paraboloidElement);
470 }
472 PolyconeWrite(xercesc::DOMElement* solElement,
473  const G4Polycone* const polycone)
474 {
475  const G4String& name = GenerateName(polycone->GetName(),polycone);
476 
477  xercesc::DOMElement* polyconeElement = NewElement("polycone");
478  polyconeElement->setAttributeNode(NewAttribute("name",name));
479  polyconeElement->setAttributeNode(NewAttribute("startphi",
481  polyconeElement->setAttributeNode(NewAttribute("deltaphi",
483  polyconeElement->setAttributeNode(NewAttribute("aunit","deg"));
484  polyconeElement->setAttributeNode(NewAttribute("lunit","mm"));
485  solElement->appendChild(polyconeElement);
486 
487  const size_t num_zplanes = polycone->GetOriginalParameters()->Num_z_planes;
488  const G4double* z_array = polycone->GetOriginalParameters()->Z_values;
489  const G4double* rmin_array = polycone->GetOriginalParameters()->Rmin;
490  const G4double* rmax_array = polycone->GetOriginalParameters()->Rmax;
491 
492  for (size_t i=0; i<num_zplanes; i++)
493  {
494  ZplaneWrite(polyconeElement,z_array[i],rmin_array[i],rmax_array[i]);
495  }
496 
497 
498 }
499 
501 GenericPolyconeWrite(xercesc::DOMElement* solElement,
502  const G4GenericPolycone* const polycone)
503 {
504  const G4String& name = GenerateName(polycone->GetName(),polycone);
505  xercesc::DOMElement* polyconeElement = NewElement("genericPolycone");
506  const G4double startPhi=polycone->GetStartPhi();
507  polyconeElement->setAttributeNode(NewAttribute("name",name));
508  polyconeElement->setAttributeNode(NewAttribute("startphi",
509  startPhi/degree));
510  polyconeElement->setAttributeNode(NewAttribute("deltaphi",
511  (polycone->GetEndPhi()-startPhi)/degree));
512  polyconeElement->setAttributeNode(NewAttribute("aunit","deg"));
513  polyconeElement->setAttributeNode(NewAttribute("lunit","mm"));
514  solElement->appendChild(polyconeElement);
515 
516  const size_t num_rzpoints = polycone->GetNumRZCorner();
517  for (size_t i=0; i<num_rzpoints; i++)
518  {
519  const G4double r_point=polycone->GetCorner(i).r;
520  const G4double z_point=polycone->GetCorner(i).z;
521  RZPointWrite(polyconeElement,r_point,z_point);
522  }
523 
524 }
525 
527 PolyhedraWrite(xercesc::DOMElement* solElement,
528  const G4Polyhedra* const polyhedra)
529 {
530  const G4String& name = GenerateName(polyhedra->GetName(),polyhedra);
531  if(polyhedra->IsGeneric() == false){
532  xercesc::DOMElement* polyhedraElement = NewElement("polyhedra");
533  polyhedraElement->setAttributeNode(NewAttribute("name",name));
534  polyhedraElement->setAttributeNode(NewAttribute("startphi",
535  polyhedra->GetOriginalParameters()->Start_angle/degree));
536  polyhedraElement->setAttributeNode(NewAttribute("deltaphi",
538  polyhedraElement->setAttributeNode(NewAttribute("numsides",
539  polyhedra->GetOriginalParameters()->numSide));
540  polyhedraElement->setAttributeNode(NewAttribute("aunit","deg"));
541  polyhedraElement->setAttributeNode(NewAttribute("lunit","mm"));
542  solElement->appendChild(polyhedraElement);
543 
544  const size_t num_zplanes = polyhedra->GetOriginalParameters()->Num_z_planes;
545  const G4double* z_array = polyhedra->GetOriginalParameters()->Z_values;
546  const G4double* rmin_array = polyhedra->GetOriginalParameters()->Rmin;
547  const G4double* rmax_array = polyhedra->GetOriginalParameters()->Rmax;
548 
549  const G4double convertRad =
550  std::cos(0.5*polyhedra->GetOriginalParameters()->Opening_angle
551  / polyhedra->GetOriginalParameters()->numSide);
552 
553  for (size_t i=0;i<num_zplanes;i++)
554  {
555  ZplaneWrite(polyhedraElement,z_array[i],
556  rmin_array[i]*convertRad, rmax_array[i]*convertRad);
557  }
558  }else{//generic polyhedra
559 
560  xercesc::DOMElement* polyhedraElement = NewElement("genericPolyhedra");
561  polyhedraElement->setAttributeNode(NewAttribute("name",name));
562  polyhedraElement->setAttributeNode(NewAttribute("startphi",
563  polyhedra->GetOriginalParameters()->Start_angle/degree));
564  polyhedraElement->setAttributeNode(NewAttribute("deltaphi",
566  polyhedraElement->setAttributeNode(NewAttribute("numsides",
567  polyhedra->GetOriginalParameters()->numSide));
568  polyhedraElement->setAttributeNode(NewAttribute("aunit","deg"));
569  polyhedraElement->setAttributeNode(NewAttribute("lunit","mm"));
570  solElement->appendChild(polyhedraElement);
571 
572  const size_t num_rzpoints = polyhedra->GetNumRZCorner();
573 
574  for (size_t i=0;i<num_rzpoints;i++)
575  {
576  const G4double r_point = polyhedra->GetCorner(i).r;
577  const G4double z_point = polyhedra->GetCorner(i).z;
578  RZPointWrite(polyhedraElement,r_point,z_point);
579  }
580  }
581 }
582 
584 SphereWrite(xercesc::DOMElement* solElement, const G4Sphere* const sphere)
585 {
586  const G4String& name = GenerateName(sphere->GetName(),sphere);
587 
588  xercesc::DOMElement* sphereElement = NewElement("sphere");
589  sphereElement->setAttributeNode(NewAttribute("name",name));
590  sphereElement->setAttributeNode(NewAttribute("rmin",
591  sphere->GetInnerRadius()/mm));
592  sphereElement->setAttributeNode(NewAttribute("rmax",
593  sphere->GetOuterRadius()/mm));
594  sphereElement->setAttributeNode(NewAttribute("startphi",
595  sphere->GetStartPhiAngle()/degree));
596  sphereElement->setAttributeNode(NewAttribute("deltaphi",
597  sphere->GetDeltaPhiAngle()/degree));
598  sphereElement->setAttributeNode(NewAttribute("starttheta",
599  sphere->GetStartThetaAngle()/degree));
600  sphereElement->setAttributeNode(NewAttribute("deltatheta",
601  sphere->GetDeltaThetaAngle()/degree));
602  sphereElement->setAttributeNode(NewAttribute("aunit","deg"));
603  sphereElement->setAttributeNode(NewAttribute("lunit","mm"));
604  solElement->appendChild(sphereElement);
605 }
606 
608 TessellatedWrite(xercesc::DOMElement* solElement,
609  const G4TessellatedSolid* const tessellated)
610 {
611  const G4String& solid_name = tessellated->GetName();
612  const G4String& name = GenerateName(solid_name, tessellated);
613 
614  xercesc::DOMElement* tessellatedElement = NewElement("tessellated");
615  tessellatedElement->setAttributeNode(NewAttribute("name",name));
616  tessellatedElement->setAttributeNode(NewAttribute("aunit","deg"));
617  tessellatedElement->setAttributeNode(NewAttribute("lunit","mm"));
618  solElement->appendChild(tessellatedElement);
619 
620  std::map<G4ThreeVector, G4String, G4ThreeVectorCompare> vertexMap;
621 
622  const size_t NumFacets = tessellated->GetNumberOfFacets();
623  size_t NumVertex = 0;
624 
625  for (size_t i=0;i<NumFacets;i++)
626  {
627  const G4VFacet* facet = tessellated->GetFacet(i);
628  const size_t NumVertexPerFacet = facet->GetNumberOfVertices();
629 
630  G4String FacetTag;
631 
632  if (NumVertexPerFacet==3) { FacetTag="triangular"; } else
633  if (NumVertexPerFacet==4) { FacetTag="quadrangular"; }
634  else
635  {
636  G4Exception("G4GDMLWriteSolids::TessellatedWrite()", "InvalidSetup",
637  FatalException, "Facet should contain 3 or 4 vertices!");
638  }
639 
640  xercesc::DOMElement* facetElement = NewElement(FacetTag);
641  tessellatedElement->appendChild(facetElement);
642 
643  for (size_t j=0; j<NumVertexPerFacet; j++)
644  {
645  std::stringstream name_stream;
646  std::stringstream ref_stream;
647 
648  name_stream << "vertex" << (j+1);
649  ref_stream << solid_name << "_v" << NumVertex;
650 
651  const G4String& fname = name_stream.str(); // facet's tag variable
652  G4String ref = ref_stream.str(); // vertex tag to be associated
653 
654  // Now search for the existance of the current vertex in the
655  // map of cached vertices. If existing, do NOT store it as
656  // position in the GDML file, so avoiding duplication; otherwise
657  // cache it in the local map and add it as position in the
658  // "define" section of the GDML file.
659 
660  const G4ThreeVector& vertex = facet->GetVertex(j);
661 
662  if(vertexMap.find(vertex) != vertexMap.end()) // Vertex is cached
663  {
664  ref = vertexMap[vertex]; // Set the proper tag for it
665  }
666  else // Vertex not found
667  {
668  vertexMap.insert(std::make_pair(vertex,ref)); // Cache vertex and ...
669  AddPosition(ref, vertex); // ... add it to define section!
670  NumVertex++;
671  }
672 
673  // Now create association of the vertex with its facet
674  //
675  facetElement->setAttributeNode(NewAttribute(fname,ref));
676  }
677  }
678 }
679 
681 TetWrite(xercesc::DOMElement* solElement, const G4Tet* const tet)
682 {
683  const G4String& solid_name = tet->GetName();
684  const G4String& name = GenerateName(solid_name, tet);
685 
686  std::vector<G4ThreeVector> vertexList = tet->GetVertices();
687 
688  xercesc::DOMElement* tetElement = NewElement("tet");
689  tetElement->setAttributeNode(NewAttribute("name",name));
690  tetElement->setAttributeNode(NewAttribute("vertex1",solid_name+"_v1"));
691  tetElement->setAttributeNode(NewAttribute("vertex2",solid_name+"_v2"));
692  tetElement->setAttributeNode(NewAttribute("vertex3",solid_name+"_v3"));
693  tetElement->setAttributeNode(NewAttribute("vertex4",solid_name+"_v4"));
694  tetElement->setAttributeNode(NewAttribute("lunit","mm"));
695  solElement->appendChild(tetElement);
696 
697  AddPosition(solid_name+"_v1",vertexList[0]);
698  AddPosition(solid_name+"_v2",vertexList[1]);
699  AddPosition(solid_name+"_v3",vertexList[2]);
700  AddPosition(solid_name+"_v4",vertexList[3]);
701 }
702 
704 TorusWrite(xercesc::DOMElement* solElement, const G4Torus* const torus)
705 {
706  const G4String& name = GenerateName(torus->GetName(),torus);
707 
708  xercesc::DOMElement* torusElement = NewElement("torus");
709  torusElement->setAttributeNode(NewAttribute("name",name));
710  torusElement->setAttributeNode(NewAttribute("rmin",torus->GetRmin()/mm));
711  torusElement->setAttributeNode(NewAttribute("rmax",torus->GetRmax()/mm));
712  torusElement->setAttributeNode(NewAttribute("rtor",torus->GetRtor()/mm));
713  torusElement->
714  setAttributeNode(NewAttribute("startphi",torus->GetSPhi()/degree));
715  torusElement->
716  setAttributeNode(NewAttribute("deltaphi",torus->GetDPhi()/degree));
717  torusElement->setAttributeNode(NewAttribute("aunit","deg"));
718  torusElement->setAttributeNode(NewAttribute("lunit","mm"));
719  solElement->appendChild(torusElement);
720 }
721 
723 GenTrapWrite(xercesc::DOMElement* solElement,
724  const G4GenericTrap* const gtrap)
725 {
726  const G4String& name = GenerateName(gtrap->GetName(),gtrap);
727 
728  std::vector<G4TwoVector> vertices = gtrap->GetVertices();
729 
730  xercesc::DOMElement* gtrapElement = NewElement("arb8");
731  gtrapElement->setAttributeNode(NewAttribute("name",name));
732  gtrapElement->setAttributeNode(NewAttribute("dz",
733  gtrap->GetZHalfLength()/mm));
734  gtrapElement->setAttributeNode(NewAttribute("v1x", vertices[0].x()));
735  gtrapElement->setAttributeNode(NewAttribute("v1y", vertices[0].y()));
736  gtrapElement->setAttributeNode(NewAttribute("v2x", vertices[1].x()));
737  gtrapElement->setAttributeNode(NewAttribute("v2y", vertices[1].y()));
738  gtrapElement->setAttributeNode(NewAttribute("v3x", vertices[2].x()));
739  gtrapElement->setAttributeNode(NewAttribute("v3y", vertices[2].y()));
740  gtrapElement->setAttributeNode(NewAttribute("v4x", vertices[3].x()));
741  gtrapElement->setAttributeNode(NewAttribute("v4y", vertices[3].y()));
742  gtrapElement->setAttributeNode(NewAttribute("v5x", vertices[4].x()));
743  gtrapElement->setAttributeNode(NewAttribute("v5y", vertices[4].y()));
744  gtrapElement->setAttributeNode(NewAttribute("v6x", vertices[5].x()));
745  gtrapElement->setAttributeNode(NewAttribute("v6y", vertices[5].y()));
746  gtrapElement->setAttributeNode(NewAttribute("v7x", vertices[6].x()));
747  gtrapElement->setAttributeNode(NewAttribute("v7y", vertices[6].y()));
748  gtrapElement->setAttributeNode(NewAttribute("v8x", vertices[7].x()));
749  gtrapElement->setAttributeNode(NewAttribute("v8y", vertices[7].y()));
750  gtrapElement->setAttributeNode(NewAttribute("lunit","mm"));
751  solElement->appendChild(gtrapElement);
752 }
753 
755 TrapWrite(xercesc::DOMElement* solElement, const G4Trap* const trap)
756 {
757  const G4String& name = GenerateName(trap->GetName(),trap);
758 
759  const G4ThreeVector& simaxis = trap->GetSymAxis();
760  const G4double phi = simaxis.phi();
761  const G4double theta = simaxis.theta();
762  const G4double alpha1 = std::atan(trap->GetTanAlpha1());
763  const G4double alpha2 = std::atan(trap->GetTanAlpha2());
764 
765  xercesc::DOMElement* trapElement = NewElement("trap");
766  trapElement->setAttributeNode(NewAttribute("name",name));
767  trapElement->setAttributeNode(NewAttribute("z",
768  2.0*trap->GetZHalfLength()/mm));
769  trapElement->setAttributeNode(NewAttribute("theta",theta/degree));
770  trapElement->setAttributeNode(NewAttribute("phi",phi/degree));
771  trapElement->setAttributeNode(NewAttribute("y1",
772  2.0*trap->GetYHalfLength1()/mm));
773  trapElement->setAttributeNode(NewAttribute("x1",
774  2.0*trap->GetXHalfLength1()/mm));
775  trapElement->setAttributeNode(NewAttribute("x2",
776  2.0*trap->GetXHalfLength2()/mm));
777  trapElement->setAttributeNode(NewAttribute("alpha1",alpha1/degree));
778  trapElement->setAttributeNode(NewAttribute("y2",
779  2.0*trap->GetYHalfLength2()/mm));
780  trapElement->setAttributeNode(NewAttribute("x3",
781  2.0*trap->GetXHalfLength3()/mm));
782  trapElement->setAttributeNode(NewAttribute("x4",
783  2.0*trap->GetXHalfLength4()/mm));
784  trapElement->setAttributeNode(NewAttribute("alpha2",alpha2/degree));
785  trapElement->setAttributeNode(NewAttribute("aunit","deg"));
786  trapElement->setAttributeNode(NewAttribute("lunit","mm"));
787  solElement->appendChild(trapElement);
788 }
789 
791 TrdWrite(xercesc::DOMElement* solElement, const G4Trd* const trd)
792 {
793  const G4String& name = GenerateName(trd->GetName(),trd);
794 
795  xercesc::DOMElement* trdElement = NewElement("trd");
796  trdElement->setAttributeNode(NewAttribute("name",name));
797  trdElement->setAttributeNode(NewAttribute("x1",
798  2.0*trd->GetXHalfLength1()/mm));
799  trdElement->setAttributeNode(NewAttribute("x2",
800  2.0*trd->GetXHalfLength2()/mm));
801  trdElement->setAttributeNode(NewAttribute("y1",
802  2.0*trd->GetYHalfLength1()/mm));
803  trdElement->setAttributeNode(NewAttribute("y2",
804  2.0*trd->GetYHalfLength2()/mm));
805  trdElement->setAttributeNode(NewAttribute("z",
806  2.0*trd->GetZHalfLength()/mm));
807  trdElement->setAttributeNode(NewAttribute("lunit","mm"));
808  solElement->appendChild(trdElement);
809 }
810 
812 TubeWrite(xercesc::DOMElement* solElement, const G4Tubs* const tube)
813 {
814  const G4String& name = GenerateName(tube->GetName(),tube);
815 
816  xercesc::DOMElement* tubeElement = NewElement("tube");
817  tubeElement->setAttributeNode(NewAttribute("name",name));
818  tubeElement->setAttributeNode(NewAttribute("rmin",
819  tube->GetInnerRadius()/mm));
820  tubeElement->setAttributeNode(NewAttribute("rmax",
821  tube->GetOuterRadius()/mm));
822  tubeElement->setAttributeNode(NewAttribute("z",
823  2.0*tube->GetZHalfLength()/mm));
824  tubeElement->setAttributeNode(NewAttribute("startphi",
825  tube->GetStartPhiAngle()/degree));
826  tubeElement->setAttributeNode(NewAttribute("deltaphi",
827  tube->GetDeltaPhiAngle()/degree));
828  tubeElement->setAttributeNode(NewAttribute("aunit","deg"));
829  tubeElement->setAttributeNode(NewAttribute("lunit","mm"));
830  solElement->appendChild(tubeElement);
831 }
832 
834 CutTubeWrite(xercesc::DOMElement* solElement, const G4CutTubs* const cuttube)
835 {
836  const G4String& name = GenerateName(cuttube->GetName(),cuttube);
837 
838  xercesc::DOMElement* cuttubeElement = NewElement("cutTube");
839  cuttubeElement->setAttributeNode(NewAttribute("name",name));
840  cuttubeElement->setAttributeNode(NewAttribute("rmin",
841  cuttube->GetInnerRadius()/mm));
842  cuttubeElement->setAttributeNode(NewAttribute("rmax",
843  cuttube->GetOuterRadius()/mm));
844  cuttubeElement->setAttributeNode(NewAttribute("z",
845  2.0*cuttube->GetZHalfLength()/mm));
846  cuttubeElement->setAttributeNode(NewAttribute("startphi",
847  cuttube->GetStartPhiAngle()/degree));
848  cuttubeElement->setAttributeNode(NewAttribute("deltaphi",
849  cuttube->GetDeltaPhiAngle()/degree));
850  cuttubeElement->setAttributeNode(NewAttribute("lowX",
851  cuttube->GetLowNorm().getX()/mm));
852  cuttubeElement->setAttributeNode(NewAttribute("lowY",
853  cuttube->GetLowNorm().getY()/mm));
854  cuttubeElement->setAttributeNode(NewAttribute("lowZ",
855  cuttube->GetLowNorm().getZ()/mm));
856  cuttubeElement->setAttributeNode(NewAttribute("highX",
857  cuttube->GetHighNorm().getX()/mm));
858  cuttubeElement->setAttributeNode(NewAttribute("highY",
859  cuttube->GetHighNorm().getY()/mm));
860  cuttubeElement->setAttributeNode(NewAttribute("highZ",
861  cuttube->GetHighNorm().getZ()/mm));
862  cuttubeElement->setAttributeNode(NewAttribute("aunit","deg"));
863  cuttubeElement->setAttributeNode(NewAttribute("lunit","mm"));
864  solElement->appendChild(cuttubeElement);
865 }
866 
868 TwistedboxWrite(xercesc::DOMElement* solElement,
869  const G4TwistedBox* const twistedbox)
870 {
871  const G4String& name = GenerateName(twistedbox->GetName(),twistedbox);
872 
873  xercesc::DOMElement* twistedboxElement = NewElement("twistedbox");
874  twistedboxElement->setAttributeNode(NewAttribute("name",name));
875  twistedboxElement->setAttributeNode(NewAttribute("x",
876  2.0*twistedbox->GetXHalfLength()/mm));
877  twistedboxElement->setAttributeNode(NewAttribute("y",
878  2.0*twistedbox->GetYHalfLength()/mm));
879  twistedboxElement->setAttributeNode(NewAttribute("z",
880  2.0*twistedbox->GetZHalfLength()/mm));
881  twistedboxElement->setAttributeNode(NewAttribute("PhiTwist",
882  twistedbox->GetPhiTwist()/degree));
883  twistedboxElement->setAttributeNode(NewAttribute("aunit","deg"));
884  twistedboxElement->setAttributeNode(NewAttribute("lunit","mm"));
885  solElement->appendChild(twistedboxElement);
886 }
887 
889 TwistedtrapWrite(xercesc::DOMElement* solElement,
890  const G4TwistedTrap* const twistedtrap)
891 {
892  const G4String& name = GenerateName(twistedtrap->GetName(),twistedtrap);
893 
894  xercesc::DOMElement* twistedtrapElement = NewElement("twistedtrap");
895  twistedtrapElement->setAttributeNode(NewAttribute("name",name));
896  twistedtrapElement->setAttributeNode(NewAttribute("y1",
897  2.0*twistedtrap->GetY1HalfLength()/mm));
898  twistedtrapElement->setAttributeNode(NewAttribute("x1",
899  2.0*twistedtrap->GetX1HalfLength()/mm));
900  twistedtrapElement->setAttributeNode(NewAttribute("x2",
901  2.0*twistedtrap->GetX2HalfLength()/mm));
902  twistedtrapElement->setAttributeNode(NewAttribute("y2",
903  2.0*twistedtrap->GetY2HalfLength()/mm));
904  twistedtrapElement->setAttributeNode(NewAttribute("x3",
905  2.0*twistedtrap->GetX3HalfLength()/mm));
906  twistedtrapElement->setAttributeNode(NewAttribute("x4",
907  2.0*twistedtrap->GetX4HalfLength()/mm));
908  twistedtrapElement->setAttributeNode(NewAttribute("z",
909  2.0*twistedtrap->GetZHalfLength()/mm));
910  twistedtrapElement->setAttributeNode(NewAttribute("Alph",
911  twistedtrap->GetTiltAngleAlpha()/degree));
912  twistedtrapElement->setAttributeNode(NewAttribute("Theta",
913  twistedtrap->GetPolarAngleTheta()/degree));
914  twistedtrapElement->setAttributeNode(NewAttribute("Phi",
915  twistedtrap->GetAzimuthalAnglePhi()/degree));
916  twistedtrapElement->setAttributeNode(NewAttribute("PhiTwist",
917  twistedtrap->GetPhiTwist()/degree));
918  twistedtrapElement->setAttributeNode(NewAttribute("aunit","deg"));
919  twistedtrapElement->setAttributeNode(NewAttribute("lunit","mm"));
920 
921  solElement->appendChild(twistedtrapElement);
922 }
923 
925 TwistedtrdWrite(xercesc::DOMElement* solElement,
926  const G4TwistedTrd* const twistedtrd)
927 {
928  const G4String& name = GenerateName(twistedtrd->GetName(),twistedtrd);
929 
930  xercesc::DOMElement* twistedtrdElement = NewElement("twistedtrd");
931  twistedtrdElement->setAttributeNode(NewAttribute("name",name));
932  twistedtrdElement->setAttributeNode(NewAttribute("x1",
933  2.0*twistedtrd->GetX1HalfLength()/mm));
934  twistedtrdElement->setAttributeNode(NewAttribute("x2",
935  2.0*twistedtrd->GetX2HalfLength()/mm));
936  twistedtrdElement->setAttributeNode(NewAttribute("y1",
937  2.0*twistedtrd->GetY1HalfLength()/mm));
938  twistedtrdElement->setAttributeNode(NewAttribute("y2",
939  2.0*twistedtrd->GetY2HalfLength()/mm));
940  twistedtrdElement->setAttributeNode(NewAttribute("z",
941  2.0*twistedtrd->GetZHalfLength()/mm));
942  twistedtrdElement->setAttributeNode(NewAttribute("PhiTwist",
943  twistedtrd->GetPhiTwist()/degree));
944  twistedtrdElement->setAttributeNode(NewAttribute("aunit","deg"));
945  twistedtrdElement->setAttributeNode(NewAttribute("lunit","mm"));
946  solElement->appendChild(twistedtrdElement);
947 }
948 
950 TwistedtubsWrite(xercesc::DOMElement* solElement,
951  const G4TwistedTubs* const twistedtubs)
952 {
953  const G4String& name = GenerateName(twistedtubs->GetName(),twistedtubs);
954 
955  xercesc::DOMElement* twistedtubsElement = NewElement("twistedtubs");
956  twistedtubsElement->setAttributeNode(NewAttribute("name",name));
957  twistedtubsElement->setAttributeNode(NewAttribute("twistedangle",
958  twistedtubs->GetPhiTwist()/degree));
959  twistedtubsElement->setAttributeNode(NewAttribute("endinnerrad",
960  twistedtubs->GetInnerRadius()/mm));
961  twistedtubsElement->setAttributeNode(NewAttribute("endouterrad",
962  twistedtubs->GetOuterRadius()/mm));
963  twistedtubsElement->setAttributeNode(NewAttribute("zlen",
964  2.0*twistedtubs->GetZHalfLength()/mm));
965  twistedtubsElement->setAttributeNode(NewAttribute("phi",
966  twistedtubs->GetDPhi()/degree));
967  twistedtubsElement->setAttributeNode(NewAttribute("aunit","deg"));
968  twistedtubsElement->setAttributeNode(NewAttribute("lunit","mm"));
969  solElement->appendChild(twistedtubsElement);
970 }
971 
973 ZplaneWrite(xercesc::DOMElement* element, const G4double& z,
974  const G4double& rmin, const G4double& rmax)
975 {
976  xercesc::DOMElement* zplaneElement = NewElement("zplane");
977  zplaneElement->setAttributeNode(NewAttribute("z",z/mm));
978  zplaneElement->setAttributeNode(NewAttribute("rmin",rmin/mm));
979  zplaneElement->setAttributeNode(NewAttribute("rmax",rmax/mm));
980  element->appendChild(zplaneElement);
981 }
982 
984 RZPointWrite(xercesc::DOMElement* element, const G4double& r,
985  const G4double& z)
986 {
987  xercesc::DOMElement* rzpointElement = NewElement("rzpoint");
988  rzpointElement->setAttributeNode(NewAttribute("r",r/mm));
989  rzpointElement->setAttributeNode(NewAttribute("z",z/mm));
990  element->appendChild(rzpointElement);
991 }
992 
994 OpticalSurfaceWrite(xercesc::DOMElement* solElement,
995  const G4OpticalSurface* const surf)
996 {
997  xercesc::DOMElement* optElement = NewElement("opticalsurface");
998  G4OpticalSurfaceModel smodel = surf->GetModel();
999  G4double sval = (smodel==glisur) ? surf->GetPolish() : surf->GetSigmaAlpha();
1000 
1001  optElement->setAttributeNode(NewAttribute("name", surf->GetName()));
1002  optElement->setAttributeNode(NewAttribute("model", smodel));
1003  optElement->setAttributeNode(NewAttribute("finish", surf->GetFinish()));
1004  optElement->setAttributeNode(NewAttribute("type", surf->GetType()));
1005  optElement->setAttributeNode(NewAttribute("value", sval));
1006 
1007  solElement->appendChild(optElement);
1008 }
1009 
1010 void G4GDMLWriteSolids::SolidsWrite(xercesc::DOMElement* gdmlElement)
1011 {
1012  G4cout << "G4GDML: Writing solids..." << G4endl;
1013 
1014  solidsElement = NewElement("solids");
1015  gdmlElement->appendChild(solidsElement);
1016 
1017  solidList.clear();
1018 }
1019 
1020 void G4GDMLWriteSolids::AddSolid(const G4VSolid* const solidPtr)
1021 {
1022  for (size_t i=0; i<solidList.size(); i++) // Check if solid is
1023  { // already in the list!
1024  if (solidList[i] == solidPtr) { return; }
1025  }
1026 
1027  solidList.push_back(solidPtr);
1028 
1029  if (const G4BooleanSolid* const booleanPtr
1030  = dynamic_cast<const G4BooleanSolid*>(solidPtr))
1031  { BooleanWrite(solidsElement,booleanPtr); } else
1032  if (solidPtr->GetEntityType()=="G4MultiUnion")
1033  { const G4MultiUnion* const munionPtr
1034  = static_cast<const G4MultiUnion*>(solidPtr);
1035  MultiUnionWrite(solidsElement,munionPtr); } else
1036  if (solidPtr->GetEntityType()=="G4Box")
1037  { const G4Box* const boxPtr
1038  = static_cast<const G4Box*>(solidPtr);
1039  BoxWrite(solidsElement,boxPtr); } else
1040  if (solidPtr->GetEntityType()=="G4Cons")
1041  { const G4Cons* const conePtr
1042  = static_cast<const G4Cons*>(solidPtr);
1043  ConeWrite(solidsElement,conePtr); } else
1044  if (solidPtr->GetEntityType()=="G4EllipticalCone")
1045  { const G4EllipticalCone* const elconePtr
1046  = static_cast<const G4EllipticalCone*>(solidPtr);
1047  ElconeWrite(solidsElement,elconePtr); } else
1048  if (solidPtr->GetEntityType()=="G4Ellipsoid")
1049  { const G4Ellipsoid* const ellipsoidPtr
1050  = static_cast<const G4Ellipsoid*>(solidPtr);
1051  EllipsoidWrite(solidsElement,ellipsoidPtr); } else
1052  if (solidPtr->GetEntityType()=="G4EllipticalTube")
1053  { const G4EllipticalTube* const eltubePtr
1054  = static_cast<const G4EllipticalTube*>(solidPtr);
1055  EltubeWrite(solidsElement,eltubePtr); } else
1056  if (solidPtr->GetEntityType()=="G4ExtrudedSolid")
1057  { const G4ExtrudedSolid* const xtruPtr
1058  = static_cast<const G4ExtrudedSolid*>(solidPtr);
1059  XtruWrite(solidsElement,xtruPtr); } else
1060  if (solidPtr->GetEntityType()=="G4Hype")
1061  { const G4Hype* const hypePtr
1062  = static_cast<const G4Hype*>(solidPtr);
1063  HypeWrite(solidsElement,hypePtr); } else
1064  if (solidPtr->GetEntityType()=="G4Orb")
1065  { const G4Orb* const orbPtr
1066  = static_cast<const G4Orb*>(solidPtr);
1067  OrbWrite(solidsElement,orbPtr); } else
1068  if (solidPtr->GetEntityType()=="G4Para")
1069  { const G4Para* const paraPtr
1070  = static_cast<const G4Para*>(solidPtr);
1071  ParaWrite(solidsElement,paraPtr); } else
1072  if (solidPtr->GetEntityType()=="G4Paraboloid")
1073  { const G4Paraboloid* const paraboloidPtr
1074  = static_cast<const G4Paraboloid*>(solidPtr);
1075  ParaboloidWrite(solidsElement,paraboloidPtr); } else
1076  if (solidPtr->GetEntityType()=="G4Polycone")
1077  { const G4Polycone* const polyconePtr
1078  = static_cast<const G4Polycone*>(solidPtr);
1079  PolyconeWrite(solidsElement,polyconePtr); } else
1080  if (solidPtr->GetEntityType()=="G4GenericPolycone")
1081  { const G4GenericPolycone* const genpolyconePtr
1082  = static_cast<const G4GenericPolycone*>(solidPtr);
1083  GenericPolyconeWrite(solidsElement,genpolyconePtr); } else
1084  if (solidPtr->GetEntityType()=="G4Polyhedra")
1085  { const G4Polyhedra* const polyhedraPtr
1086  = static_cast<const G4Polyhedra*>(solidPtr);
1087  PolyhedraWrite(solidsElement,polyhedraPtr); } else
1088  if (solidPtr->GetEntityType()=="G4Sphere")
1089  { const G4Sphere* const spherePtr
1090  = static_cast<const G4Sphere*>(solidPtr);
1091  SphereWrite(solidsElement,spherePtr); } else
1092  if (solidPtr->GetEntityType()=="G4TessellatedSolid")
1093  { const G4TessellatedSolid* const tessellatedPtr
1094  = static_cast<const G4TessellatedSolid*>(solidPtr);
1095  TessellatedWrite(solidsElement,tessellatedPtr); } else
1096  if (solidPtr->GetEntityType()=="G4Tet")
1097  { const G4Tet* const tetPtr
1098  = static_cast<const G4Tet*>(solidPtr);
1099  TetWrite(solidsElement,tetPtr); } else
1100  if (solidPtr->GetEntityType()=="G4Torus")
1101  { const G4Torus* const torusPtr
1102  = static_cast<const G4Torus*>(solidPtr);
1103  TorusWrite(solidsElement,torusPtr); } else
1104  if (solidPtr->GetEntityType()=="G4GenericTrap")
1105  { const G4GenericTrap* const gtrapPtr
1106  = static_cast<const G4GenericTrap*>(solidPtr);
1107  GenTrapWrite(solidsElement,gtrapPtr); } else
1108  if (solidPtr->GetEntityType()=="G4Trap")
1109  { const G4Trap* const trapPtr
1110  = static_cast<const G4Trap*>(solidPtr);
1111  TrapWrite(solidsElement,trapPtr); } else
1112  if (solidPtr->GetEntityType()=="G4Trd")
1113  { const G4Trd* const trdPtr
1114  = static_cast<const G4Trd*>(solidPtr);
1115  TrdWrite(solidsElement,trdPtr); } else
1116  if (solidPtr->GetEntityType()=="G4Tubs")
1117  { const G4Tubs* const tubePtr
1118  = static_cast<const G4Tubs*>(solidPtr);
1119  TubeWrite(solidsElement,tubePtr); } else
1120  if (solidPtr->GetEntityType()=="G4CutTubs")
1121  { const G4CutTubs* const cuttubePtr
1122  = static_cast<const G4CutTubs*>(solidPtr);
1123  CutTubeWrite(solidsElement,cuttubePtr); } else
1124  if (solidPtr->GetEntityType()=="G4TwistedBox")
1125  { const G4TwistedBox* const twistedboxPtr
1126  = static_cast<const G4TwistedBox*>(solidPtr);
1127  TwistedboxWrite(solidsElement,twistedboxPtr); } else
1128  if (solidPtr->GetEntityType()=="G4TwistedTrap")
1129  { const G4TwistedTrap* const twistedtrapPtr
1130  = static_cast<const G4TwistedTrap*>(solidPtr);
1131  TwistedtrapWrite(solidsElement,twistedtrapPtr); } else
1132  if (solidPtr->GetEntityType()=="G4TwistedTrd")
1133  { const G4TwistedTrd* const twistedtrdPtr
1134  = static_cast<const G4TwistedTrd*>(solidPtr);
1135  TwistedtrdWrite(solidsElement,twistedtrdPtr); } else
1136  if (solidPtr->GetEntityType()=="G4TwistedTubs")
1137  { const G4TwistedTubs* const twistedtubsPtr
1138  = static_cast<const G4TwistedTubs*>(solidPtr);
1139  TwistedtubsWrite(solidsElement,twistedtubsPtr); }
1140  else
1141  {
1142  G4String error_msg = "Unknown solid: " + solidPtr->GetName()
1143  + "; Type: " + solidPtr->GetEntityType();
1144  G4Exception("G4GDMLWriteSolids::AddSolid()", "WriteError",
1145  FatalException, error_msg);
1146  }
1147 }
G4ThreeVector GetSymAxis() const
G4double GetSPhi() const
static const G4double kAngularPrecision
G4PolyconeSideRZ GetCorner(G4int index) const
G4String GetName() const
G4double GetXHalfLength4() const
G4double GetXHalfLength() const
G4double GetOuterStereo() const
Definition: G4Para.hh:77
G4double GetX1HalfLength() const
Definition: G4TwistedTrd.hh:77
G4OpticalSurfaceModel GetModel() const
G4double GetY1HalfLength() const
Definition: G4TwistedTrd.hh:79
G4double GetPolarAngleTheta() const
G4double GetYHalfLength2() const
G4double GetYHalfLength1() const
G4double GetInnerStereo() const
G4double GetDy() const
G4double GetSemiAxisX() const
CLHEP::Hep3Vector G4ThreeVector
void BoxWrite(xercesc::DOMElement *, const G4Box *const)
G4double GetInnerRadius() const
CLHEP::HepRotation G4RotationMatrix
void PolyhedraWrite(xercesc::DOMElement *, const G4Polyhedra *const)
void TessellatedWrite(xercesc::DOMElement *, const G4TessellatedSolid *const)
G4double z
Definition: TRTMaterials.hh:39
Definition: G4Box.hh:64
G4String name
Definition: TRTMaterials.hh:40
G4double GetZTopCut() const
G4double GetZHalfLength() const
G4ThreeVector GetLowNorm() const
Definition: G4Tubs.hh:85
Definition: xmlparse.cc:179
G4double GetZHalfLength() const
virtual G4int GetNumberOfVertices() const =0
virtual ~G4GDMLWriteSolids()
G4double GetRmax() const
void TrdWrite(xercesc::DOMElement *, const G4Trd *const)
G4double GetZBottomCut() const
const G4String & GetName() const
void FirstpositionWrite(xercesc::DOMElement *element, const G4String &name, const G4ThreeVector &pos)
void XtruWrite(xercesc::DOMElement *, const G4ExtrudedSolid *const)
const G4SurfaceType & GetType() const
G4double GetZHalfLength() const
G4double GetOuterRadiusMinusZ() const
G4double GetRadiusMinusZ() const
Definition: G4Trd.hh:72
G4double GetX2HalfLength() const
Definition: G4TwistedTrd.hh:78
G4double GetInnerRadius() const
virtual G4GeometryType GetEntityType() const =0
G4double GetZHalfLength() const
void TwistedtrdWrite(xercesc::DOMElement *, const G4TwistedTrd *const)
xercesc::DOMElement * NewElement(const G4String &)
Definition: G4GDMLWrite.cc:127
G4double GetStartPhiAngle() const
G4double GetDeltaPhiAngle() const
int G4int
Definition: G4Types.hh:78
G4double GetZHalfLength() const
G4double GetSemiAxisMax(G4int i) const
G4double GetXHalfLength2() const
G4TwoVector GetVertex(G4int index) const
G4double GetZHalfLength() const
Definition: G4TwistedTrd.hh:81
G4double GetRtor() const
G4double GetZHalfLength() const
Definition: G4TwistedBox.hh:75
void TwistedboxWrite(xercesc::DOMElement *, const G4TwistedBox *const)
G4double GetEndPhi() const
G4double GetTanAlpha2() const
G4int GetNumRZCorner() const
G4double GetPhiTwist() const
G4VFacet * GetFacet(G4int i) const
G4double GetY1HalfLength() const
void MultiUnionWrite(xercesc::DOMElement *solElement, const G4MultiUnion *const)
std::vector< G4ThreeVector > GetVertices() const
Definition: G4Tet.cc:790
G4Transform3D * GetTransformation(G4int index) const
G4double GetXHalfLength2() const
G4double GetRadius() const
static const G4int maxTransforms
void RZPointWrite(xercesc::DOMElement *, const G4double &, const G4double &)
void OrbWrite(xercesc::DOMElement *, const G4Orb *const)
void TwistedtubsWrite(xercesc::DOMElement *, const G4TwistedTubs *const)
G4double GetXHalfLength1() const
G4double GetDz() const
G4GLOB_DLL std::ostream G4cout
G4double GetDeltaPhiAngle() const
G4double GetPolish() const
G4double GetStartThetaAngle() const
G4VSolid * GetSolid(G4int index) const
G4double GetRmin() const
G4double GetXHalfLength3() const
void TrapWrite(xercesc::DOMElement *, const G4Trap *const)
void ConeWrite(xercesc::DOMElement *, const G4Cons *const)
Definition: G4Tet.hh:65
void ElconeWrite(xercesc::DOMElement *, const G4EllipticalCone *const)
Definition: G4Hype.hh:67
G4double GetZHalfLength() const
void ParaboloidWrite(xercesc::DOMElement *, const G4Paraboloid *const)
void FirstrotationWrite(xercesc::DOMElement *element, const G4String &name, const G4ThreeVector &rot)
void PolyconeWrite(xercesc::DOMElement *, const G4Polycone *const)
G4double GetY2HalfLength() const
Definition: G4TwistedTrd.hh:80
G4int GetNofVertices() const
void OpticalSurfaceWrite(xercesc::DOMElement *, const G4OpticalSurface *const)
G4double GetZMax() const
Definition: G4Cons.hh:83
G4double GetX3HalfLength() const
G4double GetPhiTwist() const
Definition: G4TwistedTrd.hh:82
G4double GetDPhi() const
G4double GetYHalfLength() const
G4double GetStartPhiAngle() const
HepGeom::Transform3D G4Transform3D
void AddPosition(const G4String &name, const G4ThreeVector &pos)
void GenericPolyconeWrite(xercesc::DOMElement *, const G4GenericPolycone *const)
char boolean
Definition: csz_inflate.cc:223
G4double GetYHalfLength2() const
G4double GetOuterRadius() const
G4double GetStartPhiAngle() const
G4double GetStartPhi() const
G4String GenerateName(const G4String &, const void *const)
Definition: G4GDMLWrite.cc:90
G4double GetInnerRadiusPlusZ() const
void RotationWrite(xercesc::DOMElement *element, const G4String &name, const G4ThreeVector &rot)
G4double GetDPhi() const
void CutTubeWrite(xercesc::DOMElement *, const G4CutTubs *const)
G4double GetInnerRadius() const
G4PolyconeHistorical * GetOriginalParameters() const
G4OpticalSurfaceFinish GetFinish() const
G4double GetDx() const
G4int GetNofZSections() const
Definition: G4Orb.hh:61
G4double GetZHalfLength() const
G4double GetXHalfLength() const
G4double GetInnerRadius() const
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
Definition: G4Exception.cc:41
void ZplaneWrite(xercesc::DOMElement *, const G4double &, const G4double &, const G4double &)
G4double GetSemiAxisY() const
G4double GetX4HalfLength() const
G4double GetYHalfLength() const
Definition: G4TwistedBox.hh:74
void HypeWrite(xercesc::DOMElement *, const G4Hype *const)
G4int GetNumberOfFacets() const
G4double GetOuterRadius() const
G4double GetRadiusPlusZ() const
G4double GetZHalfLength() const
xercesc::DOMAttr * NewAttribute(const G4String &, const G4String &)
Definition: G4GDMLWrite.cc:103
static const G4double kLinearPrecision
G4double GetTanAlpha() const
G4bool IsGeneric() const
void EltubeWrite(xercesc::DOMElement *, const G4EllipticalTube *const)
void ParaWrite(xercesc::DOMElement *, const G4Para *const)
G4ThreeVector GetHighNorm() const
void EllipsoidWrite(xercesc::DOMElement *, const G4Ellipsoid *const)
G4ThreeVector GetAngles(const G4RotationMatrix &)
ZSection GetZSection(G4int index) const
virtual void SolidsWrite(xercesc::DOMElement *)
void TetWrite(xercesc::DOMElement *, const G4Tet *const)
G4PolyhedraHistorical * GetOriginalParameters() const
G4double GetZHalfLength() const
static const double degree
Definition: G4SIunits.hh:125
G4double GetZHalfLength() const
void TubeWrite(xercesc::DOMElement *, const G4Tubs *const)
G4ThreeVector GetSymAxis() const
G4double GetInnerRadius() const
CLHEP::Hep2Vector G4TwoVector
Definition: G4TwoVector.hh:42
G4double GetZTopCut() const
void BooleanWrite(xercesc::DOMElement *, const G4BooleanSolid *const)
G4double GetZHalfLength() const
G4double GetAzimuthalAnglePhi() const
G4OpticalSurfaceModel
#define G4endl
Definition: G4ios.hh:61
void TorusWrite(xercesc::DOMElement *, const G4Torus *const)
G4double GetXHalfLength1() const
G4double GetOuterRadius() const
G4double GetStartPhiAngle() const
G4PolyhedraSideRZ GetCorner(const G4int index) const
G4double GetYHalfLength1() const
G4double GetDeltaPhiAngle() const
void PositionWrite(xercesc::DOMElement *element, const G4String &name, const G4ThreeVector &pos)
void TwistedtrapWrite(xercesc::DOMElement *, const G4TwistedTrap *const)
double G4double
Definition: G4Types.hh:76
G4double GetPhiTwist() const
Definition: G4TwistedBox.hh:76
G4double GetInnerRadiusMinusZ() const
G4double GetSigmaAlpha() const
G4double GetTanAlpha1() const
static const G4double alpha
G4int GetNumRZCorner() const
virtual G4ThreeVector GetVertex(G4int i) const =0
G4double GetDeltaThetaAngle() const
G4double GetX1HalfLength() const
void GenTrapWrite(xercesc::DOMElement *, const G4GenericTrap *const)
static const double mm
Definition: G4SIunits.hh:102
G4double GetTiltAngleAlpha() const
G4double GetX2HalfLength() const
G4double GetOuterRadiusPlusZ() const
const std::vector< G4TwoVector > & GetVertices() const
G4double GetZHalfLength() const
G4double GetOuterRadius() const
G4double GetXHalfLength() const
Definition: G4TwistedBox.hh:73
xercesc::DOMElement * solidsElement
static const G4double pos
void SphereWrite(xercesc::DOMElement *, const G4Sphere *const)
G4double GetPhiTwist() const
G4double GetOuterRadius() const
virtual void AddSolid(const G4VSolid *const)
int GetNumberOfSolids() const
G4double GetY2HalfLength() const
std::vector< const G4VSolid * > solidList
G4double GetDeltaPhiAngle() const
G4double GetYHalfLength() const