20#include "BDSException.hh"
21#include "BDSScorerType.hh"
22#include "BDSUtilities.hh"
33 new std::map<BDSScorerType, std::string> ({
34 {BDSScorerType::cellcharge,
"cellcharge"},
35 {BDSScorerType::cellcharge3d,
"cellcharge3d"},
36 {BDSScorerType::depositeddose,
"depositeddose"},
37 {BDSScorerType::depositeddose3d,
"depositeddose3d"},
38 {BDSScorerType::depositedenergy,
"depositedenergy"},
39 {BDSScorerType::depositedenergyblm,
"depositedenergyblm"},
40 {BDSScorerType::depositedenergy,
"depositedenergy3d"},
41 {BDSScorerType::population,
"population"},
42 {BDSScorerType::population3d,
"population3d"},
43 {BDSScorerType::populationscaled,
"populationscaled"},
44 {BDSScorerType::cellflux,
"cellflux"},
45 {BDSScorerType::cellflux3d,
"cellflux3d"},
46 {BDSScorerType::cellfluxscaled,
"cellfluxscaled"},
47 {BDSScorerType::cellfluxscaled3d,
"cellfluxscaled3d"},
48 {BDSScorerType::cellfluxscaledperparticle,
"cellfluxscaledperparticle"},
49 {BDSScorerType::cellfluxscaledperparticle3d,
"cellfluxscaledperparticle3d"},
50 {BDSScorerType::cellflux4d,
"cellflux4d"}
55 std::map<G4String, BDSScorerType> types;
56 types[
"cellcharge"] = BDSScorerType::cellcharge;
57 types[
"cellcharge3d"] = BDSScorerType::cellcharge3d;
58 types[
"depositeddose"] = BDSScorerType::depositeddose;
59 types[
"depositeddose3d"] = BDSScorerType::depositeddose3d;
60 types[
"depositedenergy"] = BDSScorerType::depositedenergy;
61 types[
"depostiedenergyblm"] = BDSScorerType::depositedenergyblm;
62 types[
"depositedenergy3d"] = BDSScorerType::depositedenergy3d;
63 types[
"population"] = BDSScorerType::population;
64 types[
"population3d"] = BDSScorerType::population3d;
65 types[
"populationscaled"] = BDSScorerType::populationscaled;
66 types[
"cellflux"] = BDSScorerType::cellflux;
67 types[
"cellflux3d"] = BDSScorerType::cellflux3d;
68 types[
"cellfluxscaled"] = BDSScorerType::cellfluxscaled;
69 types[
"cellfluxscaled3d"] = BDSScorerType::cellfluxscaled3d;
70 types[
"cellfluxscaledperparticle"] = BDSScorerType::cellfluxscaledperparticle;
71 types[
"cellfluxscaledperparticle3d"] = BDSScorerType::cellfluxscaledperparticle3d;
72 types[
"cellflux4d"] = BDSScorerType::cellflux4d;
76 auto result = types.find(scorerType);
77 if (result == types.end())
79 G4String msg =
"\"" + scorerType +
"\" is not a valid scorer type\n";
80 msg +=
"Available scorer types are:\n";
81 for (
const auto& it : types)
82 {msg +=
"\"" + it.first +
"\"\n";}
87 G4cout << __METHOD_NAME__ <<
" determined scorer type to be " << result->second << G4endl;
89 return result->second;
General exception with possible name of object and message.
static std::map< BDSTypeSafeEnum< scorertype_def, int >, std::string > * dictionary
BDSScorerType DetermineScorerType(G4String scorerType)
function to determine the enum type of the cavity geometry (case-insensitive)
G4String LowerCase(const G4String &str)
Utility function to simplify lots of syntax changes for pedantic g4 changes.