BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
Loading...
Searching...
No Matches
BDSModulatorType.cc
1/*
2Beam Delivery Simulation (BDSIM) Copyright (C) Royal Holloway,
3University of London 2001 - 2023.
4
5This file is part of BDSIM.
6
7BDSIM is free software: you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published
9by the Free Software Foundation version 3 of the License.
10
11BDSIM is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with BDSIM. If not, see <http://www.gnu.org/licenses/>.
18*/
19#include "BDSDebug.hh"
20#include "BDSException.hh"
21#include "BDSModulatorType.hh"
22#include "BDSUtilities.hh"
23
24#include "G4String.hh"
25
26#include <map>
27#include <string>
28
29// dictionary for BDSModulatorType for reflexivity
30template<>
31std::map<BDSModulatorType, std::string>* BDSModulatorType::dictionary =
32 new std::map<BDSModulatorType, std::string> ({
33 {BDSModulatorType::none, "none"},
34 {BDSModulatorType::sint, "sint"},
35 {BDSModulatorType::singlobalt, "singlobalt"},
36 {BDSModulatorType::tophatt, "tophatt"}
37 });
38
40{
41 std::map<G4String, BDSModulatorType> types;
42 types["none"] = BDSModulatorType::none;
43 types["sint"] = BDSModulatorType::sint;
44 types["singlobalt"] = BDSModulatorType::singlobalt;
45 types["tophatt"] = BDSModulatorType::tophatt;
46
47 mType = BDS::LowerCase(mType);
48
49 auto result = types.find(mType);
50 if (result == types.end())
51 {// it's not a valid key
52 G4String msg = "\"" + mType + "\" is not a valid modulator type\n";
53 msg += "Available modulator types are:\n";
54 for (const auto& it : types)
55 {msg += "\"" + it.first + "\"\n";}
56 throw BDSException(__METHOD_NAME__, msg);
57 }
58
59#ifdef BDSDEBUG
60 G4cout << __METHOD_NAME__ << "determined modulator type to be " << result->second << G4endl;
61#endif
62 return result->second;
63}
General exception with possible name of object and message.
Definition: BDSException.hh:35
static std::map< BDSTypeSafeEnum< modulatortypes_def, int >, std::string > * dictionary
BDSModulatorType DetermineModulatorType(G4String mType)
Function that gives corresponding enum value for string (case-insensitive)
G4String LowerCase(const G4String &str)
Utility function to simplify lots of syntax changes for pedantic g4 changes.