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 76943 2013-11-19 09:57:34Z gcosmo $ 26 // 27 // 27 /// \file persistency/P03/src/ExTGRCRegionCuts 28 /// \file persistency/P03/src/ExTGRCRegionCutsMgr.cc 28 /// \brief Implementation of the ExTGRCRegionC 29 /// \brief Implementation of the ExTGRCRegionCutsMgr class 29 30 30 #include "ExTGRCRegionCutsMgr.hh" 31 #include "ExTGRCRegionCutsMgr.hh" 31 << 32 #include "ExTGRCRegionData.hh" 32 #include "ExTGRCRegionData.hh" 33 33 34 #include "G4LogicalVolume.hh" << 35 #include "G4ProductionCuts.hh" << 36 #include "G4Region.hh" 34 #include "G4Region.hh" 37 #include "G4RegionStore.hh" 35 #include "G4RegionStore.hh" 38 #include "G4UIcommand.hh" << 36 #include "G4ProductionCuts.hh" >> 37 #include "G4LogicalVolume.hh" 39 #include "G4tgbVolumeMgr.hh" 38 #include "G4tgbVolumeMgr.hh" 40 #include "G4tgrUtils.hh" 39 #include "G4tgrUtils.hh" >> 40 #include "G4UIcommand.hh" 41 41 42 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::fIns 42 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::fInstance = 0; 43 43 44 //....oooOO0OOooo........oooOO0OOooo........oo 44 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 45 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::GetI 45 ExTGRCRegionCutsMgr* ExTGRCRegionCutsMgr::GetInstance() 46 { 46 { 47 if (!fInstance) { << 47 if( !fInstance ) >> 48 { 48 fInstance = new ExTGRCRegionCutsMgr; 49 fInstance = new ExTGRCRegionCutsMgr; 49 } 50 } 50 return fInstance; 51 return fInstance; 51 } 52 } 52 53 53 //....oooOO0OOooo........oooOO0OOooo........oo 54 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 54 ExTGRCRegionCutsMgr::ExTGRCRegionCutsMgr() {} << 55 ExTGRCRegionCutsMgr::ExTGRCRegionCutsMgr() >> 56 { >> 57 } 55 58 56 //....oooOO0OOooo........oooOO0OOooo........oo 59 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 57 ExTGRCRegionCutsMgr::~ExTGRCRegionCutsMgr() 60 ExTGRCRegionCutsMgr::~ExTGRCRegionCutsMgr() 58 { 61 { 59 delete fInstance; 62 delete fInstance; 60 } 63 } 61 64 62 //....oooOO0OOooo........oooOO0OOooo........oo 65 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 63 void ExTGRCRegionCutsMgr::AddRegionData(const << 66 void ExTGRCRegionCutsMgr::AddRegionData( const std::vector<G4String>& rd ) 64 { 67 { 65 if ((rd.size() > 1) && (FindRegionData(rd[0] << 68 66 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 69 if( (rd.size() > 1) && (FindRegionData( rd[0] ).size() != 0) ) 67 G4String("Region already exist << 70 { >> 71 G4Exception("ExTGRCRegionCutsMgr::AddRegionData", "InvalidArgument", >> 72 JustWarning, >> 73 G4String("Region already exists: " + rd[0]).c_str() ); 68 return; 74 return; 69 } 75 } 70 fRegionDatae.push_back(new ExTGRCRegionData( << 76 fRegionDatae.push_back( new ExTGRCRegionData( rd ) ); 71 } 77 } 72 78 73 //....oooOO0OOooo........oooOO0OOooo........oo 79 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 74 void ExTGRCRegionCutsMgr::AddRegionCuts(const << 80 void ExTGRCRegionCutsMgr::AddRegionCuts( const std::vector<G4String>& rc ) 75 { 81 { 76 if (rc.size() == 0) { << 82 if( rc.size() == 0 ) >> 83 { 77 G4cerr << "ERROR - ExTGRCRegionCutsMgr::Ad 84 G4cerr << "ERROR - ExTGRCRegionCutsMgr::AddRegionCuts()" << G4endl 78 << " Must have 3 or 4 argume 85 << " Must have 3 or 4 arguments : REGION_NAME, gamma_CUT," 79 << " e-_CUT (e+_CUT)." << G4endl << << 86 << " e-_CUT (e+_CUT)." << G4endl 80 << G4endl; << 87 << " It has only " << rc.size() << " !" << G4endl; 81 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 88 G4Exception("ExTGRCRegionCutsMgr::AddRegionCuts()", "InvalidArgument", 82 G4UIcommand::ConvertToString(G << 89 FatalErrorInArgument, G4UIcommand::ConvertToString(G4int(rc.size())) ); 83 } 90 } 84 91 85 // Find region 92 // Find region 86 // std::vector<ExTGRCRegionData*>::const_ite << 93 std::vector<ExTGRCRegionData*>::const_iterator iter; 87 std::vector<ExTGRCRegionData*> regs = FindRe 94 std::vector<ExTGRCRegionData*> regs = FindRegionData(rc[0]); 88 95 89 if (regs.size() == 0) { << 96 if( regs.size() == 0 ) 90 G4Exception("ExTGRCRegionCutsMgr::AddRegio << 97 { >> 98 G4Exception("ExTGRCRegionCutsMgr::AddRegionCuts()", >> 99 "InvalidArgument", FatalErrorInArgument, 91 G4String(" region does not exi 100 G4String(" region does not exist: " + rc[0]).c_str()); 92 } << 101 } 93 102 94 for (size_t ii = 0; ii < regs.size(); ii++) << 103 for( size_t ii = 0; ii < regs.size(); ii++) 95 regs[ii]->SetCutsData(rc); << 104 { >> 105 regs[ii]->SetCutsData( rc ); 96 } 106 } 97 } 107 } 98 108 99 std::vector<ExTGRCRegionData*> ExTGRCRegionCut << 109 std::vector<ExTGRCRegionData*> >> 110 ExTGRCRegionCutsMgr::FindRegionData( const G4String& name) 100 { 111 { 101 std::vector<ExTGRCRegionData*> regs; 112 std::vector<ExTGRCRegionData*> regs; 102 std::vector<ExTGRCRegionData*>::const_iterat 113 std::vector<ExTGRCRegionData*>::const_iterator iter; 103 for (iter = fRegionDatae.begin(); iter != fR << 114 for( iter = fRegionDatae.begin(); iter != fRegionDatae.end(); iter++ ) 104 if (G4tgrUtils::AreWordsEquivalent(name, ( << 115 { >> 116 if( G4tgrUtils::AreWordsEquivalent( name , (*iter)->GetRegionName()) ) >> 117 { 105 regs.push_back(*iter); 118 regs.push_back(*iter); 106 } 119 } 107 } 120 } 108 return regs; << 121 return regs; 109 } 122 } 110 123 111 //....oooOO0OOooo........oooOO0OOooo........oo 124 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 112 void ExTGRCRegionCutsMgr::BuildRegions() 125 void ExTGRCRegionCutsMgr::BuildRegions() 113 { 126 { 114 std::vector<ExTGRCRegionData*>::const_iterat 127 std::vector<ExTGRCRegionData*>::const_iterator iter; 115 std::vector<G4String>::const_iterator ites; 128 std::vector<G4String>::const_iterator ites; 116 // std::vector<G4LogicalVolume*>::const_iter << 129 std::vector<G4LogicalVolume*>::const_iterator itelv; 117 for (iter = fRegionDatae.begin(); iter != fR << 130 for( iter = fRegionDatae.begin(); iter != fRegionDatae.end(); iter++ ) 118 G4Region* reg = new G4Region((*iter)->GetR << 131 { >> 132 G4Region* reg = new G4Region( (*iter)->GetRegionName() ); 119 std::vector<G4String> lvs = (*iter)->GetLV 133 std::vector<G4String> lvs = (*iter)->GetLVNames(); 120 for (ites = lvs.begin(); ites != lvs.end() << 134 for( ites = lvs.begin(); ites != lvs.end(); ites++ ) 121 G4LogicalVolume* logVol = G4tgbVolumeMgr << 135 { 122 reg->AddRootLogicalVolume(logVol); << 136 G4LogicalVolume* logVol = >> 137 G4tgbVolumeMgr::GetInstance()->FindG4LogVol(*ites, true ); >> 138 reg->AddRootLogicalVolume( logVol ); 123 } 139 } 124 } 140 } 125 } 141 } 126 142 127 //....oooOO0OOooo........oooOO0OOooo........oo 143 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 128 void ExTGRCRegionCutsMgr::BuildProductionCuts( 144 void ExTGRCRegionCutsMgr::BuildProductionCuts() 129 { 145 { 130 std::vector<ExTGRCRegionData*>::const_iterat 146 std::vector<ExTGRCRegionData*>::const_iterator iter; 131 G4RegionStore* regions = G4RegionStore::GetI 147 G4RegionStore* regions = G4RegionStore::GetInstance(); 132 //----- loop to region datae 148 //----- loop to region datae 133 for (iter = fRegionDatae.begin(); iter != fR << 149 for( iter = fRegionDatae.begin(); iter != fRegionDatae.end(); iter++ ) 134 if ((*iter)->CutsAreSet()) { << 150 { 135 G4Region* reg = regions->GetRegion((*ite << 151 if( (*iter)->CutsAreSet() ) 136 if (!reg) { << 152 { 137 G4Exception("ExTGRCRegionCutsMgr::Buil << 153 G4Region* reg = regions->GetRegion( (*iter)->GetRegionName() ); 138 FatalErrorInArgument, << 154 if( !reg ) 139 G4String("Region not found << 155 { 140 } << 156 G4Exception("ExTGRCRegionCutsMgr::BuildProductionCuts()", 141 G4ProductionCuts* cuts = new G4Productio << 157 "InvalidArgument", FatalErrorInArgument, 142 << 158 G4String("Region not found: " + (*iter)->GetRegionName()).c_str() ); 143 cuts->SetProductionCut((*iter)->GetGamma << 159 } 144 cuts->SetProductionCut((*iter)->GetElect << 160 G4ProductionCuts* cuts = new G4ProductionCuts ; 145 cuts->SetProductionCut((*iter)->GetPosit << 161 >> 162 cuts->SetProductionCut((*iter)->GetGammaCut(),"gamma"); >> 163 cuts->SetProductionCut((*iter)->GetElectronCut(),"e-"); >> 164 cuts->SetProductionCut((*iter)->GetPositronCut(),"e+"); 146 reg->SetProductionCuts(cuts); 165 reg->SetProductionCuts(cuts); 147 } 166 } 148 } 167 } 149 } 168 } 150 169