19#include "BDSBeamPipeType.hh"
21#include "BDSException.hh"
22#include "BDSUtilities.hh"
33 new std::map<BDSBeamPipeType, std::string> ({
34 {BDSBeamPipeType::circular,
"circular"},
35 {BDSBeamPipeType::elliptical,
"elliptical"},
36 {BDSBeamPipeType::lhc,
"lhc"},
37 {BDSBeamPipeType::lhcdetailed,
"lhcdetailed"},
38 {BDSBeamPipeType::rectangular,
"rectangular"},
39 {BDSBeamPipeType::rectellipse,
"rectellipse"},
40 {BDSBeamPipeType::racetrack,
"racetrack"},
41 {BDSBeamPipeType::octagonal,
"octagonal"},
42 {BDSBeamPipeType::circularvacuum,
"circularvacuum"},
43 {BDSBeamPipeType::clicpcl,
"clicpcl"},
44 {BDSBeamPipeType::rhombus,
"rhombus"}
49 std::map<G4String, BDSBeamPipeType> types;
50 types[
"circular"] = BDSBeamPipeType::circular;
51 types[
"elliptical"] = BDSBeamPipeType::elliptical;
52 types[
"rectangular"] = BDSBeamPipeType::rectangular;
53 types[
"lhc"] = BDSBeamPipeType::lhc;
54 types[
"lhcscreen"] = BDSBeamPipeType::lhc;
55 types[
"lhcdetailed"] = BDSBeamPipeType::lhcdetailed;
56 types[
"rectellipse"] = BDSBeamPipeType::rectellipse;
57 types[
"racetrack"] = BDSBeamPipeType::racetrack;
58 types[
"octagonal"] = BDSBeamPipeType::octagonal;
59 types[
"circularvacuum"] = BDSBeamPipeType::circularvacuum;
60 types[
"clicpcl"] = BDSBeamPipeType::clicpcl;
61 types[
"pointsfile"] = BDSBeamPipeType::pointsfile;
62 types[
"rhombus"] = BDSBeamPipeType::rhombus;
69 {
return BDSBeamPipeType::pointsfile;}
71 auto result = types.find(apertureType);
72 if (result == types.end())
74 G4String msg =
"\"" + apertureType +
"\" is not a valid apertureType\n";
75 msg +=
"Available geometry types are:\n";
76 for (
const auto& it : types)
77 {msg +=
"\"" + it.first +
"\"\n";}
82 G4cout << __METHOD_NAME__ <<
"determined aperture type to be " << result->second << G4endl;
84 return result->second;
General exception with possible name of object and message.
static std::map< BDSTypeSafeEnum< beampipetypes_def, int >, std::string > * dictionary
G4bool StrContains(const G4String &str, const G4String &test)
Utility function to simplify lots of syntax changes for pedantic g4 changes.
G4String LowerCase(const G4String &str)
Utility function to simplify lots of syntax changes for pedantic g4 changes.
BDSBeamPipeType DetermineBeamPipeType(G4String apertureType)
Function that gives corresponding enum value for string (case-insensitive).