ECCE @ EIC Software
Reference for
ECCE @ EIC
simulation and reconstruction software on GitHub
Home page
Related Pages
Modules
Namespaces
Classes
Files
External Links
File List
File Members
ECCE @ EIC Software
Deprecated List
Modules
Namespaces
Classes
Files
File List
acts
analysis
coresoftware
Doxygen_Assist
ecce-detectors
fun4all_eicdetectors
geant4
macros
blob
master
common
DisplayOn.C
ECCEStyle.C
ECCEStyle.h
G4_Aerogel.C
G4_AllSilicon.C
G4_B0ECAL.C
G4_B0Tracking_EIC.C
G4_Barrel_EIC.C
G4_Bbc.C
G4_BECAL.C
G4_BlackHole.C
G4_BMMG.C
G4_BToF.C
G4_BWD.C
G4_CEmc_Albedo.C
G4_CEmc_EIC.C
G4_CEmc_Spacal.C
G4_DIRC.C
G4_DRCALO.C
G4_dRICH.C
G4_DSTReader_EICDetector.C
G4_EEMC.C
G4_EEMC_hybrid.C
G4_EHCAL.C
G4_EToF.C
G4_EventEvaluator.C
G4_FEMC.C
G4_FEMC_EIC.C
G4_FHCAL.C
G4_FST_EIC.C
G4_FwdJets.C
G4_GEM_EIC.C
G4_Global.C
G4_HcalIn_ref.C
G4_HcalOut_ref.C
G4_hFarBwdBeamLine_EIC.C
G4_hFarFwdBeamLine_EIC.C
G4_HToF.C
G4_Input.C
G4_Jets.C
G4_KFParticle.C
G4_LFHCAL.C
G4_Magnet.C
G4_Micromegas.C
G4_mRICH.C
G4_mRwell_EIC.C
G4_Mvtx_EIC.C
G4_ParticleFlow.C
G4_Pipe.C
G4_Pipe_EIC.C
G4_Piston.C
G4_PlugDoor.C
G4_PlugDoor_EIC.C
G4_Production.C
G4_PSTOF.C
G4_RICH.C
G4_TopoClusterReco.C
G4_TPC_EIC.C
G4_Tracking_EIC.C
G4_TrackingSupport.C
G4_TRD.C
G4_TTL_EIC.C
G4_User.C
G4_World.C
GlobalVariables.C
QA.C
sPhenixStyle.C
sPhenixStyle.h
detectors
online_distribution
tutorials
doxygen_mainpage.h
File Members
External Links
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
G4_World.C
Go to the documentation of this file.
Or view
the newest version in sPHENIX GitHub for file G4_World.C
1
#ifndef MACRO_G4WORLD_C
2
#define MACRO_G4WORLD_C
3
4
#include <
GlobalVariables.C
>
5
6
#include <
g4main/PHG4Reco.h
>
7
8
R__LOAD_LIBRARY
(libg4testbench.so)
9
10
namespace G4WORLD
11
{
12
double
AddSpace
= 100.;
// add this much space in cm around edge of detector
13
string
WorldMaterial
=
"G4_AIR"
;
// default world material, use G4_Galactic for material scan
14
string
PhysicsList
=
"FTFP_BERT"
;
// for calorimeters use HP lists
15
}
// namespace G4WORLD
16
17
void
WorldInit
(
PHG4Reco
*g4Reco)
18
{
19
g4Reco->
SetWorldMaterial
(
G4WORLD::WorldMaterial
);
20
g4Reco->
SetPhysicsList
(
G4WORLD::PhysicsList
);
21
}
22
23
void
WorldSize
(
PHG4Reco
*g4Reco,
double
radius
)
24
{
25
double
world_radius =
std::max
((
BlackHoleGeometry::max_radius
+
BlackHoleGeometry::gap
), radius);
26
g4Reco->
SetWorldSizeY
(
std::max
(g4Reco->
GetWorldSizeY
(), world_radius +
G4WORLD::AddSpace
));
27
// our world is a symmetric cylinder so the center is at 0/0/0, pick the largest of abs(min_z) || abs(max_z)
28
double
min_zval =
std::min
((
BlackHoleGeometry::min_z
-
BlackHoleGeometry::gap
), -((g4Reco->
GetWorldSizeZ
() - 100) / 2.));
29
double
max_zval =
std::max
((
BlackHoleGeometry::max_z
+
BlackHoleGeometry::gap
), (g4Reco->
GetWorldSizeZ
() - 100) / 2.);
30
double
final_zval =
std::max
(fabs(min_zval), fabs(max_zval)) +
G4WORLD::AddSpace
;
31
g4Reco->
SetWorldSizeZ
(
std::max
(g4Reco->
GetWorldSizeZ
(), 2 * (final_zval)));
32
return
;
33
}
34
#endif
macros
blob
master
common
G4_World.C
Built by
Jin Huang
. updated:
Wed Jun 29 2022 17:25:58
using
1.8.2 with
ECCE GitHub integration