1 |
|
2 |
#include "MuonPhysics.hh" |
3 |
|
4 |
#include "globals.hh" |
5 |
#include "G4ios.hh" |
6 |
|
7 |
|
8 |
|
9 |
MuonPhysics::MuonPhysics(const G4String& name) |
10 |
: G4VPhysicsConstructor(name) |
11 |
{ |
12 |
} |
13 |
|
14 |
MuonPhysics::~MuonPhysics() |
15 |
{ |
16 |
} |
17 |
|
18 |
#include "G4ParticleDefinition.hh" |
19 |
#include "G4ParticleTable.hh" |
20 |
|
21 |
#include "G4MuonPlus.hh" |
22 |
#include "G4MuonMinus.hh" |
23 |
#include "G4TauMinus.hh" |
24 |
#include "G4TauPlus.hh" |
25 |
#include "G4NeutrinoTau.hh" |
26 |
#include "G4AntiNeutrinoTau.hh" |
27 |
#include "G4NeutrinoMu.hh" |
28 |
#include "G4AntiNeutrinoMu.hh" |
29 |
|
30 |
void MuonPhysics::ConstructParticle() |
31 |
{ |
32 |
// Mu |
33 |
G4MuonPlus::MuonPlusDefinition(); |
34 |
G4MuonMinus::MuonMinusDefinition(); |
35 |
G4NeutrinoMu::NeutrinoMuDefinition(); |
36 |
G4AntiNeutrinoMu::AntiNeutrinoMuDefinition(); |
37 |
|
38 |
// Tau |
39 |
G4TauMinus::TauMinusDefinition(); |
40 |
G4TauPlus::TauPlusDefinition(); |
41 |
G4NeutrinoTau::NeutrinoTauDefinition(); |
42 |
G4AntiNeutrinoTau::AntiNeutrinoTauDefinition(); |
43 |
|
44 |
} |
45 |
|
46 |
|
47 |
#include "G4ProcessManager.hh" |
48 |
|
49 |
void MuonPhysics::ConstructProcess() |
50 |
{ |
51 |
G4ProcessManager * pManager = 0; |
52 |
|
53 |
// Muon Plus Physics |
54 |
pManager = G4MuonPlus::MuonPlus()->GetProcessManager(); |
55 |
// add processes |
56 |
pManager->AddProcess(&fMuPlusIonisation, ordInActive,2, 2); |
57 |
|
58 |
pManager->AddDiscreteProcess(&fMuPlusBremsstrahlung); |
59 |
|
60 |
pManager->AddDiscreteProcess(&fMuPlusPairProduction); |
61 |
|
62 |
pManager->AddProcess(&fMuPlusMultipleScattering); |
63 |
pManager->SetProcessOrdering(&fMuPlusMultipleScattering, idxAlongStep, 1); |
64 |
pManager->SetProcessOrdering(&fMuPlusMultipleScattering, idxPostStep, 1); |
65 |
|
66 |
// Muon Minus Physics |
67 |
pManager = G4MuonMinus::MuonMinus()->GetProcessManager(); |
68 |
// add processes |
69 |
pManager->AddProcess(&fMuMinusIonisation, ordInActive,2, 2); |
70 |
|
71 |
pManager->AddDiscreteProcess(&fMuMinusBremsstrahlung); |
72 |
|
73 |
pManager->AddDiscreteProcess(&fMuMinusPairProduction); |
74 |
|
75 |
pManager->AddProcess(&fMuMinusMultipleScattering); |
76 |
pManager->SetProcessOrdering(&fMuMinusMultipleScattering, idxAlongStep, 1); |
77 |
pManager->SetProcessOrdering(&fMuMinusMultipleScattering, idxPostStep, 1); |
78 |
pManager->AddRestProcess(&fMuMinusCaptureAtRest); |
79 |
|
80 |
// Tau Plus Physics |
81 |
pManager = G4TauPlus::TauPlus()->GetProcessManager(); |
82 |
// add processes |
83 |
pManager->AddProcess(&fTauPlusIonisation, ordInActive,2, 2); |
84 |
|
85 |
pManager->AddProcess(&fTauPlusMultipleScattering); |
86 |
pManager->SetProcessOrdering(&fTauPlusMultipleScattering, idxAlongStep, 1); |
87 |
pManager->SetProcessOrdering(&fTauPlusMultipleScattering, idxPostStep, 1); |
88 |
|
89 |
// Tau Minus Physics |
90 |
pManager = G4TauMinus::TauMinus()->GetProcessManager(); |
91 |
// add processes |
92 |
pManager->AddProcess(&fTauMinusIonisation, ordInActive,2, 2); |
93 |
|
94 |
pManager->AddProcess(&fTauMinusMultipleScattering); |
95 |
pManager->SetProcessOrdering(&fTauMinusMultipleScattering, idxAlongStep, 1); |
96 |
pManager->SetProcessOrdering(&fTauMinusMultipleScattering, idxPostStep, 1); |
97 |
|
98 |
} |
99 |
|
100 |
|
101 |
|