Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/processes/hadronic/models/de_excitation/ablation/src/G4WilsonAblationModel.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /processes/hadronic/models/de_excitation/ablation/src/G4WilsonAblationModel.cc (Version 11.3.0) and /processes/hadronic/models/de_excitation/ablation/src/G4WilsonAblationModel.cc (Version 11.2)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
 10 // *                                               10 // *                                                                  *
 11 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                               17 // *                                                                  *
 18 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 20 // *                                               20 // *                                                                  *
 21 // * Parts of this code which have been  devel     21 // * Parts of this code which have been  developed by QinetiQ Ltd     *
 22 // * under contract to the European Space Agen     22 // * under contract to the European Space Agency (ESA) are the        *
 23 // * intellectual property of ESA. Rights to u     23 // * intellectual property of ESA. Rights to use, copy, modify and    *
 24 // * redistribute this software for general pu     24 // * redistribute this software for general public use are granted    *
 25 // * in compliance with any licensing, distrib     25 // * in compliance with any licensing, distribution and development   *
 26 // * policy adopted by the Geant4 Collaboratio     26 // * policy adopted by the Geant4 Collaboration. This code has been   *
 27 // * written by QinetiQ Ltd for the European S     27 // * written by QinetiQ Ltd for the European Space Agency, under ESA  *
 28 // * contract 17191/03/NL/LvH (Aurora Programm     28 // * contract 17191/03/NL/LvH (Aurora Programme).                     *
 29 // *                                               29 // *                                                                  *
 30 // * By using,  copying,  modifying or  distri     30 // * By using,  copying,  modifying or  distributing the software (or *
 31 // * any work based  on the software)  you  ag     31 // * any work based  on the software)  you  agree  to acknowledge its *
 32 // * use  in  resulting  scientific  publicati     32 // * use  in  resulting  scientific  publications,  and indicate your *
 33 // * acceptance of all terms of the Geant4 Sof     33 // * acceptance of all terms of the Geant4 Software license.          *
 34 // *******************************************     34 // ********************************************************************
 35 //                                                 35 //
 36 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%     36 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 37 //                                                 37 //
 38 // MODULE:              G4WilsonAblationModel.     38 // MODULE:              G4WilsonAblationModel.cc
 39 //                                                 39 //
 40 // Version:   1.0                                  40 // Version:   1.0
 41 // Date:    08/12/2009                             41 // Date:    08/12/2009
 42 // Author:    P R Truscott                         42 // Author:    P R Truscott
 43 // Organisation:  QinetiQ Ltd, UK                  43 // Organisation:  QinetiQ Ltd, UK
 44 // Customer:    ESA/ESTEC, NOORDWIJK               44 // Customer:    ESA/ESTEC, NOORDWIJK
 45 // Contract:    17191/03/NL/LvH                    45 // Contract:    17191/03/NL/LvH
 46 //                                                 46 //
 47 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%     47 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 48 //                                                 48 //
 49 // CHANGE HISTORY                                  49 // CHANGE HISTORY
 50 // --------------                                  50 // --------------
 51 //                                                 51 //
 52 // 6 October 2003, P R Truscott, QinetiQ Ltd,      52 // 6 October 2003, P R Truscott, QinetiQ Ltd, UK
 53 // Created.                                        53 // Created.
 54 //                                                 54 //
 55 // 15 March 2004, P R Truscott, QinetiQ Ltd, U     55 // 15 March 2004, P R Truscott, QinetiQ Ltd, UK
 56 // Beta release                                    56 // Beta release
 57 //                                                 57 //
 58 // 08 December 2009, P R Truscott, QinetiQ Ltd     58 // 08 December 2009, P R Truscott, QinetiQ Ltd, UK
 59 // Ver 1.0                                         59 // Ver 1.0
 60 // Updated as a result of changes in the G4Eva     60 // Updated as a result of changes in the G4Evaporation classes.  These changes
 61 // affect mostly SelectSecondariesByEvaporatio     61 // affect mostly SelectSecondariesByEvaporation, and now you have variables
 62 // associated with the evaporation model which     62 // associated with the evaporation model which can be changed:
 63 //    OPTxs to select the inverse cross-sectio     63 //    OPTxs to select the inverse cross-section
 64 //    OPTxs = 0      => Dostrovski's parameter     64 //    OPTxs = 0      => Dostrovski's parameterization
 65 //    OPTxs = 1 or 2 => Chatterjee's paramater     65 //    OPTxs = 1 or 2 => Chatterjee's paramaterization
 66 //    OPTxs = 3 or 4 => Kalbach's parameteriza     66 //    OPTxs = 3 or 4 => Kalbach's parameterization
 67 //    useSICB        => use superimposed Coulo     67 //    useSICB        => use superimposed Coulomb Barrier for inverse cross
 68 //                      sections                   68 //                      sections
 69 // Other problem found with G4Fragment definit     69 // Other problem found with G4Fragment definition using Lorentz vector and
 70 // **G4ParticleDefinition**.  This does not al     70 // **G4ParticleDefinition**.  This does not allow A and Z to be defined for the
 71 // fragment for some reason.  Now the fragment     71 // fragment for some reason.  Now the fragment is defined more explicitly:
 72 //    G4Fragment *fragment = new G4Fragment(A,     72 //    G4Fragment *fragment = new G4Fragment(A, Z, lorentzVector);
 73 // to avoid this quirk.  Bug found in SelectSe     73 // to avoid this quirk.  Bug found in SelectSecondariesByDefault: *type is now
 74 // equated to evapType[i] whereas previously i     74 // equated to evapType[i] whereas previously it was equated to fragType[i].
 75 //                                                 75 // 
 76 // 06 August 2015, A. Ribon, CERN                  76 // 06 August 2015, A. Ribon, CERN
 77 // Migrated std::exp and std::pow to the faste     77 // Migrated std::exp and std::pow to the faster G4Exp and G4Pow.
 78 //                                                 78 //
 79 // 09 June 2017, C. Mancini Terracciano, INFN      79 // 09 June 2017, C. Mancini Terracciano, INFN
 80 // Fixed bug on the initialization of Photon E     80 // Fixed bug on the initialization of Photon Evaporation model
 81 //                                                 81 //
 82 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%     82 // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 83 //////////////////////////////////////////////     83 ////////////////////////////////////////////////////////////////////////////////
 84 //                                                 84 //
 85 #include <iomanip>                                 85 #include <iomanip>
 86 #include <numeric>                                 86 #include <numeric>
 87                                                    87 
 88 #include "G4WilsonAblationModel.hh"                88 #include "G4WilsonAblationModel.hh"
 89 #include "G4PhysicalConstants.hh"                  89 #include "G4PhysicalConstants.hh"
 90 #include "G4SystemOfUnits.hh"                      90 #include "G4SystemOfUnits.hh"
 91 #include "Randomize.hh"                            91 #include "Randomize.hh"
 92 #include "G4ParticleTable.hh"                      92 #include "G4ParticleTable.hh"
 93 #include "G4IonTable.hh"                           93 #include "G4IonTable.hh"
 94 #include "G4Alpha.hh"                              94 #include "G4Alpha.hh"
 95 #include "G4He3.hh"                                95 #include "G4He3.hh"
 96 #include "G4Triton.hh"                             96 #include "G4Triton.hh"
 97 #include "G4Deuteron.hh"                           97 #include "G4Deuteron.hh"
 98 #include "G4Proton.hh"                             98 #include "G4Proton.hh"
 99 #include "G4Neutron.hh"                            99 #include "G4Neutron.hh"
100 #include "G4AlphaEvaporationChannel.hh"           100 #include "G4AlphaEvaporationChannel.hh"
101 #include "G4He3EvaporationChannel.hh"             101 #include "G4He3EvaporationChannel.hh"
102 #include "G4TritonEvaporationChannel.hh"          102 #include "G4TritonEvaporationChannel.hh"
103 #include "G4DeuteronEvaporationChannel.hh"        103 #include "G4DeuteronEvaporationChannel.hh"
104 #include "G4ProtonEvaporationChannel.hh"          104 #include "G4ProtonEvaporationChannel.hh"
105 #include "G4NeutronEvaporationChannel.hh"         105 #include "G4NeutronEvaporationChannel.hh"
106 #include "G4PhotonEvaporation.hh"                 106 #include "G4PhotonEvaporation.hh"
107 #include "G4LorentzVector.hh"                     107 #include "G4LorentzVector.hh"
108 #include "G4VEvaporationChannel.hh"               108 #include "G4VEvaporationChannel.hh"
109                                                   109 
110 #include "G4Exp.hh"                               110 #include "G4Exp.hh"
111 #include "G4Pow.hh"                               111 #include "G4Pow.hh"
112                                                   112 
113 #include "G4PhysicsModelCatalog.hh"               113 #include "G4PhysicsModelCatalog.hh"
114                                                   114 
115 //////////////////////////////////////////////    115 ////////////////////////////////////////////////////////////////////////////////
116 //                                                116 //
117 G4WilsonAblationModel::G4WilsonAblationModel()    117 G4WilsonAblationModel::G4WilsonAblationModel()
118 {                                                 118 {
119 //                                                119 //
120 //                                                120 //
121 // Send message to stdout to advise that the G    121 // Send message to stdout to advise that the G4Abrasion model is being used.
122 //                                                122 //
123   PrintWelcomeMessage();                          123   PrintWelcomeMessage();
124 //                                                124 //
125 //                                                125 //
126 // Set the default verbose level to 0 - no out    126 // Set the default verbose level to 0 - no output.
127 //                                                127 //
128   verboseLevel = 0;                               128   verboseLevel = 0;  
129 //                                                129 //
130 //                                                130 //
131 // Set the binding energy per nucleon .... did    131 // Set the binding energy per nucleon .... did I mention that this is a crude
132 // model for nuclear de-excitation?               132 // model for nuclear de-excitation?
133 //                                                133 //
134   B = 10.0 * MeV;                                 134   B = 10.0 * MeV;
135 //                                                135 //
136 //                                                136 //
137 // It is possuble to switch off secondary part    137 // It is possuble to switch off secondary particle production (other than the
138 // final nuclear fragment).  The default is on    138 // final nuclear fragment).  The default is on.
139 //                                                139 //
140   produceSecondaries = true;                      140   produceSecondaries = true;
141 //                                                141 //
142 //                                                142 //
143 // Now we need to define the decay modes.  We'    143 // Now we need to define the decay modes.  We're using the G4Evaporation model
144 // to help determine the kinematics of the dec    144 // to help determine the kinematics of the decay.
145 //                                                145 //
146   nFragTypes  = 6;                                146   nFragTypes  = 6;
147   fragType[0] = G4Alpha::Alpha();                 147   fragType[0] = G4Alpha::Alpha();
148   fragType[1] = G4He3::He3();                     148   fragType[1] = G4He3::He3();
149   fragType[2] = G4Triton::Triton();               149   fragType[2] = G4Triton::Triton();
150   fragType[3] = G4Deuteron::Deuteron();           150   fragType[3] = G4Deuteron::Deuteron();
151   fragType[4] = G4Proton::Proton();               151   fragType[4] = G4Proton::Proton();
152   fragType[5] = G4Neutron::Neutron();             152   fragType[5] = G4Neutron::Neutron();
153   for(G4int i=0; i<200; ++i) { fSig[i] = 0.0;     153   for(G4int i=0; i<200; ++i) { fSig[i] = 0.0; }
154 //                                                154 //
155 //                                                155 //
156 // Set verboseLevel default to no output.         156 // Set verboseLevel default to no output.
157 //                                                157 //
158   verboseLevel = 0;                               158   verboseLevel = 0;
159   theChannelFactory = new G4EvaporationFactory    159   theChannelFactory = new G4EvaporationFactory(new G4PhotonEvaporation());
160   theChannels = theChannelFactory->GetChannel(    160   theChannels = theChannelFactory->GetChannel();
161 //                                                161 //
162 //                                                162 //
163 // Set defaults for evaporation classes.  Thes    163 // Set defaults for evaporation classes.  These can be overridden by user
164 // "set" methods.                                 164 // "set" methods.
165 //                                                165 //
166   OPTxs   = 3;                                    166   OPTxs   = 3;
167   useSICB = false;                                167   useSICB = false;
168   fragmentVector = 0;                             168   fragmentVector = 0;
169                                                   169 
170   secID = G4PhysicsModelCatalog::GetModelID("m    170   secID = G4PhysicsModelCatalog::GetModelID("model_G4WilsonAblationModel");
171 }                                                 171 }
172 //////////////////////////////////////////////    172 ////////////////////////////////////////////////////////////////////////////////
173 //                                                173 //
174 G4WilsonAblationModel::~G4WilsonAblationModel(    174 G4WilsonAblationModel::~G4WilsonAblationModel()
175 {}                                                175 {}
176                                                   176 
177 //////////////////////////////////////////////    177 ////////////////////////////////////////////////////////////////////////////////
178 //                                                178 //
179 G4FragmentVector *G4WilsonAblationModel::Break    179 G4FragmentVector *G4WilsonAblationModel::BreakItUp
180   (const G4Fragment &theNucleus)                  180   (const G4Fragment &theNucleus)
181 {                                                 181 {
182 //                                                182 //
183 //                                                183 //
184 // Initilise the pointer to the G4FragmentVect    184 // Initilise the pointer to the G4FragmentVector used to return the information
185 // about the breakup.                             185 // about the breakup.
186 //                                                186 //
187   fragmentVector = new G4FragmentVector;          187   fragmentVector = new G4FragmentVector;
188   fragmentVector->clear();                        188   fragmentVector->clear();
189 //                                                189 //
190 //                                                190 //
191 // Get the A, Z and excitation of the nucleus.    191 // Get the A, Z and excitation of the nucleus.
192 //                                                192 //
193   G4int A     = theNucleus.GetA_asInt();          193   G4int A     = theNucleus.GetA_asInt();
194   G4int Z     = theNucleus.GetZ_asInt();          194   G4int Z     = theNucleus.GetZ_asInt();
195   G4double ex = theNucleus.GetExcitationEnergy    195   G4double ex = theNucleus.GetExcitationEnergy();
196   if (verboseLevel >= 2)                          196   if (verboseLevel >= 2)
197   {                                               197   {
198     G4cout <<"oooooooooooooooooooooooooooooooo    198     G4cout <<"oooooooooooooooooooooooooooooooooooooooo"
199            <<"oooooooooooooooooooooooooooooooo    199            <<"oooooooooooooooooooooooooooooooooooooooo"
200            <<G4endl;                              200            <<G4endl;
201     G4cout.precision(6);                          201     G4cout.precision(6);
202     G4cout <<"IN G4WilsonAblationModel" <<G4en    202     G4cout <<"IN G4WilsonAblationModel" <<G4endl;
203     G4cout <<"Initial prefragment A=" <<A         203     G4cout <<"Initial prefragment A=" <<A
204            <<", Z=" <<Z                           204            <<", Z=" <<Z
205            <<", excitation energy = " <<ex/MeV    205            <<", excitation energy = " <<ex/MeV <<" MeV"
206            <<G4endl;                              206            <<G4endl; 
207   }                                               207   }
208 //                                                208 //
209 //                                                209 //
210 // Check that there is a nucleus to speak of.     210 // Check that there is a nucleus to speak of.  It's possible there isn't one
211 // or its just a proton or neutron.  In either    211 // or its just a proton or neutron.  In either case, the excitation energy
212 // (from the Lorentz vector) is not used.         212 // (from the Lorentz vector) is not used.
213 //                                                213 //
214   if (A == 0)                                     214   if (A == 0)
215   {                                               215   {
216     if (verboseLevel >= 2)                        216     if (verboseLevel >= 2)
217     {                                             217     {
218       G4cout <<"No nucleus to decay" <<G4endl;    218       G4cout <<"No nucleus to decay" <<G4endl;
219       G4cout <<"oooooooooooooooooooooooooooooo    219       G4cout <<"oooooooooooooooooooooooooooooooooooooooo"
220              <<"oooooooooooooooooooooooooooooo    220              <<"oooooooooooooooooooooooooooooooooooooooo"
221              <<G4endl;                            221              <<G4endl;
222     }                                             222     }
223     return fragmentVector;                        223     return fragmentVector;
224   }                                               224   }
225   else if (A == 1)                                225   else if (A == 1)
226   {                                               226   {
227     G4LorentzVector lorentzVector = theNucleus    227     G4LorentzVector lorentzVector = theNucleus.GetMomentum();
228     lorentzVector.setE(lorentzVector.e()-ex+10    228     lorentzVector.setE(lorentzVector.e()-ex+10.0*eV);
229     if (Z == 0)                                   229     if (Z == 0)
230     {                                             230     {
231       G4Fragment *fragment = new G4Fragment(lo    231       G4Fragment *fragment = new G4Fragment(lorentzVector,G4Neutron::Neutron());
232       if (fragment != nullptr) { fragment->Set    232       if (fragment != nullptr) { fragment->SetCreatorModelID(secID); }
233       fragmentVector->push_back(fragment);        233       fragmentVector->push_back(fragment);
234     }                                             234     }
235     else                                          235     else
236     {                                             236     {
237       G4Fragment *fragment = new G4Fragment(lo    237       G4Fragment *fragment = new G4Fragment(lorentzVector,G4Proton::Proton());
238       if (fragment != nullptr) { fragment->Set    238       if (fragment != nullptr) { fragment->SetCreatorModelID(secID); }
239       fragmentVector->push_back(fragment);        239       fragmentVector->push_back(fragment);
240     }                                             240     }
241     if (verboseLevel >= 2)                        241     if (verboseLevel >= 2)
242     {                                             242     {
243       G4cout <<"Final fragment is in fact only    243       G4cout <<"Final fragment is in fact only a nucleon) :" <<G4endl;
244       G4cout <<(*fragmentVector)[0] <<G4endl;     244       G4cout <<(*fragmentVector)[0] <<G4endl;
245       G4cout <<"oooooooooooooooooooooooooooooo    245       G4cout <<"oooooooooooooooooooooooooooooooooooooooo"
246              <<"oooooooooooooooooooooooooooooo    246              <<"oooooooooooooooooooooooooooooooooooooooo"
247              <<G4endl;                            247              <<G4endl;
248     }                                             248     }
249     return fragmentVector;                        249     return fragmentVector;
250   }                                               250   }
251 //                                                251 //
252 //                                                252 //
253 // Then the number of nucleons ablated (either    253 // Then the number of nucleons ablated (either as nucleons or light nuclear
254 // fragments) is based on a simple argument fo    254 // fragments) is based on a simple argument for the binding energy per nucleon.
255 //                                                255 //
256   G4int DAabl = (G4int) (ex / B);                 256   G4int DAabl = (G4int) (ex / B);
257   if (DAabl > A) DAabl = A;                       257   if (DAabl > A) DAabl = A;
258 // The following lines are no longer accurate     258 // The following lines are no longer accurate given we now treat the final fragment
259 //  if (verboseLevel >= 2)                        259 //  if (verboseLevel >= 2)
260 //    G4cout <<"Number of nucleons ejected = "    260 //    G4cout <<"Number of nucleons ejected = " <<DAabl <<G4endl;
261                                                   261 
262 //                                                262 //
263 //                                                263 //
264 // Determine the nuclear fragment from the abl    264 // Determine the nuclear fragment from the ablation process by sampling the
265 // Rudstam equation.                              265 // Rudstam equation.
266 //                                                266 //
267   G4int AF = A - DAabl;                           267   G4int AF = A - DAabl;
268   G4int ZF = 0;                                   268   G4int ZF = 0;
269                                                   269   
270   if (AF > 0)                                     270   if (AF > 0)
271   {                                               271   {
272     G4Pow* g4calc = G4Pow::GetInstance();         272     G4Pow* g4calc = G4Pow::GetInstance(); 
273     G4double AFd = (G4double) AF;                 273     G4double AFd = (G4double) AF;
274     G4double R = 11.8 / g4calc->powZ(AF, 0.45)    274     G4double R = 11.8 / g4calc->powZ(AF, 0.45);
275     G4int minZ = std::max(1, Z - DAabl);          275     G4int minZ = std::max(1, Z - DAabl);
276 //                                                276 //
277 //                                                277 //
278 // Here we define an integral probability dist    278 // Here we define an integral probability distribution based on the Rudstam
279 // equation assuming a constant AF.               279 // equation assuming a constant AF.
280 //                                                280 //    
281     G4int zmax = std::min(199, Z);                281     G4int zmax = std::min(199, Z);
282     G4double sum = 0.0;                           282     G4double sum = 0.0;
283     for (ZF=minZ; ZF<=zmax; ++ZF)                 283     for (ZF=minZ; ZF<=zmax; ++ZF)
284     {                                             284     {
285       sum += G4Exp(-R*g4calc->powA(std::abs(ZF    285       sum += G4Exp(-R*g4calc->powA(std::abs(ZF - 0.486*AFd + 3.8E-04*AFd*AFd),1.5));
286       fSig[ZF] = sum;                             286       fSig[ZF] = sum;
287     }                                             287     }
288 //                                                288 //
289 //                                                289 //
290 // Now sample that distribution to determine a    290 // Now sample that distribution to determine a value for ZF.
291 //                                                291 //
292     sum *= G4UniformRand();                       292     sum *= G4UniformRand();
293     for (ZF=minZ; ZF<=zmax; ++ZF) {               293     for (ZF=minZ; ZF<=zmax; ++ZF) {
294       if(sum <= fSig[ZF]) { break; }              294       if(sum <= fSig[ZF]) { break; }
295     }                                             295     } 
296   }                                               296   }
297   G4int DZabl = Z - ZF;                           297   G4int DZabl = Z - ZF;
298 //                                                298 //
299 //                                                299 //
300 // Now determine the nucleons or nuclei which     300 // Now determine the nucleons or nuclei which have bee ablated.  The preference
301 // is for the production of alphas, then other    301 // is for the production of alphas, then other nuclei in order of decreasing
302 // binding energy. The energies assigned to th    302 // binding energy. The energies assigned to the products of the decay are
303 // provisional for the moment (the 10eV is jus    303 // provisional for the moment (the 10eV is just to avoid errors with negative
304 // excitation energies due to rounding).          304 // excitation energies due to rounding).
305 //                                                305 //
306   G4double totalEpost = 0.0;                      306   G4double totalEpost = 0.0;
307   evapType.clear();                               307   evapType.clear();
308   for (G4int ift=0; ift<nFragTypes; ift++)        308   for (G4int ift=0; ift<nFragTypes; ift++)
309   {                                               309   {
310     G4ParticleDefinition *type = fragType[ift]    310     G4ParticleDefinition *type = fragType[ift];
311     G4double n  = std::floor((G4double) DAabl     311     G4double n  = std::floor((G4double) DAabl / type->GetBaryonNumber() + 1.0E-10);
312     G4double n1 = 1.0E+10;                        312     G4double n1 = 1.0E+10;
313     if (fragType[ift]->GetPDGCharge() > 0.0)      313     if (fragType[ift]->GetPDGCharge() > 0.0)
314       n1 = std::floor((G4double) DZabl / type-    314       n1 = std::floor((G4double) DZabl / type->GetPDGCharge() + 1.0E-10);
315     if (n > n1) n = n1;                           315     if (n > n1) n = n1;
316     if (n > 0.0)                                  316     if (n > 0.0)
317     {                                             317     {
318       G4double mass = type->GetPDGMass();         318       G4double mass = type->GetPDGMass();
319       for (G4int j=0; j<(G4int) n; j++)           319       for (G4int j=0; j<(G4int) n; j++)
320       {                                           320       {
321         totalEpost += mass;                       321         totalEpost += mass;
322         evapType.push_back(type);                 322         evapType.push_back(type);
323       }                                           323       }
324       DAabl -= (G4int) (n * type->GetBaryonNum    324       DAabl -= (G4int) (n * type->GetBaryonNumber() + 1.0E-10);
325       DZabl -= (G4int) (n * type->GetPDGCharge    325       DZabl -= (G4int) (n * type->GetPDGCharge() + 1.0E-10);
326     }                                             326     }
327   }                                               327   }
328 //                                                328 //
329 //                                                329 //
330 // Determine the properties of the final nucle    330 // Determine the properties of the final nuclear fragment.  Note that if
331 // the final fragment is predicted to have a n    331 // the final fragment is predicted to have a nucleon number of zero, then
332 // really it's the particle last in the vector    332 // really it's the particle last in the vector evapType which becomes the
333 // final fragment.  Therefore delete this from    333 // final fragment.  Therefore delete this from the vector if this is the
334 // case.                                          334 // case.
335 //                                                335 //
336   G4double massFinalFrag = 0.0;                   336   G4double massFinalFrag = 0.0;
337   if (AF > 0)                                     337   if (AF > 0)
338     massFinalFrag = G4ParticleTable::GetPartic    338     massFinalFrag = G4ParticleTable::GetParticleTable()->GetIonTable()->
339       GetIonMass(ZF,AF);                          339       GetIonMass(ZF,AF);
340   else                                            340   else
341   {                                               341   {
342     G4ParticleDefinition *type = evapType[evap    342     G4ParticleDefinition *type = evapType[evapType.size()-1];
343     AF                         = type->GetBary    343     AF                         = type->GetBaryonNumber();
344     ZF                         = (G4int) (type    344     ZF                         = (G4int) (type->GetPDGCharge() + 1.0E-10);
345     evapType.erase(evapType.end()-1);             345     evapType.erase(evapType.end()-1);
346   }                                               346   }
347   totalEpost   += massFinalFrag;                  347   totalEpost   += massFinalFrag;
348 //                                                348 //
349 //                                                349 //
350 // Provide verbose output on the nuclear fragm    350 // Provide verbose output on the nuclear fragment if requested.
351 //                                                351 //
352   if (verboseLevel >= 2)                          352   if (verboseLevel >= 2)
353   {                                               353   {
354     G4cout <<"Final fragment      A=" <<AF        354     G4cout <<"Final fragment      A=" <<AF
355            <<", Z=" <<ZF                          355            <<", Z=" <<ZF
356            <<G4endl;                              356            <<G4endl;
357     for (G4int ift=0; ift<nFragTypes; ift++)      357     for (G4int ift=0; ift<nFragTypes; ift++)
358     {                                             358     {
359       G4ParticleDefinition *type = fragType[if    359       G4ParticleDefinition *type = fragType[ift];
360       G4long n = std::count(evapType.cbegin(),    360       G4long n = std::count(evapType.cbegin(),evapType.cend(),type);
361       if (n > 0)                                  361       if (n > 0) 
362         G4cout <<"Particle type: " <<std::setw    362         G4cout <<"Particle type: " <<std::setw(10) <<type->GetParticleName()
363                <<", number of particles emitte    363                <<", number of particles emitted = " <<n <<G4endl;
364     }                                             364     }
365   }                                               365   }
366 //                                                366 //
367 // Add the total energy from the fragment.  No    367 // Add the total energy from the fragment.  Note that the fragment is assumed
368 // to be de-excited and does not undergo photo    368 // to be de-excited and does not undergo photo-evaporation .... I did mention
369 // this is a bit of a crude model?                369 // this is a bit of a crude model?
370 //                                                370 //
371   G4double massPreFrag      = theNucleus.GetGr    371   G4double massPreFrag      = theNucleus.GetGroundStateMass();
372   G4double totalEpre        = massPreFrag + ex    372   G4double totalEpre        = massPreFrag + ex;
373   G4double excess           = totalEpre - tota    373   G4double excess           = totalEpre - totalEpost;
374 //  G4Fragment *resultNucleus(theNucleus);        374 //  G4Fragment *resultNucleus(theNucleus);
375   G4Fragment *resultNucleus = new G4Fragment(A    375   G4Fragment *resultNucleus = new G4Fragment(A, Z, theNucleus.GetMomentum());
376   G4ThreeVector boost(0.0,0.0,0.0);               376   G4ThreeVector boost(0.0,0.0,0.0);
377   std::size_t nEvap = 0;                          377   std::size_t nEvap = 0;
378   if (produceSecondaries && evapType.size()>0)    378   if (produceSecondaries && evapType.size()>0)
379   {                                               379   {
380     if (excess > 0.0)                             380     if (excess > 0.0)
381     {                                             381     {
382       SelectSecondariesByEvaporation (resultNu    382       SelectSecondariesByEvaporation (resultNucleus);
383       nEvap = fragmentVector->size();             383       nEvap = fragmentVector->size();
384       boost = resultNucleus->GetMomentum().fin    384       boost = resultNucleus->GetMomentum().findBoostToCM();
385       if (evapType.size() > 0)                    385       if (evapType.size() > 0)
386         SelectSecondariesByDefault (boost);       386         SelectSecondariesByDefault (boost);
387     }                                             387     }
388     else                                          388     else
389       SelectSecondariesByDefault(G4ThreeVector    389       SelectSecondariesByDefault(G4ThreeVector(0.0,0.0,0.0));
390   }                                               390   }
391                                                   391 
392   if (AF > 0)                                     392   if (AF > 0)
393   {                                               393   {
394     G4double mass = G4ParticleTable::GetPartic    394     G4double mass = G4ParticleTable::GetParticleTable()->GetIonTable()->
395       GetIonMass(ZF,AF);                          395       GetIonMass(ZF,AF);
396     G4double e    = mass + 10.0*eV;               396     G4double e    = mass + 10.0*eV;
397     G4double p    = std::sqrt(e*e-mass*mass);     397     G4double p    = std::sqrt(e*e-mass*mass);
398     G4ThreeVector direction(0.0,0.0,1.0);         398     G4ThreeVector direction(0.0,0.0,1.0);
399     G4LorentzVector lorentzVector = G4LorentzV    399     G4LorentzVector lorentzVector = G4LorentzVector(direction*p, e);
400     lorentzVector.boost(-boost);                  400     lorentzVector.boost(-boost);
401     G4Fragment* frag = new G4Fragment(AF, ZF,     401     G4Fragment* frag = new G4Fragment(AF, ZF, lorentzVector);
402     if (frag != nullptr) { frag->SetCreatorMod    402     if (frag != nullptr) { frag->SetCreatorModelID(secID); }
403     fragmentVector->push_back(frag);              403     fragmentVector->push_back(frag);
404   }                                               404   }
405   delete resultNucleus;                           405   delete resultNucleus;
406 //                                                406 //
407 //                                                407 //
408 // Provide verbose output on the ablation prod    408 // Provide verbose output on the ablation products if requested.
409 //                                                409 //
410   if (verboseLevel >= 2)                          410   if (verboseLevel >= 2)
411   {                                               411   {
412     if (nEvap > 0)                                412     if (nEvap > 0)
413     {                                             413     {
414       G4cout <<"----------------------" <<G4en    414       G4cout <<"----------------------" <<G4endl;
415       G4cout <<"Evaporated particles :" <<G4en    415       G4cout <<"Evaporated particles :" <<G4endl;
416       G4cout <<"----------------------" <<G4en    416       G4cout <<"----------------------" <<G4endl;
417     }                                             417     }
418     std::size_t ie = 0;                           418     std::size_t ie = 0;
419     for (auto iter = fragmentVector->cbegin();    419     for (auto iter = fragmentVector->cbegin();
420               iter != fragmentVector->cend();     420               iter != fragmentVector->cend(); ++iter)
421     {                                             421     {
422       if (ie == nEvap)                            422       if (ie == nEvap)
423       {                                           423       {
424 //        G4cout <<*iter  <<G4endl;               424 //        G4cout <<*iter  <<G4endl;
425         G4cout <<"----------------------------    425         G4cout <<"---------------------------------" <<G4endl;
426         G4cout <<"Particles from default emiss    426         G4cout <<"Particles from default emission :" <<G4endl;
427         G4cout <<"----------------------------    427         G4cout <<"---------------------------------" <<G4endl;
428       }                                           428       }
429       G4cout <<*iter <<G4endl;                    429       G4cout <<*iter <<G4endl;
430     }                                             430     }
431     G4cout <<"oooooooooooooooooooooooooooooooo    431     G4cout <<"oooooooooooooooooooooooooooooooooooooooo"
432            <<"oooooooooooooooooooooooooooooooo    432            <<"oooooooooooooooooooooooooooooooooooooooo"
433            <<G4endl;                              433            <<G4endl;
434   }                                               434   }
435                                                   435 
436   return fragmentVector;                          436   return fragmentVector;    
437 }                                                 437 }
438 //////////////////////////////////////////////    438 ////////////////////////////////////////////////////////////////////////////////
439 //                                                439 //
440 void G4WilsonAblationModel::SelectSecondariesB    440 void G4WilsonAblationModel::SelectSecondariesByEvaporation
441   (G4Fragment *intermediateNucleus)               441   (G4Fragment *intermediateNucleus)
442 {                                                 442 {
443   G4Fragment theResidualNucleus = *intermediat    443   G4Fragment theResidualNucleus = *intermediateNucleus;
444   G4bool evaporate = true;                        444   G4bool evaporate = true;
445   // Loop checking, 05-Aug-2015, Vladimir Ivan    445   // Loop checking, 05-Aug-2015, Vladimir Ivanchenko
446   while (evaporate && evapType.size() != 0)       446   while (evaporate && evapType.size() != 0)
447   {                                               447   {
448 //                                                448 //
449 //                                                449 //
450 // Here's the cheaky bit.  We're hijacking the    450 // Here's the cheaky bit.  We're hijacking the G4Evaporation model, in order to
451 // more accurately sample to kinematics, but t    451 // more accurately sample to kinematics, but the species of the nuclear
452 // fragments will be the ones of our choosing     452 // fragments will be the ones of our choosing as above.
453 //                                                453 //
454     std::vector <G4VEvaporationChannel*>  theC    454     std::vector <G4VEvaporationChannel*>  theChannels1;
455     theChannels1.clear();                         455     theChannels1.clear();
456     std::vector <G4VEvaporationChannel*>::iter    456     std::vector <G4VEvaporationChannel*>::iterator i;
457     VectorOfFragmentTypes::iterator iter;         457     VectorOfFragmentTypes::iterator iter;
458     std::vector <VectorOfFragmentTypes::iterat    458     std::vector <VectorOfFragmentTypes::iterator> iters;
459     iters.clear();                                459     iters.clear();
460     iter = std::find(evapType.begin(), evapTyp    460     iter = std::find(evapType.begin(), evapType.end(), G4Alpha::Alpha());
461     if (iter != evapType.end())                   461     if (iter != evapType.end())
462     {                                             462     {
463       theChannels1.push_back(new G4AlphaEvapor    463       theChannels1.push_back(new G4AlphaEvaporationChannel);
464       i = theChannels1.end() - 1;                 464       i = theChannels1.end() - 1;
465       (*i)->SetOPTxs(OPTxs);                      465       (*i)->SetOPTxs(OPTxs);
466       (*i)->UseSICB(useSICB);                     466       (*i)->UseSICB(useSICB);
467 //      (*i)->Initialize(theResidualNucleus);     467 //      (*i)->Initialize(theResidualNucleus);
468       iters.push_back(iter);                      468       iters.push_back(iter);
469     }                                             469     }
470     iter = std::find(evapType.begin(), evapTyp    470     iter = std::find(evapType.begin(), evapType.end(), G4He3::He3());
471     if (iter != evapType.end())                   471     if (iter != evapType.end())
472     {                                             472     {
473       theChannels1.push_back(new G4He3Evaporat    473       theChannels1.push_back(new G4He3EvaporationChannel);
474       i = theChannels1.end() - 1;                 474       i = theChannels1.end() - 1;
475       (*i)->SetOPTxs(OPTxs);                      475       (*i)->SetOPTxs(OPTxs);
476       (*i)->UseSICB(useSICB);                     476       (*i)->UseSICB(useSICB);
477 //      (*i)->Initialize(theResidualNucleus);     477 //      (*i)->Initialize(theResidualNucleus);
478       iters.push_back(iter);                      478       iters.push_back(iter);
479     }                                             479     }
480     iter = std::find(evapType.begin(), evapTyp    480     iter = std::find(evapType.begin(), evapType.end(), G4Triton::Triton());
481     if (iter != evapType.end())                   481     if (iter != evapType.end())
482     {                                             482     {
483       theChannels1.push_back(new G4TritonEvapo    483       theChannels1.push_back(new G4TritonEvaporationChannel);
484       i = theChannels1.end() - 1;                 484       i = theChannels1.end() - 1;
485       (*i)->SetOPTxs(OPTxs);                      485       (*i)->SetOPTxs(OPTxs);
486       (*i)->UseSICB(useSICB);                     486       (*i)->UseSICB(useSICB);
487 //      (*i)->Initialize(theResidualNucleus);     487 //      (*i)->Initialize(theResidualNucleus);
488       iters.push_back(iter);                      488       iters.push_back(iter);
489     }                                             489     }
490     iter = std::find(evapType.begin(), evapTyp    490     iter = std::find(evapType.begin(), evapType.end(), G4Deuteron::Deuteron());
491     if (iter != evapType.end())                   491     if (iter != evapType.end())
492     {                                             492     {
493       theChannels1.push_back(new G4DeuteronEva    493       theChannels1.push_back(new G4DeuteronEvaporationChannel);
494       i = theChannels1.end() - 1;                 494       i = theChannels1.end() - 1;
495       (*i)->SetOPTxs(OPTxs);                      495       (*i)->SetOPTxs(OPTxs);
496       (*i)->UseSICB(useSICB);                     496       (*i)->UseSICB(useSICB);
497 //      (*i)->Initialize(theResidualNucleus);     497 //      (*i)->Initialize(theResidualNucleus);
498       iters.push_back(iter);                      498       iters.push_back(iter);
499     }                                             499     }
500     iter = std::find(evapType.begin(), evapTyp    500     iter = std::find(evapType.begin(), evapType.end(), G4Proton::Proton());
501     if (iter != evapType.end())                   501     if (iter != evapType.end())
502     {                                             502     {
503       theChannels1.push_back(new G4ProtonEvapo    503       theChannels1.push_back(new G4ProtonEvaporationChannel);
504       i = theChannels1.end() - 1;                 504       i = theChannels1.end() - 1;
505       (*i)->SetOPTxs(OPTxs);                      505       (*i)->SetOPTxs(OPTxs);
506       (*i)->UseSICB(useSICB);                     506       (*i)->UseSICB(useSICB);
507 //      (*i)->Initialize(theResidualNucleus);     507 //      (*i)->Initialize(theResidualNucleus);
508       iters.push_back(iter);                      508       iters.push_back(iter);
509     }                                             509     }
510     iter = std::find(evapType.begin(), evapTyp    510     iter = std::find(evapType.begin(), evapType.end(), G4Neutron::Neutron());
511     if (iter != evapType.end())                   511     if (iter != evapType.end())
512     {                                             512     {
513       theChannels1.push_back(new G4NeutronEvap    513       theChannels1.push_back(new G4NeutronEvaporationChannel);
514       i = theChannels1.end() - 1;                 514       i = theChannels1.end() - 1;
515       (*i)->SetOPTxs(OPTxs);                      515       (*i)->SetOPTxs(OPTxs);
516       (*i)->UseSICB(useSICB);                     516       (*i)->UseSICB(useSICB);
517 //      (*i)->Initialize(theResidualNucleus);     517 //      (*i)->Initialize(theResidualNucleus);
518       iters.push_back(iter);                      518       iters.push_back(iter);
519     }                                             519     }
520     std::size_t nChannels = theChannels1.size(    520     std::size_t nChannels = theChannels1.size();
521                                                   521 
522     G4double totalProb = 0.0;                     522     G4double totalProb = 0.0;
523     G4int ich = 0;                                523     G4int ich = 0;
524     G4double probEvapType[6] = {0.0};             524     G4double probEvapType[6] = {0.0};
525     for (auto iterEv=theChannels1.cbegin();       525     for (auto iterEv=theChannels1.cbegin();
526               iterEv!=theChannels1.cend(); ++i    526               iterEv!=theChannels1.cend(); ++iterEv) {
527       totalProb += (*iterEv)->GetEmissionProba    527       totalProb += (*iterEv)->GetEmissionProbability(intermediateNucleus);
528       probEvapType[ich] = totalProb;              528       probEvapType[ich] = totalProb;
529       ++ich;                                      529       ++ich;
530     }                                             530     }
531     if (totalProb > 0.0) {                        531     if (totalProb > 0.0) {
532 //                                                532 //
533 //                                                533 //
534 // The emission probability for at least one o    534 // The emission probability for at least one of the evaporation channels is
535 // positive, therefore work out which one shou    535 // positive, therefore work out which one should be selected and decay
536 // the nucleus.                                   536 // the nucleus.
537 //                                                537 //
538       G4double xi = totalProb*G4UniformRand();    538       G4double xi = totalProb*G4UniformRand();
539       std::size_t ii = 0;                         539       std::size_t ii = 0;
540       for (ii=0; ii<nChannels; ++ii)              540       for (ii=0; ii<nChannels; ++ii)
541       {                                           541       {
542         if (xi < probEvapType[ii]) { break; }     542         if (xi < probEvapType[ii]) { break; }
543       }                                           543       }
544       if (ii >= nChannels) { ii = nChannels -     544       if (ii >= nChannels) { ii = nChannels - 1; }
545       G4FragmentVector *evaporationResult = th    545       G4FragmentVector *evaporationResult = theChannels1[ii]->
546         BreakUpFragment(intermediateNucleus);     546         BreakUpFragment(intermediateNucleus);
547       if ((*evaporationResult)[0] != nullptr)     547       if ((*evaporationResult)[0] != nullptr)
548       {                                           548       {
549         (*evaporationResult)[0]->SetCreatorMod    549         (*evaporationResult)[0]->SetCreatorModelID(secID);
550       }                                           550       }
551       fragmentVector->push_back((*evaporationR    551       fragmentVector->push_back((*evaporationResult)[0]);
552       intermediateNucleus = (*evaporationResul    552       intermediateNucleus = (*evaporationResult)[1];
553       delete evaporationResult;                   553       delete evaporationResult;
554     }                                             554     }
555     else                                          555     else
556     {                                             556     {
557 //                                                557 //
558 //                                                558 //
559 // Probability for further evaporation is nil     559 // Probability for further evaporation is nil so have to escape from this
560 // routine and set the energies of the seconda    560 // routine and set the energies of the secondaries to 10eV.
561 //                                                561 //
562       evaporate = false;                          562       evaporate = false;
563     }                                             563     }
564   }                                               564   }
565                                                   565   
566   return;                                         566   return;
567 }                                                 567 }
568 //////////////////////////////////////////////    568 ////////////////////////////////////////////////////////////////////////////////
569 //                                                569 //
570 void G4WilsonAblationModel::SelectSecondariesB    570 void G4WilsonAblationModel::SelectSecondariesByDefault (G4ThreeVector boost)
571 {                                                 571 {
572   for (std::size_t i=0; i<evapType.size(); ++i    572   for (std::size_t i=0; i<evapType.size(); ++i)
573   {                                               573   {
574     G4ParticleDefinition *type = evapType[i];     574     G4ParticleDefinition *type = evapType[i];
575     G4double mass              = type->GetPDGM    575     G4double mass              = type->GetPDGMass();
576     G4double e                 = mass + 10.0*e    576     G4double e                 = mass + 10.0*eV;
577     G4double p                 = std::sqrt(e*e    577     G4double p                 = std::sqrt(e*e-mass*mass);
578     G4double costheta          = 2.0*G4Uniform    578     G4double costheta          = 2.0*G4UniformRand() - 1.0;
579     G4double sintheta          = std::sqrt((1.    579     G4double sintheta          = std::sqrt((1.0 - costheta)*(1.0 + costheta));
580     G4double phi               = twopi * G4Uni    580     G4double phi               = twopi * G4UniformRand() * rad;
581     G4ThreeVector direction(sintheta*std::cos(    581     G4ThreeVector direction(sintheta*std::cos(phi),sintheta*std::sin(phi),costheta);
582     G4LorentzVector lorentzVector = G4LorentzV    582     G4LorentzVector lorentzVector = G4LorentzVector(direction*p, e);
583     lorentzVector.boost(-boost);                  583     lorentzVector.boost(-boost);
584 // Possibility that the following line is not     584 // Possibility that the following line is not correctly carrying over A and Z
585 // from particle definition.  Force values.  P    585 // from particle definition.  Force values.  PRT 03/12/2009.
586 //    G4Fragment *fragment          =             586 //    G4Fragment *fragment          = 
587 //      new G4Fragment(lorentzVector, type);      587 //      new G4Fragment(lorentzVector, type);
588     G4int A = type->GetBaryonNumber();            588     G4int A = type->GetBaryonNumber();
589     G4int Z = (G4int) (type->GetPDGCharge() +     589     G4int Z = (G4int) (type->GetPDGCharge() + 1.0E-10);
590     G4Fragment *fragment          =               590     G4Fragment *fragment          = 
591       new G4Fragment(A, Z, lorentzVector);        591       new G4Fragment(A, Z, lorentzVector);
592     if (fragment != nullptr) { fragment->SetCr    592     if (fragment != nullptr) { fragment->SetCreatorModelID(secID); }
593     fragmentVector->push_back(fragment);          593     fragmentVector->push_back(fragment);
594   }                                               594   }
595 }                                                 595 }
596 //////////////////////////////////////////////    596 ////////////////////////////////////////////////////////////////////////////////
597 //                                                597 //
598 void G4WilsonAblationModel::PrintWelcomeMessag    598 void G4WilsonAblationModel::PrintWelcomeMessage ()
599 {                                                 599 {
600   G4cout <<G4endl;                                600   G4cout <<G4endl;
601   G4cout <<" *********************************    601   G4cout <<" *****************************************************************"
602          <<G4endl;                                602          <<G4endl;
603   G4cout <<" Nuclear ablation model for nuclea    603   G4cout <<" Nuclear ablation model for nuclear-nuclear interactions activated"
604          <<G4endl;                                604          <<G4endl;
605   G4cout <<" (Written by QinetiQ Ltd for the E    605   G4cout <<" (Written by QinetiQ Ltd for the European Space Agency)"
606          <<G4endl;                                606          <<G4endl;
607   G4cout <<" !!! WARNING: This model is not we    607   G4cout <<" !!! WARNING: This model is not well validation and should not be used for accurate simulation !!!"
608          <<G4endl;                                608          <<G4endl;
609   G4cout <<" *********************************    609   G4cout <<" *****************************************************************"
610          <<G4endl;                                610          <<G4endl;
611   G4cout << G4endl;                               611   G4cout << G4endl;
612                                                   612 
613   return;                                         613   return;
614 }                                                 614 }
615 //////////////////////////////////////////////    615 ////////////////////////////////////////////////////////////////////////////////
616 //                                                616 //
617                                                   617