Main Page
Namespaces
Classes
Package Documentation
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Pages
src
SimG4Core
PhysicsLists
plugins
QBBCCMS.cc
Go to the documentation of this file.
1
#include "QBBCCMS.hh"
2
#include "
SimG4Core/PhysicsLists/interface/CMSMonopolePhysics.h
"
3
#include "
FWCore/MessageLogger/interface/MessageLogger.h
"
4
5
#include "G4EmStandardPhysics_option1.hh"
6
#include "G4DecayPhysics.hh"
7
#include "G4EmExtraPhysics.hh"
8
#include "G4StoppingPhysics.hh"
9
#include "G4HadronicProcessStore.hh"
10
11
#include "G4DataQuestionaire.hh"
12
#include "G4HadronInelasticQBBC.hh"
13
#include "G4HadronElasticPhysicsXS.hh"
14
#include "G4IonPhysics.hh"
15
#include "G4NeutronTrackingCut.hh"
16
17
QBBCCMS::QBBCCMS(
G4LogicalVolumeToDDLogicalPartMap
&
map
,
18
const
HepPDT::ParticleDataTable
*
table_
,
19
sim::FieldBuilder
*fieldBuilder_,
20
const
edm::ParameterSet
&
p
) :
PhysicsList
(map, table_, fieldBuilder_, p) {
21
22
G4DataQuestionaire it(photon);
23
24
int
ver = p.
getUntrackedParameter
<
int
>(
"Verbosity"
,0);
25
bool
emPhys = p.
getUntrackedParameter
<
bool
>(
"EMPhysics"
,
true
);
26
bool
hadPhys = p.
getUntrackedParameter
<
bool
>(
"HadPhysics"
,
true
);
27
bool
tracking= p.
getParameter
<
bool
>(
"TrackingCut"
);
28
edm::LogInfo
(
"PhysicsList"
) <<
"You are using the simulation engine: "
29
<<
"QBBC with Flags for EM Physics "
30
<< emPhys <<
" and for Hadronic Physics "
31
<< hadPhys
32
<<
" and tracking cut "
<< tracking;
33
34
if
(emPhys) {
35
// EM Physics
36
RegisterPhysics(
new
G4EmStandardPhysics_option1(ver));
37
38
// Synchroton Radiation & GN Physics
39
RegisterPhysics(
new
G4EmExtraPhysics(ver));
40
}
41
42
// Decays
43
RegisterPhysics(
new
G4DecayPhysics(ver));
44
45
if
(hadPhys) {
46
G4HadronicProcessStore::Instance()->SetVerbose(ver);
47
48
// Hadron Elastic scattering
49
RegisterPhysics(
new
G4HadronElasticPhysicsXS(ver));
50
51
// Hadron Physics
52
RegisterPhysics(
new
G4HadronInelasticQBBC(ver));
53
54
// Stopping Physics
55
RegisterPhysics(
new
G4StoppingPhysics(ver));
56
57
// Ion Physics
58
RegisterPhysics(
new
G4IonPhysics(ver));
59
60
// Neutron tracking cut
61
if
(tracking) {
62
RegisterPhysics(
new
G4NeutronTrackingCut(ver));
63
}
64
}
65
66
// Monopoles
67
RegisterPhysics(
new
CMSMonopolePhysics
(table_,fieldBuilder_,p));
68
}
69
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
edm::ParameterSet::getUntrackedParameter
T getUntrackedParameter(std::string const &, T const &) const
MessageLogger.h
ParticleDataTable
HepPDT::ParticleDataTable ParticleDataTable
Definition:
ParticleDataTable.h:9
sim::FieldBuilder
Definition:
FieldBuilder.h:19
Association.map
dictionary map
Definition:
Association.py:205
PhysicsList
Definition:
PhysicsList.h:13
DDMapper< G4LogicalVolume *, DDLogicalPart >
edm::LogInfo
Definition:
MessageLogger.h:214
AlCaHLTBitMon_ParallelJobs.p
tuple p
Definition:
AlCaHLTBitMon_ParallelJobs.py:152
CMSMonopolePhysics
Definition:
CMSMonopolePhysics.h:15
CMSMonopolePhysics.h
edm::ParameterSet
Definition:
ParameterSet.h:35
table_
Table table_
Definition:
Actions.cc:22
Generated for CMSSW Reference Manual by
1.8.5