Geant4-11
G4TransportationManager.icc
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// G4TransportationManager inlined function members implementation
27//
28// Created : 10 March 1997, J. Apostolakis
29// Reviewed: 26 April 2006, G. Cosmo
30// ----------------------------------------------------------------------------
31
32// ----------------------------------------------------------------------------
33// GetNavigatorForTracking()
34//
35// Utility method to return the active navigator for tracking, always
36// the first in the collection of registered navigators.
37//
38inline
39G4Navigator* G4TransportationManager::GetNavigatorForTracking() const
40{
41 return fNavigators[0];
42}
43
44// ----------------------------------------------------------------------------
45// SetWorldForTracking()
46//
47// Set the tracking world volume.
48// This method is to be invoked by G4RunManagerKernel.
49//
50inline
51void G4TransportationManager::SetWorldForTracking(G4VPhysicalVolume* theWorld)
52{
53 fWorlds[0] = theWorld;
54 fNavigators[0]->SetWorldVolume(theWorld);
55}
56
57// ----------------------------------------------------------------------------
58// GetPropagatorInField()
59//
60// Return the associated propagator in field.
61//
62inline
63G4PropagatorInField* G4TransportationManager::GetPropagatorInField() const
64{
65 return fPropagatorInField;
66}
67
68// ----------------------------------------------------------------------------
69// SetPropagatorInField()
70//
71// Set the associated propagator in field.
72//
73inline
74void G4TransportationManager::
75SetPropagatorInField( G4PropagatorInField* newFieldPropagator )
76{
77 fPropagatorInField = newFieldPropagator;
78}
79
80// ----------------------------------------------------------------------------
81// GetFieldManager()
82//
83// Return the associated field manager.
84//
85inline
86G4FieldManager* G4TransportationManager::GetFieldManager() const
87{
88 return fFieldManager;
89}
90
91// ----------------------------------------------------------------------------
92// GetNoActiveNavigators()
93//
94// Return the number of active navigators.
95//
96inline
97size_t G4TransportationManager::GetNoActiveNavigators() const
98{
99 return fActiveNavigators.size();
100}
101
102// ----------------------------------------------------------------------------
103// GetActiveNavigatorsIterator()
104//
105// Return an iterator to the list of active navigators.
106//
107inline
108std::vector<G4Navigator*>::iterator
109G4TransportationManager::GetActiveNavigatorsIterator()
110{
111 std::vector<G4Navigator*>::iterator iterator
112 = std::vector<G4Navigator*>::iterator(fActiveNavigators.begin());
113 return iterator;
114}
115
116// ----------------------------------------------------------------------------
117// GetNoWorlds()
118//
119// Return the number of registerd worlds.
120//
121inline
122size_t G4TransportationManager::GetNoWorlds() const
123{
124 return fWorlds.size();
125}
126
127// ----------------------------------------------------------------------------
128// GetWorldsIterator()
129//
130// Return an iterator to the list of registered worlds.
131//
132inline
133std::vector<G4VPhysicalVolume*>::iterator
134G4TransportationManager::GetWorldsIterator()
135{
136 std::vector<G4VPhysicalVolume*>::iterator iterator
137 = std::vector<G4VPhysicalVolume*>::iterator(fWorlds.begin());
138 return iterator;
139}
140
141// ----------------------------------------------------------------------------
142// GetSafetyHelper()
143//
144// Return pointer to the created navigation safety helper instance.
145//
146inline
147G4SafetyHelper* G4TransportationManager::GetSafetyHelper() const
148{
149 return fSafetyHelper;
150}