Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // >> 26 // $Id: ExTGRCRegionCutsMgr.cc,v 1.3 2008/12/18 12:56:56 gunter Exp $ >> 27 // GEANT4 tag $Name: geant4-09-02 $ 26 // 28 // 27 /// \file persistency/P03/src/ExTGRCRegionCuts << 29 // Author: P. Arce 28 /// \brief Implementation of the ExTGRCRegionC << 30 // Changes: creation May 2007 >> 31 // --------------------------------------------------------------------------- 29 32 30 #include "ExTGRCRegionCutsMgr.hh" 33 #include "ExTGRCRegionCutsMgr.hh" 31 << 32 #include "ExTGRCRegionData.hh" 34 #include "ExTGRCRegionData.hh" 33 35 34 #include "G4LogicalVolume.hh" << 35 #include "G4ProductionCuts.hh" << 36 #include "G4Region.hh" 36 #include "G4Region.hh" 37 #include "G4RegionStore.hh" 37 #include "G4RegionStore.hh" 38 #include "G4UIcommand.hh" << 38 #include "G4ProductionCuts.hh" >> 39 #include "G4LogicalVolume.hh" 39 #include "G4tgbVolumeMgr.hh" 40 #include "G4tgbVolumeMgr.hh" 40 #include "G4tgrUtils.hh" 41 #include "G4tgrUtils.hh" >> 42 #include "G4UIcommand.hh" 41 43 42 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::fIns << 44 //---------------------------------------------------------------------- >> 45 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::theInstance = 0; 43 46 44 //....oooOO0OOooo........oooOO0OOooo........oo << 47 //---------------------------------------------------------------------- 45 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::GetI 48 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::GetInstance() 46 { 49 { 47 if (!fInstance) { << 50 if( !theInstance ) 48 fInstance = new ExTGRCRegionCutsMgr; << 51 { >> 52 theInstance = new ExTGRCRegionCutsMgr; 49 } 53 } 50 return fInstance; << 54 return theInstance; 51 } 55 } 52 56 53 //....oooOO0OOooo........oooOO0OOooo........oo << 57 //----------------------------------------------------------------------- 54 ExTGRCRegionCutsMgr::ExTGRCRegionCutsMgr() {} << 58 ExTGRCRegionCutsMgr::ExTGRCRegionCutsMgr() >> 59 { >> 60 } 55 61 56 //....oooOO0OOooo........oooOO0OOooo........oo << 62 //----------------------------------------------------------------------- 57 ExTGRCRegionCutsMgr::~ExTGRCRegionCutsMgr() 63 ExTGRCRegionCutsMgr::~ExTGRCRegionCutsMgr() 58 { 64 { 59 delete fInstance; << 65 delete theInstance; 60 } 66 } 61 67 62 //....oooOO0OOooo........oooOO0OOooo........oo << 68 //----------------------------------------------------------------------- 63 void ExTGRCRegionCutsMgr::AddRegionData(const << 69 void ExTGRCRegionCutsMgr::AddRegionData( const std::vector<G4String>& rd ) 64 { 70 { 65 if ((rd.size() > 1) && (FindRegionData(rd[0] << 71 66 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 72 if( (rd.size() > 1) && (FindRegionData( rd[0] ).size() != 0) ) 67 G4String("Region already exist << 73 { >> 74 G4Exception("ExTGRCRegionCutsMgr::AddRegionData", "InvalidArgument", >> 75 JustWarning, >> 76 G4String("Region already exists: " + rd[0]).c_str() ); 68 return; 77 return; 69 } 78 } 70 fRegionDatae.push_back(new ExTGRCRegionData( << 79 theRegionDatae.push_back( new ExTGRCRegionData( rd ) ); 71 } 80 } 72 81 73 //....oooOO0OOooo........oooOO0OOooo........oo << 82 //----------------------------------------------------------------------- 74 void ExTGRCRegionCutsMgr::AddRegionCuts(const << 83 void ExTGRCRegionCutsMgr::AddRegionCuts( const std::vector<G4String>& rc ) 75 { 84 { 76 if (rc.size() == 0) { << 85 if( rc.size() == 0 ) >> 86 { 77 G4cerr << "ERROR - ExTGRCRegionCutsMgr::Ad 87 G4cerr << "ERROR - ExTGRCRegionCutsMgr::AddRegionCuts()" << G4endl 78 << " Must have 3 or 4 argume 88 << " Must have 3 or 4 arguments : REGION_NAME, gamma_CUT," 79 << " e-_CUT (e+_CUT)." << G4endl << << 89 << " e-_CUT (e+_CUT)." << G4endl 80 << G4endl; << 90 << " It has only " << rc.size() << " !" << G4endl; 81 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 91 G4Exception("ExTGRCRegionCutsMgr::AddRegionCuts()", "InvalidArgument", 82 G4UIcommand::ConvertToString(G << 92 FatalErrorInArgument, G4UIcommand::ConvertToString(G4int(rc.size())) ); 83 } 93 } 84 94 85 // Find region 95 // Find region 86 // std::vector<ExTGRCRegionData*>::const_ite << 96 std::vector<ExTGRCRegionData*>::const_iterator iter; 87 std::vector<ExTGRCRegionData*> regs = FindRe 97 std::vector<ExTGRCRegionData*> regs = FindRegionData(rc[0]); 88 98 89 if (regs.size() == 0) { << 99 if( regs.size() == 0 ) 90 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 100 { >> 101 G4Exception("ExTGRCRegionCutsMgr::AddRegionCuts()", >> 102 "InvalidArgument", FatalErrorInArgument, 91 G4String(" region does not exi 103 G4String(" region does not exist: " + rc[0]).c_str()); 92 } << 104 } 93 105 94 for (size_t ii = 0; ii < regs.size(); ii++) << 106 for( size_t ii = 0; ii < regs.size(); ii++) 95 regs[ii]->SetCutsData(rc); << 107 { >> 108 regs[ii]->SetCutsData( rc ); 96 } 109 } 97 } 110 } 98 111 99 std::vector<ExTGRCRegionData*> ExTGRCRegionCut << 112 //----------------------------------------------------------------------- >> 113 std::vector<ExTGRCRegionData*> >> 114 ExTGRCRegionCutsMgr::FindRegionData( const G4String& name) 100 { 115 { 101 std::vector<ExTGRCRegionData*> regs; 116 std::vector<ExTGRCRegionData*> regs; 102 std::vector<ExTGRCRegionData*>::const_iterat 117 std::vector<ExTGRCRegionData*>::const_iterator iter; 103 for (iter = fRegionDatae.begin(); iter != fR << 118 for( iter = theRegionDatae.begin(); iter != theRegionDatae.end(); iter++ ) 104 if (G4tgrUtils::AreWordsEquivalent(name, ( << 119 { >> 120 if( G4tgrUtils::AreWordsEquivalent( name , (*iter)->GetRegionName()) ) >> 121 { 105 regs.push_back(*iter); 122 regs.push_back(*iter); 106 } 123 } 107 } 124 } 108 return regs; << 125 return regs; 109 } 126 } 110 127 111 //....oooOO0OOooo........oooOO0OOooo........oo << 128 //----------------------------------------------------------------------- 112 void ExTGRCRegionCutsMgr::BuildRegions() 129 void ExTGRCRegionCutsMgr::BuildRegions() 113 { 130 { 114 std::vector<ExTGRCRegionData*>::const_iterat 131 std::vector<ExTGRCRegionData*>::const_iterator iter; 115 std::vector<G4String>::const_iterator ites; 132 std::vector<G4String>::const_iterator ites; 116 // std::vector<G4LogicalVolume*>::const_iter << 133 std::vector<G4LogicalVolume*>::const_iterator itelv; 117 for (iter = fRegionDatae.begin(); iter != fR << 134 for( iter = theRegionDatae.begin(); iter != theRegionDatae.end(); iter++ ) 118 G4Region* reg = new G4Region((*iter)->GetR << 135 { >> 136 G4Region* reg = new G4Region( (*iter)->GetRegionName() ); 119 std::vector<G4String> lvs = (*iter)->GetLV 137 std::vector<G4String> lvs = (*iter)->GetLVNames(); 120 for (ites = lvs.begin(); ites != lvs.end() << 138 for( ites = lvs.begin(); ites != lvs.end(); ites++ ) 121 G4LogicalVolume* logVol = G4tgbVolumeMgr << 139 { 122 reg->AddRootLogicalVolume(logVol); << 140 G4LogicalVolume* logVol = >> 141 G4tgbVolumeMgr::GetInstance()->FindG4LogVol(*ites, true ); >> 142 reg->AddRootLogicalVolume( logVol ); 123 } 143 } 124 } 144 } 125 } 145 } 126 146 127 //....oooOO0OOooo........oooOO0OOooo........oo << 147 //----------------------------------------------------------------------- 128 void ExTGRCRegionCutsMgr::BuildProductionCuts( 148 void ExTGRCRegionCutsMgr::BuildProductionCuts() 129 { 149 { 130 std::vector<ExTGRCRegionData*>::const_iterat 150 std::vector<ExTGRCRegionData*>::const_iterator iter; 131 G4RegionStore* regions = G4RegionStore::GetI 151 G4RegionStore* regions = G4RegionStore::GetInstance(); 132 //----- loop to region datae 152 //----- loop to region datae 133 for (iter = fRegionDatae.begin(); iter != fR << 153 for( iter = theRegionDatae.begin(); iter != theRegionDatae.end(); iter++ ) 134 if ((*iter)->CutsAreSet()) { << 154 { 135 G4Region* reg = regions->GetRegion((*ite << 155 if( (*iter)->CutsAreSet() ) 136 if (!reg) { << 156 { 137 G4Exception("ExTGRCRegionCutsMgr::Buil << 157 G4Region* reg = regions->GetRegion( (*iter)->GetRegionName() ); 138 FatalErrorInArgument, << 158 if( !reg ) 139 G4String("Region not found << 159 { 140 } << 160 G4Exception("ExTGRCRegionCutsMgr::BuildProductionCuts()", 141 G4ProductionCuts* cuts = new G4Productio << 161 "InvalidArgument", FatalErrorInArgument, 142 << 162 G4String("Region not found: " + (*iter)->GetRegionName()).c_str() ); 143 cuts->SetProductionCut((*iter)->GetGamma << 163 } 144 cuts->SetProductionCut((*iter)->GetElect << 164 G4ProductionCuts* cuts = new G4ProductionCuts ; 145 cuts->SetProductionCut((*iter)->GetPosit << 165 >> 166 cuts->SetProductionCut((*iter)->GetGammaCut(),"gamma"); >> 167 cuts->SetProductionCut((*iter)->GetElectronCut(),"e-"); >> 168 cuts->SetProductionCut((*iter)->GetPositronCut(),"e+"); 146 reg->SetProductionCuts(cuts); 169 reg->SetProductionCuts(cuts); 147 } 170 } 148 } 171 } 149 } 172 } 150 173