Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4AdjointCrossSurfChecker.hh
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// G4AdjointCrossSurfChecker
27//
28// Class Description:
29//
30// This class is responsible for checking the crossing of a surface
31// that could be the external boundary of a volume or the external
32// surface of a sphere.
33// It is used to check if an adjoint particle reaches the external
34// surface or reenter the sensitive region delimited by the adjoint
35// source.
36
37// Author: L. Desorgher, SpaceIT GmbH - 15 January 2007
38// Contract: ESA contract 21435/08/NL/AT
39// Customer: ESA/ESTEC
40//---------------------------------------------------------------------
41#ifndef G4AdjointCrossSurfChecker_hh
42#define G4AdjointCrossSurfChecker_hh 1
43
44#include "globals.hh"
45#include "G4ThreeVector.hh"
46#include <vector>
47
48class G4Step;
49
51{
52 public:
53
55
56 G4bool CrossingASphere(const G4Step* aStep,
57 G4double sphere_radius,
58 G4ThreeVector sphere_center,
59 G4ThreeVector& cross_pos,
60 G4double& cos_to_surface,
61 G4bool& GoingIn);
62
64 const G4String& volume_name,
65 G4double& cos_to_surface,
66 G4bool& GoingIn);
67
69 const G4String& volume_name,
70 const G4String& mother_lvol_name,
71 G4double& cos_to_surface,
72 G4bool& GoingIn);
73
75 const G4String& surface_name,
76 G4ThreeVector& cross_pos,
77 G4double& cos_to_surface,
78 G4bool& GoingIn);
79
81 G4int ind,
82 G4ThreeVector& cross_pos,
83 G4double& cos_to_surface,
84 G4bool& GoingIn);
85
87 G4String& surface_name,
88 G4ThreeVector& cross_pos,
89 G4double& cos_to_surface,
90 G4bool& GoingIn);
91
93 const G4String& vol1_name,
94 const G4String& vol2_name,
95 G4ThreeVector& cross_pos,
96 G4double& cos_to_surface,
97 G4bool& GoingIn);
98
99 G4bool AddaSphericalSurface(const G4String& SurfaceName,
100 G4double radius,
101 G4ThreeVector pos,
102 G4double& area);
104 const G4String& SurfaceName,
105 G4double radius,
106 const G4String& volume_name,
107 G4ThreeVector& center,
108 G4double& area);
109 G4bool AddanExtSurfaceOfAvolume(const G4String& SurfaceName,
110 const G4String& volume_name,
111 G4double& area);
113 const G4String& volume_name1,
114 const G4String& volume_name2,
115 G4double& area);
117
118 private:
119
122
123 G4int FindRegisteredSurface(const G4String& name);
124
125 private:
126
128
129 std::vector<G4String> ListOfSurfaceName;
130 std::vector<G4String> ListOfSurfaceType;
131 std::vector<G4double> ListOfSphereRadius;
132 std::vector<G4ThreeVector> ListOfSphereCenter;
133 std::vector<G4String> ListOfVol1Name;
134 std::vector<G4String> ListOfVol2Name;
135 std::vector<G4double> AreaOfSurface;
136};
137
138#endif
double G4double
Definition: G4Types.hh:83
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
G4bool CrossingAGivenRegisteredSurface(const G4Step *aStep, const G4String &surface_name, G4ThreeVector &cross_pos, G4double &cos_to_surface, G4bool &GoingIn)
G4bool CrossingAnInterfaceBetweenTwoVolumes(const G4Step *aStep, const G4String &vol1_name, const G4String &vol2_name, G4ThreeVector &cross_pos, G4double &cos_to_surface, G4bool &GoingIn)
G4bool CrossingOneOfTheRegisteredSurface(const G4Step *aStep, G4String &surface_name, G4ThreeVector &cross_pos, G4double &cos_to_surface, G4bool &GoingIn)
G4bool AddaSphericalSurface(const G4String &SurfaceName, G4double radius, G4ThreeVector pos, G4double &area)
G4bool GoingInOrOutOfaVolumeByExtSurface(const G4Step *aStep, const G4String &volume_name, const G4String &mother_lvol_name, G4double &cos_to_surface, G4bool &GoingIn)
G4bool AddanExtSurfaceOfAvolume(const G4String &SurfaceName, const G4String &volume_name, G4double &area)
static G4AdjointCrossSurfChecker * GetInstance()
G4bool AddanInterfaceBetweenTwoVolumes(const G4String &SurfaceName, const G4String &volume_name1, const G4String &volume_name2, G4double &area)
G4bool AddaSphericalSurfaceWithCenterAtTheCenterOfAVolume(const G4String &SurfaceName, G4double radius, const G4String &volume_name, G4ThreeVector &center, G4double &area)
G4bool GoingInOrOutOfaVolume(const G4Step *aStep, const G4String &volume_name, G4double &cos_to_surface, G4bool &GoingIn)
G4bool CrossingASphere(const G4Step *aStep, G4double sphere_radius, G4ThreeVector sphere_center, G4ThreeVector &cross_pos, G4double &cos_to_surface, G4bool &GoingIn)
Definition: G4Step.hh:62
#define G4ThreadLocal
Definition: tls.hh:77