GT_Messenger.cc

Go to the documentation of this file.
00001 //! \file
00002 //!
00003 //! Source file for Gem_Tracker messenger class for the user interface.
00004 //!
00005 //! Defines the singleton messenger class and its member routines which
00006 //! control the parameters of Gem_Tracker detector within the OLYMPUS
00007 //! Monte Carlo.  This allow the user to control the parameters and/or
00008 //! running from command files or interactively.
00009 //!
00010 //! \author D.K. Hasell
00011 //! \version 1.0
00012 //! \date 2010-10-17
00013 //!
00014 //! \ingroup control
00015 
00016 // *+****1****+****2****+****3****+****4****+****5****+****6****+****7****+****
00017 
00018 // Include user header files referenced in this file.
00019 
00020 #include "GT_Messenger.h"
00021 #include "GT_SD.h"
00022 
00023 // Include the GEANT4 header files referenced in this file.
00024 
00025 #include "G4UIdirectory.hh"
00026 
00027 // Initialise the static data pointer for the GT_Messenger class.
00028 
00029 GT_Messenger * GT_Messenger::m_pInstance = 0;
00030 
00031 // Use the standard namespace.
00032 
00033 using namespace std;
00034 
00035 // *+****1****+****2****+****3****+****4****+****5****+****6****+****7****+****
00036 
00037 // Define the routine to return pointer to the instance of GT_Messenger.
00038 
00039 GT_Messenger * GT_Messenger::Instance() {
00040    if( m_pInstance == 0 ) {
00041       m_pInstance = new GT_Messenger();
00042    }
00043    return m_pInstance;
00044 }
00045 
00046 // Constructor of GT_Messenger class.
00047 
00048 GT_Messenger::GT_Messenger() {
00049 
00050    GTdir = new G4UIdirectory( "/Olympus/GT/" );
00051    GTdir->SetGuidance( "OLYMPUS Gem Tracker user commands." );
00052 
00053 }
00054 
00055 // Routine to set a pointer to the GT_SD class and define the user
00056 // functions available.
00057 
00058 void GT_Messenger::setGT_SDptr( GT_SD * ptr ) {
00059 
00060    pGT_SD = ptr;
00061 
00062    GT_SDdir = new G4UIdirectory( "/Olympus/GT/SD/" );
00063    GT_SDdir->SetGuidance( "Gem Tracker Sensitive Detector commands." );
00064 
00065    // Threshold.
00066 
00067    GT_SDsetThreshold = new
00068       G4UIcmdWithADoubleAndUnit( "/Olympus/GT/SD/setThreshold", this );
00069    GT_SDsetThreshold->SetDefaultUnit( "eV" );
00070    GT_SDsetThreshold->SetGuidance( "Set hit threshold." );
00071    GT_SDsetThreshold->SetParameterName( "energy", false );
00072    GT_SDsetThreshold->SetRange( "energy >= 0.0" );
00073    GT_SDsetThreshold->AvailableForStates( G4State_Idle );
00074 
00075    GT_SDgetThreshold = new
00076       G4UIcmdWithoutParameter( "/Olympus/GT/SD/getThreshold", this );
00077    GT_SDgetThreshold->SetGuidance( "Get hit threshold." );
00078 
00079    // X resolution.
00080 
00081    GT_SDsetXresol = new
00082       G4UIcmdWithADoubleAndUnit( "/Olympus/GT/SD/setXresol", this );
00083    GT_SDsetXresol->SetDefaultUnit( "um" );
00084    GT_SDsetXresol->SetGuidance( "Set X resolution." );
00085    GT_SDsetXresol->SetParameterName( "x", false );
00086    GT_SDsetXresol->SetRange( "x >= 0.0" );
00087    GT_SDsetXresol->AvailableForStates( G4State_Idle );
00088 
00089    GT_SDgetXresol = new
00090       G4UIcmdWithoutParameter( "/Olympus/GT/SD/getXresol", this );
00091    GT_SDgetXresol->SetGuidance( "Get X resolution." );
00092 
00093    // Y resolution.
00094 
00095    GT_SDsetYresol = new
00096       G4UIcmdWithADoubleAndUnit( "/Olympus/GT/SD/setYresol", this );
00097    GT_SDsetYresol->SetDefaultUnit( "um" );
00098    GT_SDsetYresol->SetGuidance( "Set Y resolution." );
00099    GT_SDsetYresol->SetParameterName( "y", false );
00100    GT_SDsetYresol->SetRange( "y >= 0.0" );
00101    GT_SDsetYresol->AvailableForStates( G4State_Idle );
00102 
00103    GT_SDgetYresol = new
00104       G4UIcmdWithoutParameter( "/Olympus/GT/SD/getYresol", this );
00105    GT_SDgetYresol->SetGuidance( "Get Y resolution." );
00106 
00107 }
00108 
00109 // Routines to set new values and get current values.
00110 
00111 void GT_Messenger::SetNewValue( G4UIcommand * command, G4String newValue ) {
00112 
00113    // GT_SD Threshold.
00114 
00115    if( command == GT_SDsetThreshold ) {
00116       pGT_SD->setThreshold( GT_SDsetThreshold->GetNewDoubleValue( newValue ) );
00117       G4cout << "GT_SD threshold = " << newValue << G4endl;
00118    }
00119    else if( command == GT_SDgetThreshold ) {
00120       G4cout << "GT_SD threshold = " << pGT_SD->getThreshold() / eV 
00121              << " [eV]" << G4endl;
00122    }
00123 
00124   // GT_SD X resolution.
00125 
00126    else if( command == GT_SDsetXresol ) {
00127       pGT_SD->setXresol( GT_SDsetXresol->GetNewDoubleValue( newValue ) );
00128       G4cout << "GT_SD X resolution = " << newValue << G4endl;
00129    }
00130    else if( command == GT_SDgetXresol ) {
00131       G4cout << "GT_SD X resolution = " << pGT_SD->getXresol() / um 
00132              << " [um]" << G4endl;
00133    }
00134 
00135   // GT_SD Y resolution.
00136 
00137    else if( command == GT_SDsetYresol ) {
00138       pGT_SD->setYresol( GT_SDsetYresol->GetNewDoubleValue( newValue ) );
00139       G4cout << "GT_SD Y resolution = " << newValue << G4endl;
00140    }
00141    else if( command == GT_SDgetYresol ) {
00142       G4cout << "GT_SD Y resolution = " << pGT_SD->getYresol() / um 
00143              << " [um]" << G4endl;
00144    }
00145 
00146 }
00147 
00148 // Routine to get current value (not used).
00149 
00150 G4String GT_Messenger::GetCurrentValue( G4UIcommand * command ) {
00151    G4String cv;
00152    return cv;
00153 }