BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
|
Factory for rectellipse aperture model beampipes. More...
#include <BDSBeamPipeFactoryRectEllipse.hh>
Public Member Functions | |
virtual BDSBeamPipe * | CreateBeamPipe (const G4String &nameIn, G4double lengthIn, G4double aper1=0, G4double aper2=0, G4double aper3=0, G4double aper4=0, G4Material *vacuumMaterialIn=nullptr, G4double beamPipeThicknessIn=0, G4Material *beamPipeMaterialIn=nullptr, const G4String &pointsFileIn="", const G4String &pointsUnitIn="") |
create a flat ended beampipe | |
virtual BDSBeamPipe * | CreateBeamPipe (const G4String &nameIn, G4double lengthIn, const G4ThreeVector &inputFaceNormalIn, const G4ThreeVector &outputFaceNormalIn, G4double aper1=0, G4double aper2=0, G4double aper3=0, G4double aper4=0, G4Material *vacuumMaterialIn=nullptr, G4double beamPipeThicknessIn=0, G4Material *beamPipeMaterialIn=nullptr, const G4String &pointsFileIn="", const G4String &pointsUnitIn="") |
![]() | |
virtual BDSBeamPipe * | CreateBeamPipe (const G4String &nameIn, G4double lengthIn, G4double aper1=0, G4double aper2=0, G4double aper3=0, G4double aper4=0, G4Material *vacuumMaterialIn=nullptr, G4double beamPipeThicknessIn=0, G4Material *beamPipeMaterialIn=nullptr, const G4String &pointsFileIn="", const G4String &pointsUnitIn="")=0 |
create a flat ended beampipe | |
virtual BDSBeamPipe * | CreateBeamPipe (const G4String &nameIn, G4double lengthIn, const G4ThreeVector &inputFaceNormalIn, const G4ThreeVector &outputFaceNormalIn, G4double aper1=0, G4double aper2=0, G4double aper3=0, G4double aper4=0, G4Material *vacuumMaterialIn=nullptr, G4double beamPipeThicknessIn=0, G4Material *beamPipeMaterialIn=nullptr, const G4String &pointsFileIn="", const G4String &pointsUnitIn="")=0 |
virtual | ~BDSBeamPipeFactoryBase () |
Virtual base destructor. | |
![]() | |
virtual void | FactoryBaseCleanUp () |
Empty containers for next use - factories are never deleted so can't rely on scope. | |
Private Member Functions | |
BDSBeamPipe * | CommonFinalConstruction (const G4String &nameIn, G4Material *vacuumMaterialIn, G4Material *beamPipeMaterialIn, G4double lengthIn, G4double widthIn, G4double heightIn) |
void | CreateGeneralAngledSolids (const G4String &nameIn, G4double lengthIn, G4double aper1In, G4double aper2In, G4double aper3In, G4double aper4In, G4double beamPipeThicknessIn, const G4ThreeVector &inputfaceIn, const G4ThreeVector &outputfaceIn) |
void | CreateContainerSubtractionSolid (const G4String &nameIn, G4double &lengthIn, G4double &beamPipeThicknessIn, G4double &aper1In, G4double &aper2In, G4double &aper3In, G4double &aper4In) |
Additional Inherited Members | |
![]() | |
BDSBeamPipeFactoryBase () | |
base constructor | |
void | CleanUpBase () |
virtual void | CleanUp () |
void | CommonConstruction (const G4String &nameIn, G4Material *vacuumMaterialIn, G4Material *beamPipeMaterialIn, G4double length) |
finalise beampipe construction | |
BDSBeamPipe * | BuildBeamPipeAndRegisterVolumes (BDSExtent extent, G4double containerRadius, G4bool containerIsCircular=false) |
build beampipe and register logical volumes | |
virtual void | BuildLogicalVolumes (const G4String &nameIn, G4Material *vacuumMaterialIn, G4Material *beamPipeMaterialIn) |
build logical volumes | |
virtual void | SetVisAttributes (G4Material *beamPipeMaterialIn, G4Material *vacuumMaterialIn) |
Set visual attributes. | |
virtual void | SetUserLimits (G4double length) |
Set user limits. | |
virtual void | PlaceComponents (const G4String &nameIn) |
Place volumes. | |
![]() | |
static void | CheckAngledVolumeCanBeBuilt (G4double length, const G4ThreeVector &inputfaceAngle, const G4ThreeVector &outputfaceAngle, G4double horizontalWidth, const G4String &name) |
check if a beam pipe volume with angled faces can be constructed | |
![]() | |
G4bool | sensitiveBeamPipe |
Whether the beam pipe will record energy deposition. | |
G4bool | sensitiveVacuum |
Whether the vacuum will record any energy deposition. | |
G4bool | storeApertureImpacts |
Whether to store aperture impacts. | |
G4VSolid * | vacuumSolid |
G4VSolid * | beamPipeSolid |
G4VSolid * | containerSolid |
G4VSolid * | containerSubtractionSolid |
Longer (in length) version of container solid for unambiguous subtraction. | |
G4LogicalVolume * | vacuumLV |
G4LogicalVolume * | beamPipeLV |
G4LogicalVolume * | containerLV |
G4PVPlacement * | vacuumPV |
G4PVPlacement * | beamPipePV |
G4ThreeVector | inputFaceNormal |
For recording the face normals in the finished pipe component. | |
G4ThreeVector | outputFaceNormal |
For recording the face normals in the finished pipe component. | |
![]() | |
std::set< G4LogicalVolume * > | allLogicalVolumes |
std::set< G4VPhysicalVolume * > | allPhysicalVolumes |
std::set< G4RotationMatrix * > | allRotationMatrices |
std::set< G4UserLimits * > | allUserLimits |
std::set< G4VSolid * > | allSolids |
std::set< G4VisAttributes * > | allVisAttributes |
G4double | lengthSafety |
Cache of global constants variable. | |
G4double | lengthSafetyLarge |
Cache of global constants variable. | |
G4bool | checkOverlaps |
Cache of global constants variable. | |
G4bool | visDebug |
Cache of global constants variable. | |
G4int | nSegmentsPerCircle |
Cache of global constants variable. | |
G4VisAttributes * | containerVisAttr |
Cache of global constants variable. | |
G4UserLimits * | defaultUserLimits |
Cache of global constants variable. | |
Factory for rectellipse aperture model beampipes.
This is the overlap of (boolean AND) a rectangle and an ellipse transversely. This factory is similar to the simple LHC factory and uses the intersection of an elliptical tube and a box. This method produces a solid shape, so to achieve a pipe, a smaller duplicate intersection solid is made for subtraction from the outer one. To achieve the angled faces, G4CutTubs is used and the rectangular box is made longer so the first intersection gives the angled face from the easier G4CutTubs primitive.
This factory requires four aperture parameters. Aper1,2 are the horizontal and vertical half widths of the rectangle respectively, and aper3,4 are the horizontal and vertical semi-axes of the ellipse. Note, will aper1,2 should be < aper1,2 otherwise an elliptical tube will be more efficient.
Definition at line 45 of file BDSBeamPipeFactoryRectEllipse.hh.
BDSBeamPipeFactoryRectEllipse::BDSBeamPipeFactoryRectEllipse | ( | ) |
Definition at line 45 of file BDSBeamPipeFactoryRectEllipse.cc.
|
inlinevirtual |
Definition at line 49 of file BDSBeamPipeFactoryRectEllipse.hh.
|
private |
only the solids are unique, once we have those, the logical volumes and placement in the container are the same. group all this functionality together
Definition at line 210 of file BDSBeamPipeFactoryRectEllipse.cc.
References BDSBeamPipeFactoryBase::BuildBeamPipeAndRegisterVolumes(), and BDSBeamPipeFactoryBase::CommonConstruction().
Referenced by CreateBeamPipe().
|
virtual |
Create a beam pipe with angled faces as described by unit normal vectors. The input face normal vector must have a negative z component and the output face a positive z component.
Implements BDSBeamPipeFactoryBase.
Definition at line 164 of file BDSBeamPipeFactoryRectEllipse.cc.
References CommonFinalConstruction(), BDSBeamPipeFactoryElliptical::CreateBeamPipe(), CreateGeneralAngledSolids(), BDSBeamPipeFactoryBase::inputFaceNormal, BDSFactoryBase::lengthSafetyLarge, and BDSBeamPipeFactoryBase::outputFaceNormal.
|
virtual |
create a flat ended beampipe
Implements BDSBeamPipeFactoryBase.
Definition at line 48 of file BDSBeamPipeFactoryRectEllipse.cc.
References CommonFinalConstruction(), BDSBeamPipeFactoryElliptical::CreateBeamPipe(), BDSFactoryBase::lengthSafety, and BDSFactoryBase::lengthSafetyLarge.
|
private |
Definition at line 367 of file BDSBeamPipeFactoryRectEllipse.cc.
|
private |
the angled ones have degeneracy in the geant4 solids they used so we can avoid code duplication by grouping common construction tasks
Definition at line 229 of file BDSBeamPipeFactoryRectEllipse.cc.
References BDS::CalculateSafeAngledVolumeLength(), BDSBeamPipeFactoryBase::CheckAngledVolumeCanBeBuilt(), BDSFactoryBase::lengthSafety, and BDSFactoryBase::lengthSafetyLarge.
Referenced by CreateBeamPipe().