File indexing completed on 2025-02-23 09:22:20
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030 #include "LETMessenger.hh"
0031
0032 #include "LET.hh"
0033 #include <G4UIcmdWithABool.hh>
0034 #include <G4UIcmdWithAString.hh>
0035 #include <G4UIcmdWithAnInteger.hh>
0036 #include <G4UIcmdWithoutParameter.hh>
0037 #include <G4UIdirectory.hh>
0038
0039 namespace RadioBio
0040 {
0041
0042
0043
0044 LETMessenger::LETMessenger(LET* LET) : G4UImessenger(), fLET(LET)
0045 {
0046
0047 fLETDir = new G4UIdirectory("/LET/");
0048 fLETDir->SetGuidance("commands to setup LET calculation");
0049
0050
0051 fCalculationCmd = new G4UIcmdWithABool("/LET/calculate", this);
0052 fCalculationCmd->SetGuidance("Whether to enable LET calculation");
0053 fCalculationCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0054 fCalculationCmd->SetToBeBroadcasted(false);
0055
0056
0057 fVerbosityCmd = new G4UIcmdWithAnInteger("/LET/verbose", this);
0058 fVerbosityCmd->SetGuidance("Set verbosity level of LET");
0059 fVerbosityCmd->SetGuidance("0 = quiet");
0060 fVerbosityCmd->SetGuidance("1 = important messages (~10 per run)");
0061 fVerbosityCmd->SetGuidance("2 = debug");
0062 fVerbosityCmd->SetToBeBroadcasted(false);
0063
0064
0065 fResetCmd = new G4UIcmdWithoutParameter("/LET/reset", this);
0066 fResetCmd->SetGuidance("Reset accumulated data");
0067 fResetCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0068 fResetCmd->SetToBeBroadcasted(false);
0069
0070
0071 fLETPathCmd = new G4UIcmdWithAString("/LET/fileName", this);
0072 fLETPathCmd->SetGuidance("Set the filename for the LET file");
0073 fLETPathCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0074 fLETPathCmd->SetToBeBroadcasted(false);
0075
0076
0077 fPrintCmd = new G4UIcmdWithoutParameter("/LET/print", this);
0078 fPrintCmd->SetGuidance("Print LET parameters");
0079 fPrintCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0080 fPrintCmd->SetToBeBroadcasted(false);
0081 }
0082
0083
0084
0085 LETMessenger::~LETMessenger()
0086 {
0087 delete fLETDir;
0088 delete fCalculationCmd;
0089 delete fVerbosityCmd;
0090 delete fResetCmd;
0091 delete fLETPathCmd;
0092 delete fPrintCmd;
0093 }
0094
0095
0096
0097 void LETMessenger::SetNewValue(G4UIcommand* command, G4String newValue)
0098 {
0099 if (command == fCalculationCmd) {
0100 fLET->SetCalculationEnabled(fCalculationCmd->GetNewBoolValue(newValue));
0101 }
0102
0103 if (command == fVerbosityCmd) {
0104 fLET->SetVerboseLevel(fVerbosityCmd->GetNewIntValue(newValue));
0105 }
0106
0107 if (command == fResetCmd) {
0108 fLET->Reset();
0109 }
0110
0111 if (command == fLETPathCmd) {
0112 fLET->SetPath(newValue);
0113 }
0114
0115 if (command == fPrintCmd) {
0116 fLET->PrintParameters();
0117 }
0118 }
0119
0120
0121
0122 }