60 if (aStep ==
nullptr)
return false;
68#ifdef VERBOSE_ENERSPLIT
78 return (
G4int)theEnergies.size();
81 theEnergies.push_back(edep);
82 return (
G4int)theEnergies.size();
85 if (thePhantomParam ==
nullptr) GetPhantomParam(
true);
88 std::vector<std::pair<G4int, G4double>> rnsl =
93 G4double kinEnergyPre = kinEnergyPreOrig;
98 for (ii = 0; ii < rnsl.size(); ++ii) {
101#ifdef VERBOSE_ENERSPLIT
103 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter1 step length geom "
108#ifdef VERBOSE_ENERSPLIT
110 G4cout <<
"G4EnergySplitter RN: step length geom TOTAL " << slSum <<
" true TOTAL "
111 << stepLength <<
" ratio " << stepLength / slSum <<
" Energy "
118 if (theNIterations == 0) {
119 for (ii = 0; ii < rnsl.size(); ++ii) {
121 G4double edepStep = edep * sl / slSum;
123#ifdef VERBOSE_ENERSPLIT
125 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" edep " << edepStep <<
G4endl;
128 theEnergies.push_back(edepStep);
133#ifdef VERBOSE_ENERSPLIT
137 for (ii = 0; ii < rnsl.size(); ++ii) {
141 for (ii = 0; ii < rnsl.size(); ii++) {
142 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes " << ii
143 <<
" RN: iter0 corrected energy lost " << edep * rnsl[ii].second / slSum <<
G4endl;
148 G4double slRatio = stepLength / slSum;
149#ifdef VERBOSE_ENERSPLIT
151 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes RN: iter 0, step ratio " << slRatio
158 std::vector<G4double> stepLengths;
159 for (
G4int iiter = 1; iiter <= theNIterations; ++iiter) {
163 for (ii = 0; ii < rnsl.size(); ++ii) {
165 stepLengths.push_back(sl * slRatio);
166#ifdef VERBOSE_ENERSPLIT
168 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
169 <<
" corrected step length " << sl * slRatio <<
G4endl;
173 for (ii = 0; ii < rnsl.size(); ++ii) {
176 if (kinEnergyPre > 0.) {
177 dEdx = emcalc.
GetDEDX(kinEnergyPre, part, mate);
179 G4double elost = stepLengths[ii] * dEdx;
181#ifdef VERBOSE_ENERSPLIT
183 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter1 energy lost "
184 << elost <<
" energy at interaction " << kinEnergyPre <<
" = stepLength "
185 << stepLengths[ii] <<
" * dEdx " << dEdx <<
G4endl;
187 kinEnergyPre -= elost;
188 theEnergies.push_back(elost);
197 kinEnergyPre = kinEnergyPreOrig;
198 for (ii = 0; ii < rnsl.size(); ++ii) {
200 stepLengths[ii] = theElossExt->TrueStepLength(kinEnergyPre, rnsl[ii].second, mate, part);
201 kinEnergyPre -= theEnergies[ii];
203#ifdef VERBOSE_ENERSPLIT
205 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
206 <<
" step length geom " << stepLengths[ii] <<
" geom2true "
207 << rnsl[ii].second / stepLengths[ii] <<
G4endl;
210 slSum += stepLengths[ii];
215#ifdef VERBOSE_ENERSPLIT
217 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
218 <<
" step ratio " << slRatio <<
G4endl;
220 for (ii = 0; ii < rnsl.size(); ++ii) {
221 stepLengths[ii] *= slratio;
222#ifdef VERBOSE_ENERSPLIT
224 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
225 <<
" corrected step length " << stepLengths[ii] <<
G4endl;
232 for (ii = 0; ii < rnsl.size(); ++ii) {
235 if (kinEnergyPre > 0.) {
236 dEdx = emcalc.
GetDEDX(kinEnergyPre, part, mate);
238 G4double elost = stepLengths[ii] * dEdx;
239#ifdef VERBOSE_ENERSPLIT
241 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
242 <<
" energy lost " << elost <<
" energy at interaction " << kinEnergyPre
243 <<
" = stepLength " << stepLengths[ii] <<
" * dEdx " << dEdx <<
G4endl;
245 kinEnergyPre -= elost;
246 theEnergies[ii] = elost;
252 G4double enerRatio = (edep / totalELost);
254#ifdef VERBOSE_ENERSPLIT
256 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes" << ii <<
" RN: iter" << iiter
257 <<
" energy ratio " << enerRatio <<
G4endl;
260#ifdef VERBOSE_ENERSPLIT
263 for (ii = 0; ii < theEnergies.size(); ++ii) {
264 theEnergies[ii] *= enerRatio;
265#ifdef VERBOSE_ENERSPLIT
266 elostTot += theEnergies[ii];
268 G4cout <<
"G4EnergySplitter::SplitEnergyInVolumes " << ii <<
" RN: iter" << iiter
269 <<
" corrected energy lost " << theEnergies[ii] <<
" orig elost "
270 << theEnergies[ii] / enerRatio <<
" energy before interaction "
271 << kinEnergyPreOrig - elostTot + theEnergies[ii] <<
" energy after interaction "
272 << kinEnergyPreOrig - elostTot <<
G4endl;
278 return (
G4int)theEnergies.size();
G4double GetPDGCharge() const