89{
90 auto xs = new G4ChargeExchangeXS();
91 xs->SetEnergyLimit(fLowEnergyLimit);
92 xs->SetCrossSectionFactor(fXSFactor);
93
94 auto model = new G4ChargeExchange(xs);
95
97 G4cout <<
"### ChargeExchangePhysics Construct Processes with the model <"
98 << model->GetModelName() << "> and x-section <"
99 << xs->GetName() << "> XSFactor=" << fXSFactor
101 }
102
103
105 auto proc =
106 new G4HadronInelasticProcess(part->
GetParticleName()+
"ChargeEx", part);
107 proc->AddDataSet( xs );
108 proc->RegisterMe( model );
111
112
114 proc =
new G4HadronInelasticProcess(part->
GetParticleName()+
"ChargeEx", part);
115 proc->AddDataSet( xs );
116 proc->RegisterMe( model );
119
120
122 proc =
new G4HadronInelasticProcess(part->
GetParticleName()+
"ChargeEx", part);
123 proc->AddDataSet( xs );
124 proc->RegisterMe( model );
127
128
129
131 proc =
new G4HadronInelasticProcess(part->
GetParticleName()+
"ChargeEx", part);
132 proc->AddDataSet( xs );
133 proc->RegisterMe( model );
136
137
139 proc =
new G4HadronInelasticProcess(part->
GetParticleName()+
"ChargeEx", part);
140 proc->AddDataSet( xs );
141 proc->RegisterMe( model );
144}
static G4KaonMinus * KaonMinus()
static G4KaonPlus * KaonPlus()
static G4KaonZeroLong * KaonZeroLong()
G4ProcessManager * GetProcessManager() const
const G4String & GetParticleName() const
static G4PionMinus * PionMinus()
static G4PionPlus * PionPlus()
G4int AddDiscreteProcess(G4VProcess *aProcess, G4int ord=ordDefault)
G4int GetVerboseLevel() const