Geant4-11
G4tgrVolumeAssembly.cc
Go to the documentation of this file.
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// G4tgrVolumeAssembly implementation
27//
28// Author: P.Arce, CIEMAT (November 2007)
29// --------------------------------------------------------------------
30
32#include "G4tgrUtils.hh"
33#include "G4tgrVolumeMgr.hh"
34#include "G4tgrPlaceSimple.hh"
35#include "G4tgrPlaceDivRep.hh"
37#include "G4tgrFileReader.hh"
38#include "G4tgrMessenger.hh"
39
40// --------------------------------------------------------------------
42{
43}
44
45// --------------------------------------------------------------------
47{
48}
49
50// --------------------------------------------------------------------
51G4tgrVolumeAssembly::G4tgrVolumeAssembly(const std::vector<G4String>& wl)
52{
53 theType = "VOLAssembly";
54
55 //---------- set name
57
58 G4int nVol = G4tgrUtils::GetInt(wl[2]);
59
60 G4tgrUtils::CheckWLsize(wl, 3 + nVol * 5, WLSIZE_GE,
61 "G4tgrVolumeAssembly::G4tgrVolumeAssembly");
62
63 for(G4int ii = 0; ii < nVol * 5; ii += 5)
64 {
65#ifdef G4VERBOSE
67 {
68 G4cout << " G4tgrVolumeAssembly::G4tgrVolumeAssembly() -"
69 << " Adding component: " << ii << " - " << wl[ii + 3] << G4endl;
70 }
71#endif
72 theComponentNames.push_back(G4tgrUtils::GetString(wl[3 + ii + 0]));
73 theComponentRMs.push_back(G4tgrUtils::GetString(wl[3 + ii + 1]));
74 theComponentPos.push_back(
76 G4tgrUtils::GetDouble(wl[3 + ii + 3]),
77 G4tgrUtils::GetDouble(wl[3 + ii + 4])));
78 }
79 theVisibility = 1;
80 theRGBColour = new G4double[4];
81 for(std::size_t ii = 0; ii < 4; ++ii)
82 {
83 theRGBColour[ii] = -1.;
84 }
85
86 theSolid = nullptr;
87
88#ifdef G4VERBOSE
90 {
91 G4cout << " Created " << *this << G4endl;
92 }
93#endif
94}
95
96// --------------------------------------------------------------------
97G4tgrPlace* G4tgrVolumeAssembly::AddPlace(const std::vector<G4String>& wl)
98{
99 //---------- Check for exact number of words read
100 G4tgrUtils::CheckWLsize(wl, 7, WLSIZE_EQ, " G4tgrVolumeAssembly::AddPlace");
101
102 //---------- set G4tgrPlace
104
105 pl->SetVolume(this);
106 thePlacements.push_back(pl);
107
108#ifdef G4VERBOSE
110 {
111 G4cout << " New placement: " << thePlacements.size()
112 << " added for Volume " << theName << " inside "
113 << pl->GetParentName() << " type " << pl->GetType() << G4endl;
114 }
115#endif
116 //---------- register parent - child
118
119 return pl;
120}
121
122// --------------------------------------------------------------------
123std::ostream& operator<<(std::ostream& os, const G4tgrVolumeAssembly& obj)
124{
125 os << "G4tgrVolumeAssembly= " << obj.theName;
126
127 for(std::size_t ii = 0; ii < obj.theComponentNames.size(); ++ii)
128 {
129 os << obj.theComponentNames[ii]
130 << " RotMatName= " << obj.theComponentRMs[ii]
131 << " Position= " << obj.theComponentPos[ii].x() << " "
132 << obj.theComponentPos[ii].y() << " " << obj.theComponentPos[ii].z();
133 }
134 os << G4endl;
135
136 return os;
137}
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition: G4Types.hh:83
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
@ WLSIZE_EQ
Definition: G4tgrUtils.hh:47
@ WLSIZE_GE
Definition: G4tgrUtils.hh:51
static G4int GetVerboseLevel()
const G4String & GetParentName() const
Definition: G4tgrPlace.hh:52
const G4String & GetType() const
Definition: G4tgrPlace.hh:55
void SetVolume(G4tgrVolume *vol)
Definition: G4tgrPlace.hh:56
static G4String GetString(const G4String &str)
Definition: G4tgrUtils.cc:173
static void CheckWLsize(const std::vector< G4String > &wl, unsigned int nWCheck, WLSIZEtype st, const G4String &methodName)
Definition: G4tgrUtils.cc:490
static G4int GetInt(const G4String &str)
Definition: G4tgrUtils.cc:447
static G4double GetDouble(const G4String &str, G4double unitval=1.)
Definition: G4tgrUtils.cc:198
std::vector< G4ThreeVector > theComponentPos
std::vector< G4String > theComponentRMs
std::vector< G4String > theComponentNames
virtual G4tgrPlace * AddPlace(const std::vector< G4String > &wl)
void RegisterParentChild(const G4String &parentName, const G4tgrPlace *pl)
static G4tgrVolumeMgr * GetInstance()
G4String theType
Definition: G4tgrVolume.hh:104
G4String theName
Definition: G4tgrVolume.hh:102
G4tgrSolid * theSolid
Definition: G4tgrVolume.hh:108
G4bool theVisibility
Definition: G4tgrVolume.hh:113
G4double * theRGBColour
Definition: G4tgrVolume.hh:114
std::vector< G4tgrPlace * > thePlacements
Definition: G4tgrVolume.hh:110
std::ostream & operator<<(std::ostream &, const BasicVector3D< float > &)