19#ifndef BDSBEAMPIPEFACTORYELLIPTICAL_H
20#define BDSBEAMPIPEFACTORYELLIPTICAL_H
22#include "BDSBeamPipeFactoryBase.hh"
23#include "BDSBeamPipe.hh"
43 G4Material* vacuumMaterialIn =
nullptr,
44 G4double beamPipeThicknessIn = 0,
45 G4Material* beamPipeMaterialIn =
nullptr,
46 const G4String& pointsFileIn =
"",
47 const G4String& pointsUnitIn =
"");
51 const G4ThreeVector& inputFaceNormalIn,
52 const G4ThreeVector& outputFaceNormalIn,
57 G4Material* vacuumMaterialIn =
nullptr,
58 G4double beamPipeThicknessIn = 0,
59 G4Material* beamPipeMaterialIn =
nullptr,
60 const G4String& pointsFileIn =
"",
61 const G4String& pointsUnitIn =
"");
69 G4Material* vacuumMaterialIn,
70 G4Material* beamPipeMaterialIn,
72 G4double containerRadiusX,
73 G4double containerRadiusY);
81 G4double beamPipeThicknessIn,
82 const G4ThreeVector& inputfaceIn,
83 const G4ThreeVector& outputfaceIn,
84 G4double& containerRadiusX,
85 G4double& containerRadiusY);
Abstract base class for beampipe factory classes.
Factory for elliptical beam pipes.
void CreateGeneralAngledSolids(const G4String &nameIn, G4double lengthIn, G4double aper1In, G4double aper2In, G4double beamPipeThicknessIn, const G4ThreeVector &inputfaceIn, const G4ThreeVector &outputfaceIn, G4double &containerRadiusX, G4double &containerRadiusY)
BDSBeamPipe * CommonFinalConstruction(const G4String &nameIn, G4Material *vacuumMaterialIn, G4Material *beamPipeMaterialIn, G4double lengthIn, G4double containerRadiusX, G4double containerRadiusY)
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
A holder class for a piece of beam pipe geometry.