Geant4 Cross Reference |
1 // 2 // ******************************************************************** 3 // * License and Disclaimer * 4 // * * 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. * 10 // * * 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitation of liability. * 17 // * * 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************************************** 25 // 26 // 27 // 28 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 29 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 30 31 #include "RunActionMessenger.hh" 32 33 #include "G4Tokenizer.hh" 34 #include "G4UIcmdWithABool.hh" 35 #include "G4UIcmdWithAnInteger.hh" 36 #include "G4UIdirectory.hh" 37 38 #include "RunAction.hh" 39 40 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 41 42 RunActionMessenger::RunActionMessenger(RunAction* runAction) 43 : G4UImessenger(), fRunAction(runAction), fRunDir(nullptr), fScanParamsCmd(nullptr) 44 { 45 fRunDir = new G4UIdirectory("/tomography/run/"); 46 fRunDir->SetGuidance("run control"); 47 48 fScanParamsCmd = new G4UIcommand("/tomography/run/scanParameters", this); 49 fScanParamsCmd->SetGuidance("Set scan parameters: number of projections, slices and pixels"); 50 51 auto nbProjections = new G4UIparameter("NbProjections", 'i', false); 52 nbProjections->SetGuidance("number of scan projections"); 53 nbProjections->SetParameterRange("NbProjections>=1"); 54 fScanParamsCmd->SetParameter(nbProjections); 55 // 56 auto nbSlices = new G4UIparameter("NbSlices", 'i', false); 57 nbSlices->SetGuidance("number of scan slices"); 58 nbSlices->SetParameterRange("NbSlices>=1"); 59 fScanParamsCmd->SetParameter(nbSlices); 60 // 61 auto nbPixels = new G4UIparameter("NbPixels", 'i', false); 62 nbPixels->SetGuidance("number of scan pixels"); 63 nbPixels->SetParameterRange("NbPixels>=1"); 64 fScanParamsCmd->SetParameter(nbPixels); 65 fScanParamsCmd->AvailableForStates(G4State_PreInit, G4State_Idle); 66 67 resumeCmd = new G4UIcmdWithABool("/tomography/run/resumeSimulation", this); 68 resumeCmd->SetGuidance("Resume the simulation after an interruption"); 69 resumeCmd->SetParameterName("interruptionFlag", true); 70 resumeCmd->SetDefaultValue(false); 71 resumeCmd->AvailableForStates(G4State_PreInit, G4State_Idle); 72 73 resumeProjectionIndexCmd = 74 new G4UIcmdWithAnInteger("/tomography/run/resumeProjectionIndex", this); 75 resumeProjectionIndexCmd->SetGuidance("Set the index of projection to resume the simulation"); 76 resumeProjectionIndexCmd->SetParameterName("ProjectionIndex", true); 77 resumeProjectionIndexCmd->SetDefaultValue(0); 78 resumeProjectionIndexCmd->SetRange("ProjectionIndex >=0"); 79 resumeProjectionIndexCmd->AvailableForStates(G4State_PreInit, G4State_Idle); 80 } 81 82 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 83 84 RunActionMessenger::~RunActionMessenger() 85 { 86 delete fRunDir; 87 delete fScanParamsCmd; 88 delete resumeCmd; 89 delete resumeProjectionIndexCmd; 90 } 91 92 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 93 94 void RunActionMessenger::SetNewValue(G4UIcommand* command, G4String newValue) 95 { 96 if (command == fScanParamsCmd) { 97 G4Tokenizer next(newValue); 98 G4int nbProjections = StoI(next()); 99 G4int nbSlices = StoI(next()); 100 G4int nbPixels = StoI(next()); 101 fRunAction->SetScanParameters(nbProjections, nbSlices, nbPixels); 102 } 103 else if (command == resumeCmd) { 104 fRunAction->SetInterruptionFlag(resumeCmd->GetNewBoolValue(newValue)); 105 } 106 else if (command == resumeProjectionIndexCmd) { 107 fRunAction->SetResumeProjectionIndex(resumeProjectionIndexCmd->GetNewIntValue(newValue)); 108 } 109 } 110 111 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 112