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 // G4tgrVolume implementation << 27 // 26 // 28 // Author: P.Arce, CIEMAT (November 2007) << 27 // $Id: G4tgrVolume.cc,v 1.13 2010/12/15 11:29:54 arce Exp $ 29 // ------------------------------------------- << 28 // GEANT4 tag $Name: geant4-09-04 $ >> 29 // >> 30 // >> 31 // class G4tgrVolume >> 32 >> 33 // History: >> 34 // - Created. P.Arce, CIEMAT (November 2007) >> 35 // ------------------------------------------------------------------------- 30 36 31 #include "G4tgrVolume.hh" 37 #include "G4tgrVolume.hh" 32 #include "G4tgrUtils.hh" 38 #include "G4tgrUtils.hh" 33 #include "G4tgrSolid.hh" 39 #include "G4tgrSolid.hh" 34 #include "G4tgrVolumeMgr.hh" 40 #include "G4tgrVolumeMgr.hh" 35 #include "G4tgrPlace.hh" 41 #include "G4tgrPlace.hh" 36 #include "G4tgrPlaceSimple.hh" 42 #include "G4tgrPlaceSimple.hh" 37 #include "G4tgrPlaceDivRep.hh" 43 #include "G4tgrPlaceDivRep.hh" 38 #include "G4tgrPlaceParameterisation.hh" 44 #include "G4tgrPlaceParameterisation.hh" 39 #include "G4tgrFileReader.hh" 45 #include "G4tgrFileReader.hh" 40 #include "G4tgrMessenger.hh" 46 #include "G4tgrMessenger.hh" 41 #include "G4UIcommand.hh" 47 #include "G4UIcommand.hh" 42 48 43 // ------------------------------------------- << 49 //------------------------------------------------------------- 44 G4tgrVolume::G4tgrVolume() 50 G4tgrVolume::G4tgrVolume() >> 51 : theName(""), theType(""), >> 52 theMaterialName(""), theSolid(0), theVisibility(false), >> 53 theRGBColour(0), theCheckOverlaps(false) 45 { 54 { 46 } 55 } 47 56 48 // ------------------------------------------- << 57 >> 58 //------------------------------------------------------------- 49 G4tgrVolume::~G4tgrVolume() 59 G4tgrVolume::~G4tgrVolume() 50 { 60 { 51 delete[] theRGBColour; << 61 delete [] theRGBColour; 52 } 62 } 53 63 54 // ------------------------------------------- << 64 55 G4tgrVolume::G4tgrVolume(const std::vector<G4S << 65 //------------------------------------------------------------- >> 66 G4tgrVolume::G4tgrVolume( const std::vector<G4String>& wl) 56 { 67 { 57 theType = "VOLSimple"; 68 theType = "VOLSimple"; 58 69 59 //---------- set name << 70 //---------- set name 60 theName = G4tgrUtils::GetString(wl[1]); << 71 theName = G4tgrUtils::GetString( wl[1] ); 61 72 62 theVisibility = true; << 73 theVisibility = 1; 63 theRGBColour = new G4double[4]; << 74 theRGBColour = new G4double[4]; 64 for(std::size_t ii = 0; ii < 4; ++ii) << 75 for(size_t ii=0; ii<4; ii++) { theRGBColour[ii] = -1.; } 65 { << 76 theCheckOverlaps = 0; 66 theRGBColour[ii] = -1.; << 67 } << 68 theCheckOverlaps = false; << 69 77 70 if(wl.size() != 4) << 78 if( wl.size() != 4 ) 71 { 79 { 72 //:VOLU tag to build a volume creating sol 80 //:VOLU tag to build a volume creating solid and material 73 //---------- set material name 81 //---------- set material name 74 theMaterialName = G4tgrUtils::GetString(wl << 82 theMaterialName = G4tgrUtils::GetString( wl[wl.size()-1] ); 75 << 83 76 //---------- create only vector<double> of 84 //---------- create only vector<double> of theSolidParams 77 theSolid = G4tgrVolumeMgr::GetInstance()-> << 85 theSolid = G4tgrVolumeMgr::GetInstance()->CreateSolid( wl, 1 ); 78 86 79 #ifdef G4VERBOSE 87 #ifdef G4VERBOSE 80 if(G4tgrMessenger::GetVerboseLevel() >= 1) << 88 if( G4tgrMessenger::GetVerboseLevel() >= 1 ) 81 { << 89 { 82 G4cout << "Created from new solid: " << << 90 G4cout << "Created from new solid: " 83 } << 91 << *this << G4endl; >> 92 } 84 #endif 93 #endif 85 } 94 } 86 else 95 else 87 { << 88 //:VOLU tag to build a volume assigning ma << 89 //---------- set material name << 90 theMaterialName = G4tgrUtils::GetString(wl << 91 theSolid = G4tgrVolumeMgr::GetInsta << 92 << 93 #ifdef G4VERBOSE << 94 if(G4tgrMessenger::GetVerboseLevel() >= 1) << 95 { 96 { 96 G4cout << "Created from existing solid: << 97 //:VOLU tag to build a volume assigning material to solid 97 } << 98 //---------- set material name >> 99 theMaterialName = G4tgrUtils::GetString( wl[3] ); >> 100 theSolid = G4tgrVolumeMgr::GetInstance()->FindSolid( wl[2], true ); >> 101 >> 102 #ifdef G4VERBOSE >> 103 if( G4tgrMessenger::GetVerboseLevel() >= 1 ) >> 104 { >> 105 G4cout << "Created from existing solid: " >> 106 << *this << G4endl; >> 107 } 98 #endif 108 #endif 99 } << 109 } 100 } 110 } 101 111 102 // ------------------------------------------- << 112 103 G4tgrVolume::G4tgrVolume(const G4tgrVolume& vo << 113 //------------------------------------------------------------------------- >> 114 G4tgrVolume::G4tgrVolume( const G4tgrVolume& vol ) 104 { 115 { 105 theName = vol.GetName(); << 116 theName = vol.GetName(); 106 theType = vol.GetType(); << 117 theType = vol.GetType(); 107 theMaterialName = vol.GetMaterialName(); << 118 theMaterialName = vol.GetMaterialName(); 108 theSolid = vol.GetSolid(); << 119 theSolid = const_cast<G4tgrSolid*>(vol.GetSolid()); 109 thePlacements = vol.GetPlacements(); << 120 thePlacements = vol.GetPlacements(); 110 theVisibility = vol.GetVisibility(); << 121 theVisibility = vol.GetVisibility(); 111 theRGBColour = vol.GetRGBColour(); << 122 theRGBColour = vol.GetRGBColour(); 112 theCheckOverlaps = vol.GetCheckOverlaps(); 123 theCheckOverlaps = vol.GetCheckOverlaps(); 113 } 124 } 114 125 115 // ------------------------------------------- << 126 116 G4tgrVolume* G4tgrVolume::GetVolume(G4int ii) << 127 //------------------------------------------------------------------------- >> 128 G4tgrVolume* G4tgrVolume::GetVolume( G4int ii ) const 117 { 129 { 118 G4String ErrMessage = "Should only be called << 130 G4String ErrMessage = "Should only be called for composite solids... " 119 G4UIcommand::ConvertTo << 131 + G4UIcommand::ConvertToString(ii); 120 G4Exception("G4tgrVolume::GetVolume()", "Inv << 132 G4Exception("G4tgrVolume::GetVolume()", "InvalidCall", 121 ErrMessage); << 133 FatalException, ErrMessage); 122 return nullptr; << 134 return 0; 123 } << 135 } 124 << 136 125 // ------------------------------------------- << 137 126 G4tgrPlace* G4tgrVolume::AddPlace(const std::v << 138 //------------------------------------------------------------- 127 { << 139 G4tgrPlace* G4tgrVolume::AddPlace( const std::vector<G4String>& wl ) 128 //---------- Check for exact number of words << 140 { 129 G4tgrUtils::CheckWLsize(wl, 8, WLSIZE_EQ, " << 141 //---------- Check for exact number of words read 130 //---------- set G4tgrPlace << 142 G4tgrUtils::CheckWLsize( wl, 8, WLSIZE_EQ, " G4tgrVolume::AddPlace"); 131 G4tgrPlaceSimple* pl = new G4tgrPlaceSimple( << 143 //---------- set G4tgrPlace >> 144 G4tgrPlaceSimple* pl = new G4tgrPlaceSimple( wl ); 132 //---------- check that there is no previous 145 //---------- check that there is no previous placement in 133 // the same parent with the same c << 146 // the same parent with the same copyNo 134 for(auto ite = thePlacements.cbegin(); ite ! << 147 std::vector<G4tgrPlace*>::iterator ite; >> 148 for( ite = thePlacements.begin(); ite != thePlacements.end(); ite++) 135 { 149 { 136 if(((*ite)->GetCopyNo() == pl->GetCopyNo() << 150 if( ((*ite)->GetCopyNo() == pl->GetCopyNo()) 137 ((*ite)->GetParentName() == pl->GetPare << 151 && ((*ite)->GetParentName() == pl->GetParentName()) ) 138 { 152 { 139 G4String ErrMessage = << 153 G4String ErrMessage = "Repeated placement. Volume " 140 "Repeated placement. Volume " + theNam << 154 + theName + " in " + pl->GetParentName(); 141 G4Exception("G4tgrVolume::AddPlace()", " 155 G4Exception("G4tgrVolume::AddPlace()", "InvalidArgument", 142 FatalErrorInArgument, ErrMes 156 FatalErrorInArgument, ErrMessage); 143 } 157 } 144 } << 158 } 145 159 146 pl->SetVolume(this); << 160 pl->SetVolume( this ); 147 thePlacements.push_back(pl); << 161 thePlacements.push_back( pl ); 148 162 149 #ifdef G4VERBOSE 163 #ifdef G4VERBOSE 150 if(G4tgrMessenger::GetVerboseLevel() >= 2) << 164 if( G4tgrMessenger::GetVerboseLevel() >= 2 ) 151 { 165 { 152 G4cout << " G4tgrVolume: New placement: " 166 G4cout << " G4tgrVolume: New placement: " << thePlacements.size() 153 << " added for Volume " << theName << 167 << " added for Volume " << theName 154 << pl->GetParentName() << " type " << 168 << " inside " << pl->GetParentName() >> 169 << " type " << pl->GetType() << G4endl; 155 } 170 } 156 #endif 171 #endif 157 //---------- register parent - child << 172 //---------- register parent - child 158 G4tgrVolumeMgr::GetInstance()->RegisterParen << 173 G4tgrVolumeMgr::GetInstance()->RegisterParentChild( pl->GetParentName(), pl ); 159 174 160 return pl; 175 return pl; 161 } 176 } 162 177 163 // ------------------------------------------- << 164 G4tgrPlaceDivRep* G4tgrVolume::AddPlaceReplica << 165 { << 166 //---------- Check for exact number of words << 167 G4tgrUtils::CheckWLsize(wl, 6, WLSIZE_GE, " << 168 G4tgrUtils::CheckWLsize(wl, 7, WLSIZE_LE, " << 169 178 170 if((wl.size() == 7) && (G4tgrUtils::GetDoubl << 179 //------------------------------------------------------------- 171 (wl[3] != "PHI")) << 180 G4tgrPlaceDivRep* >> 181 G4tgrVolume::AddPlaceReplica( const std::vector<G4String>& wl ) >> 182 { >> 183 //---------- Check for exact number of words read >> 184 G4tgrUtils::CheckWLsize( wl, 6, WLSIZE_GE, " G4tgrVolume::AddPlaceReplica"); >> 185 G4tgrUtils::CheckWLsize( wl, 7, WLSIZE_LE, " G4tgrVolume::AddPlaceReplica"); >> 186 >> 187 if( (wl.size() == 7) && (G4tgrUtils::GetDouble(wl[6]) != 0.) >> 188 && (wl[3] != "PHI") ) 172 { 189 { 173 G4Exception("G4tgrVolume::AddPlaceReplica" 190 G4Exception("G4tgrVolume::AddPlaceReplica", 174 "Offset set for replica not al 191 "Offset set for replica not along PHI, it will not be used", 175 JustWarning, 192 JustWarning, 176 G4String("Volume " + wl[1] + " << 193 G4String("Volume "+wl[1]+" in volume "+wl[2]).c_str()); 177 } 194 } 178 << 195 179 //---------- set G4tgrPlace << 196 //---------- set G4tgrPlace 180 G4tgrPlaceDivRep* pl = new G4tgrPlaceDivRep( << 197 G4tgrPlaceDivRep* pl = new G4tgrPlaceDivRep( wl ); 181 pl->SetType("PlaceReplica"); 198 pl->SetType("PlaceReplica"); 182 pl->SetVolume(this); << 199 pl->SetVolume( this ); 183 thePlacements.push_back(pl); << 200 thePlacements.push_back( pl ); 184 201 185 #ifdef G4VERBOSE 202 #ifdef G4VERBOSE 186 if(G4tgrMessenger::GetVerboseLevel() >= 2) << 203 if( G4tgrMessenger::GetVerboseLevel() >= 2 ) 187 { 204 { 188 G4cout << " G4tgrVolume: New placement re 205 G4cout << " G4tgrVolume: New placement replica: " << thePlacements.size() 189 << " added for Volume " << theName << 206 << " added for Volume " << theName 190 << pl->GetParentName() << G4endl; << 207 << " inside " << pl->GetParentName() << G4endl; 191 } 208 } 192 #endif 209 #endif 193 //---------- register parent - child << 210 //---------- register parent - child 194 G4tgrVolumeMgr::GetInstance()->RegisterParen << 211 G4tgrVolumeMgr::GetInstance()->RegisterParentChild( pl->GetParentName(), pl ); 195 212 196 return pl; 213 return pl; 197 } 214 } 198 215 199 // ------------------------------------------- << 216 >> 217 //------------------------------------------------------------- 200 G4tgrPlaceParameterisation* 218 G4tgrPlaceParameterisation* 201 G4tgrVolume::AddPlaceParam(const std::vector<G << 219 G4tgrVolume::AddPlaceParam( const std::vector<G4String>& wl ) 202 { 220 { 203 //---------- set G4tgrPlaceParameterisation 221 //---------- set G4tgrPlaceParameterisation 204 G4tgrPlaceParameterisation* pl = new G4tgrPl << 222 G4tgrPlaceParameterisation* pl = new G4tgrPlaceParameterisation( wl ); 205 223 206 pl->SetVolume(this); << 224 pl->SetVolume( this ); 207 thePlacements.push_back(pl); << 225 thePlacements.push_back( pl ); 208 226 209 #ifdef G4VERBOSE 227 #ifdef G4VERBOSE 210 if(G4tgrMessenger::GetVerboseLevel() >= 2) << 228 if( G4tgrMessenger::GetVerboseLevel() >= 2 ) 211 { 229 { 212 G4cout << " G4tgrVolume: New placement Pa 230 G4cout << " G4tgrVolume: New placement Param: " << thePlacements.size() 213 << " added for Volume " << theName << 231 << " added for Volume " << theName 214 << pl->GetParentName() << G4endl; << 232 << " inside " << pl->GetParentName() << G4endl; 215 } 233 } 216 #endif 234 #endif 217 //---------- register parent - child << 235 //---------- register parent - child 218 G4tgrVolumeMgr::GetInstance()->RegisterParen << 236 G4tgrVolumeMgr::GetInstance()->RegisterParentChild( pl->GetParentName(), pl ); 219 237 220 return pl; 238 return pl; 221 } 239 } 222 240 223 // ------------------------------------------- << 241 224 void G4tgrVolume::AddVisibility(const std::vec << 242 //------------------------------------------------------------- >> 243 void G4tgrVolume::AddVisibility( const std::vector<G4String>& wl ) 225 { 244 { 226 //---------- Check for exact number of words << 245 //---------- Check for exact number of words read 227 G4tgrUtils::CheckWLsize(wl, 3, WLSIZE_EQ, " << 246 G4tgrUtils::CheckWLsize( wl, 3, WLSIZE_EQ, " G4tgrVolume::AddVisibility"); 228 247 229 //---------- Set visibility 248 //---------- Set visibility 230 theVisibility = G4tgrUtils::GetBool(wl[2]); << 249 theVisibility = G4tgrUtils::GetBool( wl[2] ); 231 } 250 } 232 251 233 // ------------------------------------------- << 234 void G4tgrVolume::AddRGBColour(const std::vect << 235 { << 236 //---------- Check for exact number of words << 237 G4tgrUtils::CheckWLsize(wl, 5, WLSIZE_GE, " << 238 252 >> 253 //------------------------------------------------------------- >> 254 void G4tgrVolume::AddRGBColour( const std::vector<G4String>& wl ) >> 255 { >> 256 //---------- Check for exact number of words read >> 257 G4tgrUtils::CheckWLsize( wl, 5, WLSIZE_GE, " G4tgrVolume::AddRGBColour"); >> 258 239 //---------- Set RGB colour 259 //---------- Set RGB colour 240 theRGBColour[0] = G4tgrUtils::GetDouble(wl[2 << 260 theRGBColour[0] = G4tgrUtils::GetDouble( wl[2] ); 241 theRGBColour[1] = G4tgrUtils::GetDouble(wl[3 << 261 theRGBColour[1] = G4tgrUtils::GetDouble( wl[3] ); 242 theRGBColour[2] = G4tgrUtils::GetDouble(wl[4 << 262 theRGBColour[2] = G4tgrUtils::GetDouble( wl[4] ); 243 ///--------- Set transparency 263 ///--------- Set transparency 244 if(wl.size() == 6) << 264 if( wl.size() == 6 ) 245 { 265 { 246 theRGBColour[3] = G4tgrUtils::GetDouble(wl << 266 theRGBColour[3] = G4tgrUtils::GetDouble( wl[5] ); 247 } 267 } 248 } 268 } 249 269 250 // ------------------------------------------- << 270 251 void G4tgrVolume::AddCheckOverlaps(const std:: << 271 //------------------------------------------------------------- >> 272 void G4tgrVolume::AddCheckOverlaps( const std::vector<G4String>& wl ) 252 { 273 { 253 //---------- Check for exact number of words << 274 //---------- Check for exact number of words read 254 G4tgrUtils::CheckWLsize(wl, 3, WLSIZE_GE, " << 275 G4tgrUtils::CheckWLsize( wl, 3, WLSIZE_GE, " G4tgrVolume::AddCheckOverlaps"); >> 276 >> 277 ///--------- Set check overlaps >> 278 theCheckOverlaps = G4tgrUtils::GetBool( wl[2] ); 255 279 256 ///--------- Set check overlaps << 257 theCheckOverlaps = G4tgrUtils::GetBool(wl[2] << 258 } 280 } 259 281 260 // ------------------------------------------- << 282 >> 283 // ------------------------------------------------------------------------- 261 std::ostream& operator<<(std::ostream& os, con 284 std::ostream& operator<<(std::ostream& os, const G4tgrVolume& obj) 262 { 285 { 263 os << "G4tgrVolume= " << obj.theName << " Ty 286 os << "G4tgrVolume= " << obj.theName << " Type= " << obj.theType 264 << " Material= " << obj.theMaterialName < << 287 << " Material= " << obj.theMaterialName 265 << obj.theVisibility << " Colour " << (ob << 288 << " Visibility " << obj.theVisibility 266 << (obj.theRGBColour)[1] << " " << (obj.t << 289 << " Colour " << (obj.theRGBColour)[0] << " " 267 << (obj.theRGBColour)[3] << " " << 290 << (obj.theRGBColour)[1] << " " 268 << " CheckOverlaps " << obj.theCheckOverl << 291 << (obj.theRGBColour)[2] << " " 269 << obj.thePlacements.size() << G4endl; << 292 << (obj.theRGBColour)[3] << " " 270 << 293 << " CheckOverlaps " << obj.theCheckOverlaps >> 294 << " N placements " << obj.thePlacements.size() << G4endl; >> 295 271 return os; 296 return os; 272 } 297 } 273 298