File indexing completed on 2025-02-23 09:20:45
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029 #include "GB01BOptrMultiParticleChangeCrossSection.hh"
0030
0031 #include "GB01BOptrChangeCrossSection.hh"
0032
0033 #include "G4BiasingProcessInterface.hh"
0034 #include "G4ParticleDefinition.hh"
0035 #include "G4ParticleTable.hh"
0036 #include "G4SystemOfUnits.hh"
0037
0038
0039
0040 GB01BOptrMultiParticleChangeCrossSection::GB01BOptrMultiParticleChangeCrossSection()
0041 : G4VBiasingOperator("TestManyExponentialTransform")
0042 {}
0043
0044
0045
0046 void GB01BOptrMultiParticleChangeCrossSection::AddParticle(G4String particleName)
0047 {
0048 const G4ParticleDefinition* particle =
0049 G4ParticleTable::GetParticleTable()->FindParticle(particleName);
0050
0051 if (particle == 0) {
0052 G4ExceptionDescription ed;
0053 ed << "Particle `" << particleName << "' not found !" << G4endl;
0054 G4Exception("GB01BOptrMultiParticleChangeCrossSection::AddParticle(...)", "exGB01.02",
0055 JustWarning, ed);
0056 return;
0057 }
0058
0059 GB01BOptrChangeCrossSection* optr = new GB01BOptrChangeCrossSection(particleName);
0060 fParticlesToBias.push_back(particle);
0061 fBOptrForParticle[particle] = optr;
0062 }
0063
0064
0065
0066 G4VBiasingOperation* GB01BOptrMultiParticleChangeCrossSection::ProposeOccurenceBiasingOperation(
0067 const G4Track* track, const G4BiasingProcessInterface* callingProcess)
0068 {
0069
0070
0071 if (track->GetParentID() != 0) return 0;
0072
0073 if (fnInteractions > 4) return 0;
0074
0075 if (track->GetWeight() < 0.05) return 0;
0076
0077 if (fCurrentOperator)
0078 return fCurrentOperator->GetProposedOccurenceBiasingOperation(track, callingProcess);
0079 else
0080 return 0;
0081 }
0082
0083
0084
0085 void GB01BOptrMultiParticleChangeCrossSection::StartTracking(const G4Track* track)
0086 {
0087
0088 const G4ParticleDefinition* definition = track->GetParticleDefinition();
0089 std::map<const G4ParticleDefinition*, GB01BOptrChangeCrossSection*>::iterator it =
0090 fBOptrForParticle.find(definition);
0091 fCurrentOperator = 0;
0092 if (it != fBOptrForParticle.end()) fCurrentOperator = (*it).second;
0093
0094
0095 fnInteractions = 0;
0096 }
0097
0098
0099
0100 void GB01BOptrMultiParticleChangeCrossSection::OperationApplied(
0101 const G4BiasingProcessInterface* callingProcess, G4BiasingAppliedCase biasingCase,
0102 G4VBiasingOperation* occurenceOperationApplied, G4double weightForOccurenceInteraction,
0103 G4VBiasingOperation* finalStateOperationApplied, const G4VParticleChange* particleChangeProduced)
0104 {
0105
0106 fnInteractions++;
0107
0108
0109 if (fCurrentOperator)
0110 fCurrentOperator->ReportOperationApplied(callingProcess, biasingCase, occurenceOperationApplied,
0111 weightForOccurenceInteraction,
0112 finalStateOperationApplied, particleChangeProduced);
0113 }
0114
0115