Geant4  10.00.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 81843 2014-06-06 09:11:11Z 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 BooleanWrite(xercesc::DOMElement* solElement,
83  const G4BooleanSolid* const boolean)
84 {
85  G4int displaced=0;
86 
87  G4String tag("undefined");
88  if (dynamic_cast<const G4IntersectionSolid*>(boolean))
89  { tag = "intersection"; } else
90  if (dynamic_cast<const G4SubtractionSolid*>(boolean))
91  { tag = "subtraction"; } else
92  if (dynamic_cast<const G4UnionSolid*>(boolean))
93  { tag = "union"; }
94 
95  G4VSolid* firstPtr = const_cast<G4VSolid*>(boolean->GetConstituentSolid(0));
96  G4VSolid* secondPtr = const_cast<G4VSolid*>(boolean->GetConstituentSolid(1));
97 
98  G4ThreeVector firstpos,firstrot,pos,rot;
99 
100  // Solve possible displacement of referenced solids!
101  //
102  while (true)
103  {
104  if ( displaced>8 )
105  {
106  G4String ErrorMessage = "The referenced solid '"
107  + firstPtr->GetName() +
108  + "in the Boolean shape '" +
109  + boolean->GetName() +
110  + "' was displaced too many times!";
111  G4Exception("G4GDMLWriteSolids::BooleanWrite()",
112  "InvalidSetup", FatalException, ErrorMessage);
113  }
114 
115  if (G4DisplacedSolid* disp = dynamic_cast<G4DisplacedSolid*>(firstPtr))
116  {
117  firstpos += disp->GetObjectTranslation();
118  firstrot += firstrot + GetAngles(disp->GetObjectRotation());
119  firstPtr = disp->GetConstituentMovedSolid();
120  displaced++;
121  continue;
122  }
123  break;
124  }
125  displaced = 0;
126  while (true)
127  {
128  if ( displaced>maxTransforms )
129  {
130  G4String ErrorMessage = "The referenced solid '"
131  + secondPtr->GetName() +
132  + "in the Boolean shape '" +
133  + boolean->GetName() +
134  + "' was displaced too many times!";
135  G4Exception("G4GDMLWriteSolids::BooleanWrite()",
136  "InvalidSetup", FatalException, ErrorMessage);
137  }
138 
139  if (G4DisplacedSolid* disp = dynamic_cast<G4DisplacedSolid*>(secondPtr))
140  {
141  pos += disp->GetObjectTranslation();
142  rot += GetAngles(disp->GetObjectRotation());
143  secondPtr = disp->GetConstituentMovedSolid();
144  displaced++;
145  continue;
146  }
147  break;
148  }
149 
150  AddSolid(firstPtr); // At first add the constituent solids!
151  AddSolid(secondPtr);
152 
153  const G4String& name = GenerateName(boolean->GetName(),boolean);
154  const G4String& firstref = GenerateName(firstPtr->GetName(),firstPtr);
155  const G4String& secondref = GenerateName(secondPtr->GetName(),secondPtr);
156 
157  xercesc::DOMElement* booleanElement = NewElement(tag);
158  booleanElement->setAttributeNode(NewAttribute("name",name));
159  xercesc::DOMElement* firstElement = NewElement("first");
160  firstElement->setAttributeNode(NewAttribute("ref",firstref));
161  booleanElement->appendChild(firstElement);
162  xercesc::DOMElement* secondElement = NewElement("second");
163  secondElement->setAttributeNode(NewAttribute("ref",secondref));
164  booleanElement->appendChild(secondElement);
165  solElement->appendChild(booleanElement);
166  // Add the boolean solid AFTER the constituent solids!
167 
168  if ( (std::fabs(pos.x()) > kLinearPrecision)
169  || (std::fabs(pos.y()) > kLinearPrecision)
170  || (std::fabs(pos.z()) > kLinearPrecision) )
171  {
172  PositionWrite(booleanElement,name+"_pos",pos);
173  }
174 
175  if ( (std::fabs(rot.x()) > kAngularPrecision)
176  || (std::fabs(rot.y()) > kAngularPrecision)
177  || (std::fabs(rot.z()) > kAngularPrecision) )
178  {
179  RotationWrite(booleanElement,name+"_rot",rot);
180  }
181 
182  if ( (std::fabs(firstpos.x()) > kLinearPrecision)
183  || (std::fabs(firstpos.y()) > kLinearPrecision)
184  || (std::fabs(firstpos.z()) > kLinearPrecision) )
185  {
186  FirstpositionWrite(booleanElement,name+"_fpos",firstpos);
187  }
188 
189  if ( (std::fabs(firstrot.x()) > kAngularPrecision)
190  || (std::fabs(firstrot.y()) > kAngularPrecision)
191  || (std::fabs(firstrot.z()) > kAngularPrecision) )
192  {
193  FirstrotationWrite(booleanElement,name+"_frot",firstrot);
194  }
195 }
196 
198 BoxWrite(xercesc::DOMElement* solElement, const G4Box* const box)
199 {
200  const G4String& name = GenerateName(box->GetName(),box);
201 
202  xercesc::DOMElement* boxElement = NewElement("box");
203  boxElement->setAttributeNode(NewAttribute("name",name));
204  boxElement->setAttributeNode(NewAttribute("x",2.0*box->GetXHalfLength()/mm));
205  boxElement->setAttributeNode(NewAttribute("y",2.0*box->GetYHalfLength()/mm));
206  boxElement->setAttributeNode(NewAttribute("z",2.0*box->GetZHalfLength()/mm));
207  boxElement->setAttributeNode(NewAttribute("lunit","mm"));
208  solElement->appendChild(boxElement);
209 }
210 
212 ConeWrite(xercesc::DOMElement* solElement, const G4Cons* const cone)
213 {
214  const G4String& name = GenerateName(cone->GetName(),cone);
215 
216  xercesc::DOMElement* coneElement = NewElement("cone");
217  coneElement->setAttributeNode(NewAttribute("name",name));
218  coneElement->
219  setAttributeNode(NewAttribute("rmin1",cone->GetInnerRadiusMinusZ()/mm));
220  coneElement->
221  setAttributeNode(NewAttribute("rmax1",cone->GetOuterRadiusMinusZ()/mm));
222  coneElement->
223  setAttributeNode(NewAttribute("rmin2",cone->GetInnerRadiusPlusZ()/mm));
224  coneElement->
225  setAttributeNode(NewAttribute("rmax2",cone->GetOuterRadiusPlusZ()/mm));
226  coneElement->
227  setAttributeNode(NewAttribute("z",2.0*cone->GetZHalfLength()/mm));
228  coneElement->
229  setAttributeNode(NewAttribute("startphi",cone->GetStartPhiAngle()/degree));
230  coneElement->
231  setAttributeNode(NewAttribute("deltaphi",cone->GetDeltaPhiAngle()/degree));
232  coneElement->setAttributeNode(NewAttribute("aunit","deg"));
233  coneElement->setAttributeNode(NewAttribute("lunit","mm"));
234  solElement->appendChild(coneElement);
235 }
236 
238 ElconeWrite(xercesc::DOMElement* solElement,
239  const G4EllipticalCone* const elcone)
240 {
241  const G4String& name = GenerateName(elcone->GetName(),elcone);
242 
243  xercesc::DOMElement* elconeElement = NewElement("elcone");
244  elconeElement->setAttributeNode(NewAttribute("name",name));
245  elconeElement->setAttributeNode(NewAttribute("dx",elcone->GetSemiAxisX()/mm));
246  elconeElement->setAttributeNode(NewAttribute("dy",elcone->GetSemiAxisY()/mm));
247  elconeElement->setAttributeNode(NewAttribute("zmax",elcone->GetZMax()/mm));
248  elconeElement->setAttributeNode(NewAttribute("zcut",elcone->GetZTopCut()/mm));
249  elconeElement->setAttributeNode(NewAttribute("lunit","mm"));
250  solElement->appendChild(elconeElement);
251 }
252 
254 EllipsoidWrite(xercesc::DOMElement* solElement,
255  const G4Ellipsoid* const ellipsoid)
256 {
257  const G4String& name = GenerateName(ellipsoid->GetName(),ellipsoid);
258 
259  xercesc::DOMElement* ellipsoidElement = NewElement("ellipsoid");
260  ellipsoidElement->setAttributeNode(NewAttribute("name",name));
261  ellipsoidElement->
262  setAttributeNode(NewAttribute("ax",ellipsoid->GetSemiAxisMax(0)/mm));
263  ellipsoidElement->
264  setAttributeNode(NewAttribute("by",ellipsoid->GetSemiAxisMax(1)/mm));
265  ellipsoidElement->
266  setAttributeNode(NewAttribute("cz",ellipsoid->GetSemiAxisMax(2)/mm));
267  ellipsoidElement->
268  setAttributeNode(NewAttribute("zcut1",ellipsoid->GetZBottomCut()/mm));
269  ellipsoidElement->
270  setAttributeNode(NewAttribute("zcut2",ellipsoid->GetZTopCut()/mm));
271  ellipsoidElement->
272  setAttributeNode(NewAttribute("lunit","mm"));
273  solElement->appendChild(ellipsoidElement);
274 }
275 
277 EltubeWrite(xercesc::DOMElement* solElement,
278  const G4EllipticalTube* const eltube)
279 {
280  const G4String& name = GenerateName(eltube->GetName(),eltube);
281 
282  xercesc::DOMElement* eltubeElement = NewElement("eltube");
283  eltubeElement->setAttributeNode(NewAttribute("name",name));
284  eltubeElement->setAttributeNode(NewAttribute("dx",eltube->GetDx()/mm));
285  eltubeElement->setAttributeNode(NewAttribute("dy",eltube->GetDy()/mm));
286  eltubeElement->setAttributeNode(NewAttribute("dz",eltube->GetDz()/mm));
287  eltubeElement->setAttributeNode(NewAttribute("lunit","mm"));
288  solElement->appendChild(eltubeElement);
289 }
290 
292 XtruWrite(xercesc::DOMElement* solElement,
293  const G4ExtrudedSolid* const xtru)
294 {
295  const G4String& name = GenerateName(xtru->GetName(),xtru);
296 
297  xercesc::DOMElement* xtruElement = NewElement("xtru");
298  xtruElement->setAttributeNode(NewAttribute("name",name));
299  xtruElement->setAttributeNode(NewAttribute("lunit","mm"));
300  solElement->appendChild(xtruElement);
301 
302  const G4int NumVertex = xtru->GetNofVertices();
303 
304  for (G4int i=0;i<NumVertex;i++)
305  {
306  xercesc::DOMElement* twoDimVertexElement = NewElement("twoDimVertex");
307  xtruElement->appendChild(twoDimVertexElement);
308 
309  const G4TwoVector& vertex = xtru->GetVertex(i);
310 
311  twoDimVertexElement->setAttributeNode(NewAttribute("x",vertex.x()/mm));
312  twoDimVertexElement->setAttributeNode(NewAttribute("y",vertex.y()/mm));
313  }
314 
315  const G4int NumSection = xtru->GetNofZSections();
316 
317  for (G4int i=0;i<NumSection;i++)
318  {
319  xercesc::DOMElement* sectionElement = NewElement("section");
320  xtruElement->appendChild(sectionElement);
321 
322  const G4ExtrudedSolid::ZSection section = xtru->GetZSection(i);
323 
324  sectionElement->setAttributeNode(NewAttribute("zOrder",i));
325  sectionElement->setAttributeNode(NewAttribute("zPosition",section.fZ/mm));
326  sectionElement->
327  setAttributeNode(NewAttribute("xOffset",section.fOffset.x()/mm));
328  sectionElement->
329  setAttributeNode(NewAttribute("yOffset",section.fOffset.y()/mm));
330  sectionElement->
331  setAttributeNode(NewAttribute("scalingFactor",section.fScale));
332  }
333 }
334 
336 HypeWrite(xercesc::DOMElement* solElement, const G4Hype* const hype)
337 {
338  const G4String& name = GenerateName(hype->GetName(),hype);
339 
340  xercesc::DOMElement* hypeElement = NewElement("hype");
341  hypeElement->setAttributeNode(NewAttribute("name",name));
342  hypeElement->setAttributeNode(NewAttribute("rmin",
343  hype->GetInnerRadius()/mm));
344  hypeElement->setAttributeNode(NewAttribute("rmax",
345  hype->GetOuterRadius()/mm));
346  hypeElement->setAttributeNode(NewAttribute("inst",
347  hype->GetInnerStereo()/degree));
348  hypeElement->setAttributeNode(NewAttribute("outst",
349  hype->GetOuterStereo()/degree));
350  hypeElement->setAttributeNode(NewAttribute("z",
351  2.0*hype->GetZHalfLength()/mm));
352  hypeElement->setAttributeNode(NewAttribute("aunit","deg"));
353  hypeElement->setAttributeNode(NewAttribute("lunit","mm"));
354  solElement->appendChild(hypeElement);
355 }
356 
358 OrbWrite(xercesc::DOMElement* solElement, const G4Orb* const orb)
359 {
360  const G4String& name = GenerateName(orb->GetName(),orb);
361 
362  xercesc::DOMElement* orbElement = NewElement("orb");
363  orbElement->setAttributeNode(NewAttribute("name",name));
364  orbElement->setAttributeNode(NewAttribute("r",orb->GetRadius()/mm));
365  orbElement->setAttributeNode(NewAttribute("lunit","mm"));
366  solElement->appendChild(orbElement);
367 }
368 
370 ParaWrite(xercesc::DOMElement* solElement, const G4Para* const para)
371 {
372  const G4String& name = GenerateName(para->GetName(),para);
373 
374  const G4ThreeVector simaxis = para->GetSymAxis();
375  const G4double alpha = std::atan(para->GetTanAlpha());
376  const G4double phi = simaxis.phi();
377  const G4double theta = simaxis.theta();
378 
379  xercesc::DOMElement* paraElement = NewElement("para");
380  paraElement->setAttributeNode(NewAttribute("name",name));
381  paraElement->setAttributeNode(NewAttribute("x",
382  2.0*para->GetXHalfLength()/mm));
383  paraElement->setAttributeNode(NewAttribute("y",
384  2.0*para->GetYHalfLength()/mm));
385  paraElement->setAttributeNode(NewAttribute("z",
386  2.0*para->GetZHalfLength()/mm));
387  paraElement->setAttributeNode(NewAttribute("alpha",alpha/degree));
388  paraElement->setAttributeNode(NewAttribute("theta",theta/degree));
389  paraElement->setAttributeNode(NewAttribute("phi",phi/degree));
390  paraElement->setAttributeNode(NewAttribute("aunit","deg"));
391  paraElement->setAttributeNode(NewAttribute("lunit","mm"));
392  solElement->appendChild(paraElement);
393 }
394 
396 ParaboloidWrite(xercesc::DOMElement* solElement,
397  const G4Paraboloid* const paraboloid)
398 {
399  const G4String& name = GenerateName(paraboloid->GetName(),paraboloid);
400 
401  xercesc::DOMElement* paraboloidElement = NewElement("paraboloid");
402  paraboloidElement->setAttributeNode(NewAttribute("name",name));
403  paraboloidElement->setAttributeNode(NewAttribute("rlo",
404  paraboloid->GetRadiusMinusZ()/mm));
405  paraboloidElement->setAttributeNode(NewAttribute("rhi",
406  paraboloid->GetRadiusPlusZ()/mm));
407  paraboloidElement->setAttributeNode(NewAttribute("dz",
408  paraboloid->GetZHalfLength()/mm));
409  paraboloidElement->setAttributeNode(NewAttribute("lunit","mm"));
410  solElement->appendChild(paraboloidElement);
411 }
413 PolyconeWrite(xercesc::DOMElement* solElement,
414  const G4Polycone* const polycone)
415 {
416  const G4String& name = GenerateName(polycone->GetName(),polycone);
417 
418  xercesc::DOMElement* polyconeElement = NewElement("polycone");
419  polyconeElement->setAttributeNode(NewAttribute("name",name));
420  polyconeElement->setAttributeNode(NewAttribute("startphi",
422  polyconeElement->setAttributeNode(NewAttribute("deltaphi",
424  polyconeElement->setAttributeNode(NewAttribute("aunit","deg"));
425  polyconeElement->setAttributeNode(NewAttribute("lunit","mm"));
426  solElement->appendChild(polyconeElement);
427 
428  const size_t num_zplanes = polycone->GetOriginalParameters()->Num_z_planes;
429  const G4double* z_array = polycone->GetOriginalParameters()->Z_values;
430  const G4double* rmin_array = polycone->GetOriginalParameters()->Rmin;
431  const G4double* rmax_array = polycone->GetOriginalParameters()->Rmax;
432 
433  for (size_t i=0; i<num_zplanes; i++)
434  {
435  ZplaneWrite(polyconeElement,z_array[i],rmin_array[i],rmax_array[i]);
436  }
437 
438 
439 }
440 
442 GenericPolyconeWrite(xercesc::DOMElement* solElement,
443  const G4GenericPolycone* const polycone)
444 {
445  const G4String& name = GenerateName(polycone->GetName(),polycone);
446  xercesc::DOMElement* polyconeElement = NewElement("genericPolycone");
447  const G4double startPhi=polycone->GetStartPhi();
448  polyconeElement->setAttributeNode(NewAttribute("name",name));
449  polyconeElement->setAttributeNode(NewAttribute("startphi",
450  startPhi/degree));
451  polyconeElement->setAttributeNode(NewAttribute("deltaphi",
452  (polycone->GetEndPhi()-startPhi)/degree));
453  polyconeElement->setAttributeNode(NewAttribute("aunit","deg"));
454  polyconeElement->setAttributeNode(NewAttribute("lunit","mm"));
455  solElement->appendChild(polyconeElement);
456 
457  const size_t num_rzpoints = polycone->GetNumRZCorner();
458  for (size_t i=0; i<num_rzpoints; i++)
459  {
460  const G4double r_point=polycone->GetCorner(i).r;
461  const G4double z_point=polycone->GetCorner(i).z;
462  RZPointWrite(polyconeElement,r_point,z_point);
463  }
464 
465 }
466 
468 PolyhedraWrite(xercesc::DOMElement* solElement,
469  const G4Polyhedra* const polyhedra)
470 {
471  const G4String& name = GenerateName(polyhedra->GetName(),polyhedra);
472  if(polyhedra->IsGeneric() == false){
473  xercesc::DOMElement* polyhedraElement = NewElement("polyhedra");
474  polyhedraElement->setAttributeNode(NewAttribute("name",name));
475  polyhedraElement->setAttributeNode(NewAttribute("startphi",
476  polyhedra->GetOriginalParameters()->Start_angle/degree));
477  polyhedraElement->setAttributeNode(NewAttribute("deltaphi",
479  polyhedraElement->setAttributeNode(NewAttribute("numsides",
480  polyhedra->GetOriginalParameters()->numSide));
481  polyhedraElement->setAttributeNode(NewAttribute("aunit","deg"));
482  polyhedraElement->setAttributeNode(NewAttribute("lunit","mm"));
483  solElement->appendChild(polyhedraElement);
484 
485  const size_t num_zplanes = polyhedra->GetOriginalParameters()->Num_z_planes;
486  const G4double* z_array = polyhedra->GetOriginalParameters()->Z_values;
487  const G4double* rmin_array = polyhedra->GetOriginalParameters()->Rmin;
488  const G4double* rmax_array = polyhedra->GetOriginalParameters()->Rmax;
489 
490  const G4double convertRad =
491  std::cos(0.5*polyhedra->GetOriginalParameters()->Opening_angle
492  / polyhedra->GetOriginalParameters()->numSide);
493 
494  for (size_t i=0;i<num_zplanes;i++)
495  {
496  ZplaneWrite(polyhedraElement,z_array[i],
497  rmin_array[i]*convertRad, rmax_array[i]*convertRad);
498  }
499  }else{//generic polyhedra
500 
501  xercesc::DOMElement* polyhedraElement = NewElement("genericPolyhedra");
502  polyhedraElement->setAttributeNode(NewAttribute("name",name));
503  polyhedraElement->setAttributeNode(NewAttribute("startphi",
504  polyhedra->GetOriginalParameters()->Start_angle/degree));
505  polyhedraElement->setAttributeNode(NewAttribute("deltaphi",
507  polyhedraElement->setAttributeNode(NewAttribute("numsides",
508  polyhedra->GetOriginalParameters()->numSide));
509  polyhedraElement->setAttributeNode(NewAttribute("aunit","deg"));
510  polyhedraElement->setAttributeNode(NewAttribute("lunit","mm"));
511  solElement->appendChild(polyhedraElement);
512 
513  const size_t num_rzpoints = polyhedra->GetNumRZCorner();
514 
515  for (size_t i=0;i<num_rzpoints;i++)
516  {
517  const G4double r_point = polyhedra->GetCorner(i).r;
518  const G4double z_point = polyhedra->GetCorner(i).z;
519  RZPointWrite(polyhedraElement,r_point,z_point);
520  }
521  }
522 }
523 
525 SphereWrite(xercesc::DOMElement* solElement, const G4Sphere* const sphere)
526 {
527  const G4String& name = GenerateName(sphere->GetName(),sphere);
528 
529  xercesc::DOMElement* sphereElement = NewElement("sphere");
530  sphereElement->setAttributeNode(NewAttribute("name",name));
531  sphereElement->setAttributeNode(NewAttribute("rmin",
532  sphere->GetInnerRadius()/mm));
533  sphereElement->setAttributeNode(NewAttribute("rmax",
534  sphere->GetOuterRadius()/mm));
535  sphereElement->setAttributeNode(NewAttribute("startphi",
536  sphere->GetStartPhiAngle()/degree));
537  sphereElement->setAttributeNode(NewAttribute("deltaphi",
538  sphere->GetDeltaPhiAngle()/degree));
539  sphereElement->setAttributeNode(NewAttribute("starttheta",
540  sphere->GetStartThetaAngle()/degree));
541  sphereElement->setAttributeNode(NewAttribute("deltatheta",
542  sphere->GetDeltaThetaAngle()/degree));
543  sphereElement->setAttributeNode(NewAttribute("aunit","deg"));
544  sphereElement->setAttributeNode(NewAttribute("lunit","mm"));
545  solElement->appendChild(sphereElement);
546 }
547 
549 TessellatedWrite(xercesc::DOMElement* solElement,
550  const G4TessellatedSolid* const tessellated)
551 {
552  const G4String& solid_name = tessellated->GetName();
553  const G4String& name = GenerateName(solid_name, tessellated);
554 
555  xercesc::DOMElement* tessellatedElement = NewElement("tessellated");
556  tessellatedElement->setAttributeNode(NewAttribute("name",name));
557  tessellatedElement->setAttributeNode(NewAttribute("aunit","deg"));
558  tessellatedElement->setAttributeNode(NewAttribute("lunit","mm"));
559  solElement->appendChild(tessellatedElement);
560 
561  std::map<G4ThreeVector, G4String, G4ThreeVectorCompare> vertexMap;
562 
563  const size_t NumFacets = tessellated->GetNumberOfFacets();
564  size_t NumVertex = 0;
565 
566  for (size_t i=0;i<NumFacets;i++)
567  {
568  const G4VFacet* facet = tessellated->GetFacet(i);
569  const size_t NumVertexPerFacet = facet->GetNumberOfVertices();
570 
571  G4String FacetTag;
572 
573  if (NumVertexPerFacet==3) { FacetTag="triangular"; } else
574  if (NumVertexPerFacet==4) { FacetTag="quadrangular"; }
575  else
576  {
577  G4Exception("G4GDMLWriteSolids::TessellatedWrite()", "InvalidSetup",
578  FatalException, "Facet should contain 3 or 4 vertices!");
579  }
580 
581  xercesc::DOMElement* facetElement = NewElement(FacetTag);
582  tessellatedElement->appendChild(facetElement);
583 
584  for (size_t j=0; j<NumVertexPerFacet; j++)
585  {
586  std::stringstream name_stream;
587  std::stringstream ref_stream;
588 
589  name_stream << "vertex" << (j+1);
590  ref_stream << solid_name << "_v" << NumVertex;
591 
592  const G4String& fname = name_stream.str(); // facet's tag variable
593  G4String ref = ref_stream.str(); // vertex tag to be associated
594 
595  // Now search for the existance of the current vertex in the
596  // map of cached vertices. If existing, do NOT store it as
597  // position in the GDML file, so avoiding duplication; otherwise
598  // cache it in the local map and add it as position in the
599  // "define" section of the GDML file.
600 
601  const G4ThreeVector& vertex = facet->GetVertex(j);
602 
603  if(vertexMap.find(vertex) != vertexMap.end()) // Vertex is cached
604  {
605  ref = vertexMap[vertex]; // Set the proper tag for it
606  }
607  else // Vertex not found
608  {
609  vertexMap.insert(std::make_pair(vertex,ref)); // Cache vertex and ...
610  AddPosition(ref, vertex); // ... add it to define section!
611  NumVertex++;
612  }
613 
614  // Now create association of the vertex with its facet
615  //
616  facetElement->setAttributeNode(NewAttribute(fname,ref));
617  }
618  }
619 }
620 
622 TetWrite(xercesc::DOMElement* solElement, const G4Tet* const tet)
623 {
624  const G4String& solid_name = tet->GetName();
625  const G4String& name = GenerateName(solid_name, tet);
626 
627  std::vector<G4ThreeVector> vertexList = tet->GetVertices();
628 
629  xercesc::DOMElement* tetElement = NewElement("tet");
630  tetElement->setAttributeNode(NewAttribute("name",name));
631  tetElement->setAttributeNode(NewAttribute("vertex1",solid_name+"_v1"));
632  tetElement->setAttributeNode(NewAttribute("vertex2",solid_name+"_v2"));
633  tetElement->setAttributeNode(NewAttribute("vertex3",solid_name+"_v3"));
634  tetElement->setAttributeNode(NewAttribute("vertex4",solid_name+"_v4"));
635  tetElement->setAttributeNode(NewAttribute("lunit","mm"));
636  solElement->appendChild(tetElement);
637 
638  AddPosition(solid_name+"_v1",vertexList[0]);
639  AddPosition(solid_name+"_v2",vertexList[1]);
640  AddPosition(solid_name+"_v3",vertexList[2]);
641  AddPosition(solid_name+"_v4",vertexList[3]);
642 }
643 
645 TorusWrite(xercesc::DOMElement* solElement, const G4Torus* const torus)
646 {
647  const G4String& name = GenerateName(torus->GetName(),torus);
648 
649  xercesc::DOMElement* torusElement = NewElement("torus");
650  torusElement->setAttributeNode(NewAttribute("name",name));
651  torusElement->setAttributeNode(NewAttribute("rmin",torus->GetRmin()/mm));
652  torusElement->setAttributeNode(NewAttribute("rmax",torus->GetRmax()/mm));
653  torusElement->setAttributeNode(NewAttribute("rtor",torus->GetRtor()/mm));
654  torusElement->
655  setAttributeNode(NewAttribute("startphi",torus->GetSPhi()/degree));
656  torusElement->
657  setAttributeNode(NewAttribute("deltaphi",torus->GetDPhi()/degree));
658  torusElement->setAttributeNode(NewAttribute("aunit","deg"));
659  torusElement->setAttributeNode(NewAttribute("lunit","mm"));
660  solElement->appendChild(torusElement);
661 }
662 
664 GenTrapWrite(xercesc::DOMElement* solElement,
665  const G4GenericTrap* const gtrap)
666 {
667  const G4String& name = GenerateName(gtrap->GetName(),gtrap);
668 
669  std::vector<G4TwoVector> vertices = gtrap->GetVertices();
670 
671  xercesc::DOMElement* gtrapElement = NewElement("arb8");
672  gtrapElement->setAttributeNode(NewAttribute("name",name));
673  gtrapElement->setAttributeNode(NewAttribute("dz",
674  gtrap->GetZHalfLength()/mm));
675  gtrapElement->setAttributeNode(NewAttribute("v1x", vertices[0].x()));
676  gtrapElement->setAttributeNode(NewAttribute("v1y", vertices[0].y()));
677  gtrapElement->setAttributeNode(NewAttribute("v2x", vertices[1].x()));
678  gtrapElement->setAttributeNode(NewAttribute("v2y", vertices[1].y()));
679  gtrapElement->setAttributeNode(NewAttribute("v3x", vertices[2].x()));
680  gtrapElement->setAttributeNode(NewAttribute("v3y", vertices[2].y()));
681  gtrapElement->setAttributeNode(NewAttribute("v4x", vertices[3].x()));
682  gtrapElement->setAttributeNode(NewAttribute("v4y", vertices[3].y()));
683  gtrapElement->setAttributeNode(NewAttribute("v5x", vertices[4].x()));
684  gtrapElement->setAttributeNode(NewAttribute("v5y", vertices[4].y()));
685  gtrapElement->setAttributeNode(NewAttribute("v6x", vertices[5].x()));
686  gtrapElement->setAttributeNode(NewAttribute("v6y", vertices[5].y()));
687  gtrapElement->setAttributeNode(NewAttribute("v7x", vertices[6].x()));
688  gtrapElement->setAttributeNode(NewAttribute("v7y", vertices[6].y()));
689  gtrapElement->setAttributeNode(NewAttribute("v8x", vertices[7].x()));
690  gtrapElement->setAttributeNode(NewAttribute("v8y", vertices[7].y()));
691  gtrapElement->setAttributeNode(NewAttribute("lunit","mm"));
692  solElement->appendChild(gtrapElement);
693 }
694 
696 TrapWrite(xercesc::DOMElement* solElement, const G4Trap* const trap)
697 {
698  const G4String& name = GenerateName(trap->GetName(),trap);
699 
700  const G4ThreeVector& simaxis = trap->GetSymAxis();
701  const G4double phi = simaxis.phi();
702  const G4double theta = simaxis.theta();
703  const G4double alpha1 = std::atan(trap->GetTanAlpha1());
704  const G4double alpha2 = std::atan(trap->GetTanAlpha2());
705 
706  xercesc::DOMElement* trapElement = NewElement("trap");
707  trapElement->setAttributeNode(NewAttribute("name",name));
708  trapElement->setAttributeNode(NewAttribute("z",
709  2.0*trap->GetZHalfLength()/mm));
710  trapElement->setAttributeNode(NewAttribute("theta",theta/degree));
711  trapElement->setAttributeNode(NewAttribute("phi",phi/degree));
712  trapElement->setAttributeNode(NewAttribute("y1",
713  2.0*trap->GetYHalfLength1()/mm));
714  trapElement->setAttributeNode(NewAttribute("x1",
715  2.0*trap->GetXHalfLength1()/mm));
716  trapElement->setAttributeNode(NewAttribute("x2",
717  2.0*trap->GetXHalfLength2()/mm));
718  trapElement->setAttributeNode(NewAttribute("alpha1",alpha1/degree));
719  trapElement->setAttributeNode(NewAttribute("y2",
720  2.0*trap->GetYHalfLength2()/mm));
721  trapElement->setAttributeNode(NewAttribute("x3",
722  2.0*trap->GetXHalfLength3()/mm));
723  trapElement->setAttributeNode(NewAttribute("x4",
724  2.0*trap->GetXHalfLength4()/mm));
725  trapElement->setAttributeNode(NewAttribute("alpha2",alpha2/degree));
726  trapElement->setAttributeNode(NewAttribute("aunit","deg"));
727  trapElement->setAttributeNode(NewAttribute("lunit","mm"));
728  solElement->appendChild(trapElement);
729 }
730 
732 TrdWrite(xercesc::DOMElement* solElement, const G4Trd* const trd)
733 {
734  const G4String& name = GenerateName(trd->GetName(),trd);
735 
736  xercesc::DOMElement* trdElement = NewElement("trd");
737  trdElement->setAttributeNode(NewAttribute("name",name));
738  trdElement->setAttributeNode(NewAttribute("x1",
739  2.0*trd->GetXHalfLength1()/mm));
740  trdElement->setAttributeNode(NewAttribute("x2",
741  2.0*trd->GetXHalfLength2()/mm));
742  trdElement->setAttributeNode(NewAttribute("y1",
743  2.0*trd->GetYHalfLength1()/mm));
744  trdElement->setAttributeNode(NewAttribute("y2",
745  2.0*trd->GetYHalfLength2()/mm));
746  trdElement->setAttributeNode(NewAttribute("z",
747  2.0*trd->GetZHalfLength()/mm));
748  trdElement->setAttributeNode(NewAttribute("lunit","mm"));
749  solElement->appendChild(trdElement);
750 }
751 
753 TubeWrite(xercesc::DOMElement* solElement, const G4Tubs* const tube)
754 {
755  const G4String& name = GenerateName(tube->GetName(),tube);
756 
757  xercesc::DOMElement* tubeElement = NewElement("tube");
758  tubeElement->setAttributeNode(NewAttribute("name",name));
759  tubeElement->setAttributeNode(NewAttribute("rmin",
760  tube->GetInnerRadius()/mm));
761  tubeElement->setAttributeNode(NewAttribute("rmax",
762  tube->GetOuterRadius()/mm));
763  tubeElement->setAttributeNode(NewAttribute("z",
764  2.0*tube->GetZHalfLength()/mm));
765  tubeElement->setAttributeNode(NewAttribute("startphi",
766  tube->GetStartPhiAngle()/degree));
767  tubeElement->setAttributeNode(NewAttribute("deltaphi",
768  tube->GetDeltaPhiAngle()/degree));
769  tubeElement->setAttributeNode(NewAttribute("aunit","deg"));
770  tubeElement->setAttributeNode(NewAttribute("lunit","mm"));
771  solElement->appendChild(tubeElement);
772 }
773 
775 CutTubeWrite(xercesc::DOMElement* solElement, const G4CutTubs* const cuttube)
776 {
777  const G4String& name = GenerateName(cuttube->GetName(),cuttube);
778 
779  xercesc::DOMElement* cuttubeElement = NewElement("cutTube");
780  cuttubeElement->setAttributeNode(NewAttribute("name",name));
781  cuttubeElement->setAttributeNode(NewAttribute("rmin",
782  cuttube->GetInnerRadius()/mm));
783  cuttubeElement->setAttributeNode(NewAttribute("rmax",
784  cuttube->GetOuterRadius()/mm));
785  cuttubeElement->setAttributeNode(NewAttribute("z",
786  2.0*cuttube->GetZHalfLength()/mm));
787  cuttubeElement->setAttributeNode(NewAttribute("startphi",
788  cuttube->GetStartPhiAngle()/degree));
789  cuttubeElement->setAttributeNode(NewAttribute("deltaphi",
790  cuttube->GetDeltaPhiAngle()/degree));
791  cuttubeElement->setAttributeNode(NewAttribute("lowX",
792  cuttube->GetLowNorm().getX()/mm));
793  cuttubeElement->setAttributeNode(NewAttribute("lowY",
794  cuttube->GetLowNorm().getY()/mm));
795  cuttubeElement->setAttributeNode(NewAttribute("lowZ",
796  cuttube->GetLowNorm().getZ()/mm));
797  cuttubeElement->setAttributeNode(NewAttribute("highX",
798  cuttube->GetHighNorm().getX()/mm));
799  cuttubeElement->setAttributeNode(NewAttribute("highY",
800  cuttube->GetHighNorm().getY()/mm));
801  cuttubeElement->setAttributeNode(NewAttribute("highZ",
802  cuttube->GetHighNorm().getZ()/mm));
803  cuttubeElement->setAttributeNode(NewAttribute("aunit","deg"));
804  cuttubeElement->setAttributeNode(NewAttribute("lunit","mm"));
805  solElement->appendChild(cuttubeElement);
806 }
807 
809 TwistedboxWrite(xercesc::DOMElement* solElement,
810  const G4TwistedBox* const twistedbox)
811 {
812  const G4String& name = GenerateName(twistedbox->GetName(),twistedbox);
813 
814  xercesc::DOMElement* twistedboxElement = NewElement("twistedbox");
815  twistedboxElement->setAttributeNode(NewAttribute("name",name));
816  twistedboxElement->setAttributeNode(NewAttribute("x",
817  2.0*twistedbox->GetXHalfLength()/mm));
818  twistedboxElement->setAttributeNode(NewAttribute("y",
819  2.0*twistedbox->GetYHalfLength()/mm));
820  twistedboxElement->setAttributeNode(NewAttribute("z",
821  2.0*twistedbox->GetZHalfLength()/mm));
822  twistedboxElement->setAttributeNode(NewAttribute("PhiTwist",
823  twistedbox->GetPhiTwist()/degree));
824  twistedboxElement->setAttributeNode(NewAttribute("aunit","deg"));
825  twistedboxElement->setAttributeNode(NewAttribute("lunit","mm"));
826  solElement->appendChild(twistedboxElement);
827 }
828 
830 TwistedtrapWrite(xercesc::DOMElement* solElement,
831  const G4TwistedTrap* const twistedtrap)
832 {
833  const G4String& name = GenerateName(twistedtrap->GetName(),twistedtrap);
834 
835  xercesc::DOMElement* twistedtrapElement = NewElement("twistedtrap");
836  twistedtrapElement->setAttributeNode(NewAttribute("name",name));
837  twistedtrapElement->setAttributeNode(NewAttribute("y1",
838  2.0*twistedtrap->GetY1HalfLength()/mm));
839  twistedtrapElement->setAttributeNode(NewAttribute("x1",
840  2.0*twistedtrap->GetX1HalfLength()/mm));
841  twistedtrapElement->setAttributeNode(NewAttribute("x2",
842  2.0*twistedtrap->GetX2HalfLength()/mm));
843  twistedtrapElement->setAttributeNode(NewAttribute("y2",
844  2.0*twistedtrap->GetY2HalfLength()/mm));
845  twistedtrapElement->setAttributeNode(NewAttribute("x3",
846  2.0*twistedtrap->GetX3HalfLength()/mm));
847  twistedtrapElement->setAttributeNode(NewAttribute("x4",
848  2.0*twistedtrap->GetX4HalfLength()/mm));
849  twistedtrapElement->setAttributeNode(NewAttribute("z",
850  2.0*twistedtrap->GetZHalfLength()/mm));
851  twistedtrapElement->setAttributeNode(NewAttribute("Alph",
852  twistedtrap->GetTiltAngleAlpha()/degree));
853  twistedtrapElement->setAttributeNode(NewAttribute("Theta",
854  twistedtrap->GetPolarAngleTheta()/degree));
855  twistedtrapElement->setAttributeNode(NewAttribute("Phi",
856  twistedtrap->GetAzimuthalAnglePhi()/degree));
857  twistedtrapElement->setAttributeNode(NewAttribute("PhiTwist",
858  twistedtrap->GetPhiTwist()/degree));
859  twistedtrapElement->setAttributeNode(NewAttribute("aunit","deg"));
860  twistedtrapElement->setAttributeNode(NewAttribute("lunit","mm"));
861 
862  solElement->appendChild(twistedtrapElement);
863 }
864 
866 TwistedtrdWrite(xercesc::DOMElement* solElement,
867  const G4TwistedTrd* const twistedtrd)
868 {
869  const G4String& name = GenerateName(twistedtrd->GetName(),twistedtrd);
870 
871  xercesc::DOMElement* twistedtrdElement = NewElement("twistedtrd");
872  twistedtrdElement->setAttributeNode(NewAttribute("name",name));
873  twistedtrdElement->setAttributeNode(NewAttribute("x1",
874  2.0*twistedtrd->GetX1HalfLength()/mm));
875  twistedtrdElement->setAttributeNode(NewAttribute("x2",
876  2.0*twistedtrd->GetX2HalfLength()/mm));
877  twistedtrdElement->setAttributeNode(NewAttribute("y1",
878  2.0*twistedtrd->GetY1HalfLength()/mm));
879  twistedtrdElement->setAttributeNode(NewAttribute("y2",
880  2.0*twistedtrd->GetY2HalfLength()/mm));
881  twistedtrdElement->setAttributeNode(NewAttribute("z",
882  2.0*twistedtrd->GetZHalfLength()/mm));
883  twistedtrdElement->setAttributeNode(NewAttribute("PhiTwist",
884  twistedtrd->GetPhiTwist()/degree));
885  twistedtrdElement->setAttributeNode(NewAttribute("aunit","deg"));
886  twistedtrdElement->setAttributeNode(NewAttribute("lunit","mm"));
887  solElement->appendChild(twistedtrdElement);
888 }
889 
891 TwistedtubsWrite(xercesc::DOMElement* solElement,
892  const G4TwistedTubs* const twistedtubs)
893 {
894  const G4String& name = GenerateName(twistedtubs->GetName(),twistedtubs);
895 
896  xercesc::DOMElement* twistedtubsElement = NewElement("twistedtubs");
897  twistedtubsElement->setAttributeNode(NewAttribute("name",name));
898  twistedtubsElement->setAttributeNode(NewAttribute("twistedangle",
899  twistedtubs->GetPhiTwist()/degree));
900  twistedtubsElement->setAttributeNode(NewAttribute("endinnerrad",
901  twistedtubs->GetInnerRadius()/mm));
902  twistedtubsElement->setAttributeNode(NewAttribute("endouterrad",
903  twistedtubs->GetOuterRadius()/mm));
904  twistedtubsElement->setAttributeNode(NewAttribute("zlen",
905  2.0*twistedtubs->GetZHalfLength()/mm));
906  twistedtubsElement->setAttributeNode(NewAttribute("phi",
907  twistedtubs->GetDPhi()/degree));
908  twistedtubsElement->setAttributeNode(NewAttribute("aunit","deg"));
909  twistedtubsElement->setAttributeNode(NewAttribute("lunit","mm"));
910  solElement->appendChild(twistedtubsElement);
911 }
912 
914 ZplaneWrite(xercesc::DOMElement* element, const G4double& z,
915  const G4double& rmin, const G4double& rmax)
916 {
917  xercesc::DOMElement* zplaneElement = NewElement("zplane");
918  zplaneElement->setAttributeNode(NewAttribute("z",z/mm));
919  zplaneElement->setAttributeNode(NewAttribute("rmin",rmin/mm));
920  zplaneElement->setAttributeNode(NewAttribute("rmax",rmax/mm));
921  element->appendChild(zplaneElement);
922 }
923 
925 RZPointWrite(xercesc::DOMElement* element, const G4double& r,
926  const G4double& z)
927 {
928  xercesc::DOMElement* rzpointElement = NewElement("rzpoint");
929  rzpointElement->setAttributeNode(NewAttribute("r",r/mm));
930  rzpointElement->setAttributeNode(NewAttribute("z",z/mm));
931  element->appendChild(rzpointElement);
932 }
933 
935 OpticalSurfaceWrite(xercesc::DOMElement* solElement,
936  const G4OpticalSurface* const surf)
937 {
938  xercesc::DOMElement* optElement = NewElement("opticalsurface");
939  G4OpticalSurfaceModel smodel = surf->GetModel();
940  G4double sval = (smodel==glisur) ? surf->GetPolish() : surf->GetSigmaAlpha();
941 
942  optElement->setAttributeNode(NewAttribute("name", surf->GetName()));
943  optElement->setAttributeNode(NewAttribute("model", smodel));
944  optElement->setAttributeNode(NewAttribute("finish", surf->GetFinish()));
945  optElement->setAttributeNode(NewAttribute("type", surf->GetType()));
946  optElement->setAttributeNode(NewAttribute("value", sval));
947 
948  solElement->appendChild(optElement);
949 }
950 
951 void G4GDMLWriteSolids::SolidsWrite(xercesc::DOMElement* gdmlElement)
952 {
953  G4cout << "G4GDML: Writing solids..." << G4endl;
954 
955  solidsElement = NewElement("solids");
956  gdmlElement->appendChild(solidsElement);
957 
958  solidList.clear();
959 }
960 
961 void G4GDMLWriteSolids::AddSolid(const G4VSolid* const solidPtr)
962 {
963  for (size_t i=0; i<solidList.size(); i++) // Check if solid is
964  { // already in the list!
965  if (solidList[i] == solidPtr) { return; }
966  }
967 
968  solidList.push_back(solidPtr);
969 
970  if (const G4BooleanSolid* const booleanPtr
971  = dynamic_cast<const G4BooleanSolid*>(solidPtr))
972  { BooleanWrite(solidsElement,booleanPtr); } else
973  if (const G4Box* const boxPtr
974  = dynamic_cast<const G4Box*>(solidPtr))
975  { BoxWrite(solidsElement,boxPtr); } else
976  if (const G4Cons* const conePtr
977  = dynamic_cast<const G4Cons*>(solidPtr))
978  { ConeWrite(solidsElement,conePtr); } else
979  if (const G4EllipticalCone* const elconePtr
980  = dynamic_cast<const G4EllipticalCone*>(solidPtr))
981  { ElconeWrite(solidsElement,elconePtr); } else
982  if (const G4Ellipsoid* const ellipsoidPtr
983  = dynamic_cast<const G4Ellipsoid*>(solidPtr))
984  { EllipsoidWrite(solidsElement,ellipsoidPtr); } else
985  if (const G4EllipticalTube* const eltubePtr
986  = dynamic_cast<const G4EllipticalTube*>(solidPtr))
987  { EltubeWrite(solidsElement,eltubePtr); } else
988  if (const G4ExtrudedSolid* const xtruPtr
989  = dynamic_cast<const G4ExtrudedSolid*>(solidPtr))
990  { XtruWrite(solidsElement,xtruPtr); } else
991  if (const G4Hype* const hypePtr
992  = dynamic_cast<const G4Hype*>(solidPtr))
993  { HypeWrite(solidsElement,hypePtr); } else
994  if (const G4Orb* const orbPtr
995  = dynamic_cast<const G4Orb*>(solidPtr))
996  { OrbWrite(solidsElement,orbPtr); } else
997  if (const G4Para* const paraPtr
998  = dynamic_cast<const G4Para*>(solidPtr))
999  { ParaWrite(solidsElement,paraPtr); } else
1000  if (const G4Paraboloid* const paraboloidPtr
1001  = dynamic_cast<const G4Paraboloid*>(solidPtr))
1002  { ParaboloidWrite(solidsElement,paraboloidPtr); } else
1003  if (const G4Polycone* const polyconePtr
1004  = dynamic_cast<const G4Polycone*>(solidPtr))
1005  { PolyconeWrite(solidsElement,polyconePtr); } else
1006  if (const G4GenericPolycone* const genpolyconePtr
1007  = dynamic_cast<const G4GenericPolycone*>(solidPtr))
1008  { GenericPolyconeWrite(solidsElement,genpolyconePtr); } else
1009  if (const G4Polyhedra* const polyhedraPtr
1010  = dynamic_cast<const G4Polyhedra*>(solidPtr))
1011  { PolyhedraWrite(solidsElement,polyhedraPtr); } else
1012  if (const G4Sphere* const spherePtr
1013  = dynamic_cast<const G4Sphere*>(solidPtr))
1014  { SphereWrite(solidsElement,spherePtr); } else
1015  if (const G4TessellatedSolid* const tessellatedPtr
1016  = dynamic_cast<const G4TessellatedSolid*>(solidPtr))
1017  { TessellatedWrite(solidsElement,tessellatedPtr); } else
1018  if (const G4Tet* const tetPtr
1019  = dynamic_cast<const G4Tet*>(solidPtr))
1020  { TetWrite(solidsElement,tetPtr); } else
1021  if (const G4Torus* const torusPtr
1022  = dynamic_cast<const G4Torus*>(solidPtr))
1023  { TorusWrite(solidsElement,torusPtr); } else
1024  if (const G4GenericTrap* const gtrapPtr
1025  = dynamic_cast<const G4GenericTrap*>(solidPtr))
1026  { GenTrapWrite(solidsElement,gtrapPtr); } else
1027  if (const G4Trap* const trapPtr
1028  = dynamic_cast<const G4Trap*>(solidPtr))
1029  { TrapWrite(solidsElement,trapPtr); } else
1030  if (const G4Trd* const trdPtr
1031  = dynamic_cast<const G4Trd*>(solidPtr))
1032  { TrdWrite(solidsElement,trdPtr); } else
1033  if (const G4Tubs* const tubePtr
1034  = dynamic_cast<const G4Tubs*>(solidPtr))
1035  { TubeWrite(solidsElement,tubePtr); } else
1036  if (const G4CutTubs* const cuttubePtr
1037  = dynamic_cast<const G4CutTubs*>(solidPtr))
1038  { CutTubeWrite(solidsElement,cuttubePtr); } else
1039  if (const G4TwistedBox* const twistedboxPtr
1040  = dynamic_cast<const G4TwistedBox*>(solidPtr))
1041  { TwistedboxWrite(solidsElement,twistedboxPtr); } else
1042  if (const G4TwistedTrap* const twistedtrapPtr
1043  = dynamic_cast<const G4TwistedTrap*>(solidPtr))
1044  { TwistedtrapWrite(solidsElement,twistedtrapPtr); } else
1045  if (const G4TwistedTrd* const twistedtrdPtr
1046  = dynamic_cast<const G4TwistedTrd*>(solidPtr))
1047  { TwistedtrdWrite(solidsElement,twistedtrdPtr); } else
1048  if (const G4TwistedTubs* const twistedtubsPtr
1049  = dynamic_cast<const G4TwistedTubs*>(solidPtr))
1050  { TwistedtubsWrite(solidsElement,twistedtubsPtr); }
1051  else
1052  {
1053  G4String error_msg = "Unknown solid: " + solidPtr->GetName()
1054  + "; Type: " + solidPtr->GetEntityType();
1055  G4Exception("G4GDMLWriteSolids::AddSolid()", "WriteError",
1056  FatalException, error_msg);
1057  }
1058 }
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
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
std::vector< G4ThreeVector > GetVertices() const
Definition: G4Tet.cc:782
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
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
void AddPosition(const G4String &name, const G4ThreeVector &pos)
void GenericPolyconeWrite(xercesc::DOMElement *, const G4GenericPolycone *const)
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)
G4double GetY2HalfLength() const
std::vector< const G4VSolid * > solidList
G4double GetDeltaPhiAngle() const
G4double GetYHalfLength() const