19#include "BDSBeamPipeFactoryRaceTrack.hh"
20#include "BDSBeamPipeFactoryPoints.hh"
24#include "G4TwoVector.hh"
28BDSBeamPipeFactoryRaceTrack::BDSBeamPipeFactoryRaceTrack()
31void BDSBeamPipeFactoryRaceTrack::GenerateRaceTrack(std::vector<G4TwoVector>& vec,
37 G4int pointsPerCurve = pointsPerTwoPi / 4;
38 AppendAngle(vec, 0, 0.5*CLHEP::pi, r, pointsPerCurve, x, y);
39 AppendPoint(vec, x+r, y);
40 AppendAngle(vec, 0.5*CLHEP::pi, CLHEP::pi, r, pointsPerCurve, x, -y);
41 AppendPoint(vec, x, -y-r);
42 AppendAngle(vec, CLHEP::pi, (3./2.)*CLHEP::pi, r, pointsPerCurve, -x, -y);
43 AppendPoint(vec, -x-r, -y);
44 AppendAngle(vec, (3./2)*CLHEP::pi, CLHEP::twopi, r, pointsPerCurve, -x, y);
45 AppendPoint(vec, -x, y+r);
53 G4double beamPipeThickness,
56 GenerateRaceTrack(
vacuumEdge, aper1, aper2, aper3, pointsPerTwoPi);
60 GenerateRaceTrack(
beamPipeInnerEdge, bpInner1, bpInner2, bpInner3, pointsPerTwoPi);
61 G4double bpOuter1 = bpInner1 + beamPipeThickness;
62 G4double bpOuter2 = bpInner2 + beamPipeThickness;
63 G4double bpOuter3 = bpInner3 + beamPipeThickness;
64 GenerateRaceTrack(
beamPipeOuterEdge, bpOuter1, bpOuter2, bpOuter3, pointsPerTwoPi);
68 GenerateRaceTrack(
containerEdge, cont1, cont2, cont3, pointsPerTwoPi);
82 G4double beamPipeThickness)
84 G4double result = std::hypot(aper1,aper2) + aper3 + beamPipeThickness;
87 G4cout << __METHOD_NAME__ <<
"intersection radius: " << result << G4endl;
std::vector< G4TwoVector > containerSubtractionEdge
Vector of x,y coordinates for the container subtraction volume.
std::vector< G4TwoVector > beamPipeInnerEdge
Vector of x,y coordinates for beam pipe inner edge.
G4double extentY
Extents prepared by GeneratePoints function as only it knows the extents.
G4double extentX
Extents prepared by GeneratePoints function as only it knows the extents.
std::vector< G4TwoVector > vacuumEdge
Vector of x,y coordinates for vacuum extruded solid edge.
void AppendAngle(std::vector< G4TwoVector > &vec, G4double startAngle, G4double finishAngle, G4double radius, G4int nPoints=10, G4double xOffset=0, G4double yOffset=0)
std::vector< G4TwoVector > containerEdge
Vector of x,y coordinates for the container volume.
std::vector< G4TwoVector > beamPipeOuterEdge
Vector of x,y coordinates for beam pipe outer edge.
virtual void GeneratePoints(G4double aper1, G4double aper2, G4double aper3, G4double aper4, G4double beamPipeThickness, G4int pointsPerTwoPi=40)
virtual G4double CalculateIntersectionRadius(G4double aper1, G4double aper2, G4double aper3, G4double aper4, G4double beamPipeThickness)
Calculate the radius of the solid used for intersection for angled faces.
G4double lengthSafetyLarge
Cache of global constants variable.