Geant4 Cross Reference |
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 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 // $Id: G4ANuTauNucleusCcModel.cc 91806 2015-0 26 // $Id: G4ANuTauNucleusCcModel.cc 91806 2015-08-06 12:20:45Z gcosmo $ 27 // 27 // 28 // Geant4 Header : G4ANuTauNucleusCcModel 28 // Geant4 Header : G4ANuTauNucleusCcModel 29 // 29 // 30 // Author : V.Grichine 12.2.19 30 // Author : V.Grichine 12.2.19 31 // 31 // 32 32 33 #include <iostream> 33 #include <iostream> 34 #include <fstream> 34 #include <fstream> 35 #include <sstream> 35 #include <sstream> 36 36 37 #include "G4ANuTauNucleusCcModel.hh" 37 #include "G4ANuTauNucleusCcModel.hh" 38 // #include "G4NuMuNuclCcDistrKR.hh" 38 // #include "G4NuMuNuclCcDistrKR.hh" 39 39 40 // #include "G4NuMuResQX.hh" 40 // #include "G4NuMuResQX.hh" 41 41 42 #include "G4SystemOfUnits.hh" 42 #include "G4SystemOfUnits.hh" 43 #include "G4ParticleTable.hh" 43 #include "G4ParticleTable.hh" 44 #include "G4ParticleDefinition.hh" 44 #include "G4ParticleDefinition.hh" 45 #include "G4IonTable.hh" 45 #include "G4IonTable.hh" 46 #include "Randomize.hh" 46 #include "Randomize.hh" 47 #include "G4RandomDirection.hh" 47 #include "G4RandomDirection.hh" 48 // #include "G4Threading.hh" 48 // #include "G4Threading.hh" 49 49 50 // #include "G4Integrator.hh" 50 // #include "G4Integrator.hh" 51 #include "G4DataVector.hh" 51 #include "G4DataVector.hh" 52 #include "G4PhysicsTable.hh" 52 #include "G4PhysicsTable.hh" 53 /* 53 /* 54 #include "G4CascadeInterface.hh" 54 #include "G4CascadeInterface.hh" 55 // #include "G4BinaryCascade.hh" 55 // #include "G4BinaryCascade.hh" 56 #include "G4TheoFSGenerator.hh" 56 #include "G4TheoFSGenerator.hh" 57 #include "G4LundStringFragmentation.hh" 57 #include "G4LundStringFragmentation.hh" 58 #include "G4ExcitedStringDecay.hh" 58 #include "G4ExcitedStringDecay.hh" 59 #include "G4FTFModel.hh" 59 #include "G4FTFModel.hh" 60 // #include "G4BinaryCascade.hh" 60 // #include "G4BinaryCascade.hh" 61 #include "G4HadFinalState.hh" 61 #include "G4HadFinalState.hh" 62 #include "G4HadSecondary.hh" 62 #include "G4HadSecondary.hh" 63 #include "G4HadronicInteractionRegistry.hh" 63 #include "G4HadronicInteractionRegistry.hh" 64 // #include "G4INCLXXInterface.hh" 64 // #include "G4INCLXXInterface.hh" 65 #include "G4QGSModel.hh" 65 #include "G4QGSModel.hh" 66 #include "G4QGSMFragmentation.hh" 66 #include "G4QGSMFragmentation.hh" 67 #include "G4QGSParticipants.hh" 67 #include "G4QGSParticipants.hh" 68 */ 68 */ 69 #include "G4KineticTrack.hh" 69 #include "G4KineticTrack.hh" 70 #include "G4DecayKineticTracks.hh" 70 #include "G4DecayKineticTracks.hh" 71 #include "G4KineticTrackVector.hh" 71 #include "G4KineticTrackVector.hh" 72 #include "G4Fragment.hh" 72 #include "G4Fragment.hh" 73 #include "G4NucleiProperties.hh" 73 #include "G4NucleiProperties.hh" 74 #include "G4ReactionProductVector.hh" 74 #include "G4ReactionProductVector.hh" 75 75 76 #include "G4GeneratorPrecompoundInterface.hh" 76 #include "G4GeneratorPrecompoundInterface.hh" 77 #include "G4PreCompoundModel.hh" 77 #include "G4PreCompoundModel.hh" 78 #include "G4ExcitationHandler.hh" 78 #include "G4ExcitationHandler.hh" 79 79 80 80 81 #include "G4TauMinus.hh" 81 #include "G4TauMinus.hh" 82 #include "G4TauPlus.hh" 82 #include "G4TauPlus.hh" 83 #include "G4Nucleus.hh" 83 #include "G4Nucleus.hh" 84 #include "G4LorentzVector.hh" 84 #include "G4LorentzVector.hh" 85 85 86 using namespace std; 86 using namespace std; 87 using namespace CLHEP; 87 using namespace CLHEP; 88 88 89 #ifdef G4MULTITHREADED 89 #ifdef G4MULTITHREADED 90 G4Mutex G4ANuTauNucleusCcModel::numuNucleu 90 G4Mutex G4ANuTauNucleusCcModel::numuNucleusModel = G4MUTEX_INITIALIZER; 91 #endif 91 #endif 92 92 93 93 94 G4ANuTauNucleusCcModel::G4ANuTauNucleusCcModel 94 G4ANuTauNucleusCcModel::G4ANuTauNucleusCcModel(const G4String& name) 95 : G4NeutrinoNucleusModel(name) 95 : G4NeutrinoNucleusModel(name) 96 { 96 { 97 fData = fMaster = false; 97 fData = fMaster = false; 98 fMtau = 1.77686*GeV; 98 fMtau = 1.77686*GeV; 99 theTauMinus = G4TauMinus::TauMinus(); 99 theTauMinus = G4TauMinus::TauMinus(); 100 theTauPlus = G4TauPlus::TauPlus(); 100 theTauPlus = G4TauPlus::TauPlus(); 101 InitialiseModel(); 101 InitialiseModel(); 102 } 102 } 103 103 104 104 105 G4ANuTauNucleusCcModel::~G4ANuTauNucleusCcMode 105 G4ANuTauNucleusCcModel::~G4ANuTauNucleusCcModel() 106 {} 106 {} 107 107 108 108 109 void G4ANuTauNucleusCcModel::ModelDescription( 109 void G4ANuTauNucleusCcModel::ModelDescription(std::ostream& outFile) const 110 { 110 { 111 111 112 outFile << "G4ANuTauNucleusCcModel is a an 112 outFile << "G4ANuTauNucleusCcModel is a anti tau neutrino-nucleus (charge current) scattering\n" 113 << "model which uses the standard 113 << "model which uses the standard model \n" 114 << "transfer parameterization. Th 114 << "transfer parameterization. The model is fully relativistic\n"; 115 115 116 } 116 } 117 117 118 ////////////////////////////////////////////// 118 ///////////////////////////////////////////////////////// 119 // 119 // 120 // Read data from G4PARTICLEXSDATA (locally PA 120 // Read data from G4PARTICLEXSDATA (locally PARTICLEXSDATA) 121 121 122 void G4ANuTauNucleusCcModel::InitialiseModel() 122 void G4ANuTauNucleusCcModel::InitialiseModel() 123 { 123 { 124 G4String pName = "nu_mu"; 124 G4String pName = "nu_mu"; 125 // G4String pName = "anti_nu_mu"; 125 // G4String pName = "anti_nu_mu"; 126 126 127 G4int nSize(0), i(0), j(0), k(0); 127 G4int nSize(0), i(0), j(0), k(0); 128 128 129 if(!fData) 129 if(!fData) 130 { 130 { 131 #ifdef G4MULTITHREADED 131 #ifdef G4MULTITHREADED 132 G4MUTEXLOCK(&numuNucleusModel); 132 G4MUTEXLOCK(&numuNucleusModel); 133 if(!fData) 133 if(!fData) 134 { 134 { 135 #endif 135 #endif 136 fMaster = true; 136 fMaster = true; 137 #ifdef G4MULTITHREADED 137 #ifdef G4MULTITHREADED 138 } 138 } 139 G4MUTEXUNLOCK(&numuNucleusModel); 139 G4MUTEXUNLOCK(&numuNucleusModel); 140 #endif 140 #endif 141 } 141 } 142 142 143 if(fMaster) 143 if(fMaster) 144 { 144 { 145 const char* path = G4FindDataDir("G4PARTIC 145 const char* path = G4FindDataDir("G4PARTICLEXSDATA"); 146 std::ostringstream ost1, ost2, ost3, ost4; 146 std::ostringstream ost1, ost2, ost3, ost4; 147 ost1 << path << "/" << "neutrino" << "/" < 147 ost1 << path << "/" << "neutrino" << "/" << pName << "/xarraycckr"; 148 148 149 std::ifstream filein1( ost1.str().c_str() 149 std::ifstream filein1( ost1.str().c_str() ); 150 150 151 // filein.open("$PARTICLEXSDATA/"); 151 // filein.open("$PARTICLEXSDATA/"); 152 152 153 filein1>>nSize; 153 filein1>>nSize; 154 154 155 for( k = 0; k < fNbin; ++k ) 155 for( k = 0; k < fNbin; ++k ) 156 { 156 { 157 for( i = 0; i <= fNbin; ++i ) 157 for( i = 0; i <= fNbin; ++i ) 158 { 158 { 159 filein1 >> fNuMuXarrayKR[k][i]; 159 filein1 >> fNuMuXarrayKR[k][i]; 160 // G4cout<< fNuMuXarrayKR[k][i] << " 160 // G4cout<< fNuMuXarrayKR[k][i] << " "; 161 } 161 } 162 } 162 } 163 // G4cout<<G4endl<<G4endl; 163 // G4cout<<G4endl<<G4endl; 164 164 165 ost2 << path << "/" << "neutrino" << "/" < 165 ost2 << path << "/" << "neutrino" << "/" << pName << "/xdistrcckr"; 166 std::ifstream filein2( ost2.str().c_str() 166 std::ifstream filein2( ost2.str().c_str() ); 167 167 168 filein2>>nSize; 168 filein2>>nSize; 169 169 170 for( k = 0; k < fNbin; ++k ) 170 for( k = 0; k < fNbin; ++k ) 171 { 171 { 172 for( i = 0; i < fNbin; ++i ) 172 for( i = 0; i < fNbin; ++i ) 173 { 173 { 174 filein2 >> fNuMuXdistrKR[k][i]; 174 filein2 >> fNuMuXdistrKR[k][i]; 175 // G4cout<< fNuMuXdistrKR[k][i] << " 175 // G4cout<< fNuMuXdistrKR[k][i] << " "; 176 } 176 } 177 } 177 } 178 // G4cout<<G4endl<<G4endl; 178 // G4cout<<G4endl<<G4endl; 179 179 180 ost3 << path << "/" << "neutrino" << "/" < 180 ost3 << path << "/" << "neutrino" << "/" << pName << "/q2arraycckr"; 181 std::ifstream filein3( ost3.str().c_str() 181 std::ifstream filein3( ost3.str().c_str() ); 182 182 183 filein3>>nSize; 183 filein3>>nSize; 184 184 185 for( k = 0; k < fNbin; ++k ) 185 for( k = 0; k < fNbin; ++k ) 186 { 186 { 187 for( i = 0; i <= fNbin; ++i ) 187 for( i = 0; i <= fNbin; ++i ) 188 { 188 { 189 for( j = 0; j <= fNbin; ++j ) 189 for( j = 0; j <= fNbin; ++j ) 190 { 190 { 191 filein3 >> fNuMuQarrayKR[k][i][j]; 191 filein3 >> fNuMuQarrayKR[k][i][j]; 192 // G4cout<< fNuMuQarrayKR[k][i][j] < 192 // G4cout<< fNuMuQarrayKR[k][i][j] << " "; 193 } 193 } 194 } 194 } 195 } 195 } 196 // G4cout<<G4endl<<G4endl; 196 // G4cout<<G4endl<<G4endl; 197 197 198 ost4 << path << "/" << "neutrino" << "/" < 198 ost4 << path << "/" << "neutrino" << "/" << pName << "/q2distrcckr"; 199 std::ifstream filein4( ost4.str().c_str() 199 std::ifstream filein4( ost4.str().c_str() ); 200 200 201 filein4>>nSize; 201 filein4>>nSize; 202 202 203 for( k = 0; k < fNbin; ++k ) 203 for( k = 0; k < fNbin; ++k ) 204 { 204 { 205 for( i = 0; i <= fNbin; ++i ) 205 for( i = 0; i <= fNbin; ++i ) 206 { 206 { 207 for( j = 0; j < fNbin; ++j ) 207 for( j = 0; j < fNbin; ++j ) 208 { 208 { 209 filein4 >> fNuMuQdistrKR[k][i][j]; 209 filein4 >> fNuMuQdistrKR[k][i][j]; 210 // G4cout<< fNuMuQdistrKR[k][i][j] < 210 // G4cout<< fNuMuQdistrKR[k][i][j] << " "; 211 } 211 } 212 } 212 } 213 } 213 } 214 fData = true; 214 fData = true; 215 } 215 } 216 } 216 } 217 217 218 ////////////////////////////////////////////// 218 ///////////////////////////////////////////////////////// 219 219 220 G4bool G4ANuTauNucleusCcModel::IsApplicable(co 220 G4bool G4ANuTauNucleusCcModel::IsApplicable(const G4HadProjectile & aPart, 221 G4Nucleus & ) 221 G4Nucleus & ) 222 { 222 { 223 G4bool result = false; 223 G4bool result = false; 224 G4String pName = aPart.GetDefinition()->GetP 224 G4String pName = aPart.GetDefinition()->GetParticleName(); 225 G4double energy = aPart.GetTotalEnergy(); 225 G4double energy = aPart.GetTotalEnergy(); 226 226 227 if( pName == "anti_nu_tau" // || pName == 227 if( pName == "anti_nu_tau" // || pName == "anti_nu_tau" ) 228 && 228 && 229 energy > fMinNuEnergy 229 energy > fMinNuEnergy ) 230 { 230 { 231 result = true; 231 result = true; 232 } 232 } 233 233 234 return result; 234 return result; 235 } 235 } 236 236 237 /////////////////////////////////////////// Cl 237 /////////////////////////////////////////// ClusterDecay //////////////////////////////////////////////////////////// 238 // 238 // 239 // 239 // 240 240 241 G4HadFinalState* G4ANuTauNucleusCcModel::Apply 241 G4HadFinalState* G4ANuTauNucleusCcModel::ApplyYourself( 242 const G4HadProjectile& aTrack, G4Nucleus& 242 const G4HadProjectile& aTrack, G4Nucleus& targetNucleus) 243 { 243 { 244 theParticleChange.Clear(); 244 theParticleChange.Clear(); 245 fProton = f2p2h = fBreak = false; 245 fProton = f2p2h = fBreak = false; 246 fCascade = fString = false; 246 fCascade = fString = false; 247 fLVh = fLVl = fLVt = fLVcpi = G4LorentzVecto 247 fLVh = fLVl = fLVt = fLVcpi = G4LorentzVector(0.,0.,0.,0.); 248 248 249 const G4HadProjectile* aParticle = &aTrack; 249 const G4HadProjectile* aParticle = &aTrack; 250 G4double energy = aParticle->GetTotalEnergy( 250 G4double energy = aParticle->GetTotalEnergy(); 251 251 252 G4String pName = aParticle->GetDefinition() 252 G4String pName = aParticle->GetDefinition()->GetParticleName(); 253 253 254 if( energy < fMinNuEnergy ) 254 if( energy < fMinNuEnergy ) 255 { 255 { 256 theParticleChange.SetEnergyChange(energy); 256 theParticleChange.SetEnergyChange(energy); 257 theParticleChange.SetMomentumChange(aTrack 257 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 258 return &theParticleChange; 258 return &theParticleChange; 259 } 259 } 260 260 261 SampleLVkr( aTrack, targetNucleus); 261 SampleLVkr( aTrack, targetNucleus); 262 262 263 if( fBreak == true || fEmu < fMtau ) // ~5*1 263 if( fBreak == true || fEmu < fMtau ) // ~5*10^-6 264 { 264 { 265 // G4cout<<"ni, "; 265 // G4cout<<"ni, "; 266 theParticleChange.SetEnergyChange(energy); 266 theParticleChange.SetEnergyChange(energy); 267 theParticleChange.SetMomentumChange(aTrack 267 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 268 return &theParticleChange; 268 return &theParticleChange; 269 } 269 } 270 270 271 // LVs of initial state 271 // LVs of initial state 272 272 273 G4LorentzVector lvp1 = aParticle->Get4Moment 273 G4LorentzVector lvp1 = aParticle->Get4Momentum(); 274 G4LorentzVector lvt1( 0., 0., 0., fM1 ); 274 G4LorentzVector lvt1( 0., 0., 0., fM1 ); 275 G4double mPip = G4ParticleTable::GetParticle 275 G4double mPip = G4ParticleTable::GetParticleTable()->FindParticle(211)->GetPDGMass(); 276 276 277 // 1-pi by fQtransfer && nu-energy 277 // 1-pi by fQtransfer && nu-energy 278 G4LorentzVector lvpip1( 0., 0., 0., mPip ); 278 G4LorentzVector lvpip1( 0., 0., 0., mPip ); 279 G4LorentzVector lvsum, lv2, lvX; 279 G4LorentzVector lvsum, lv2, lvX; 280 G4ThreeVector eP; 280 G4ThreeVector eP; 281 G4double cost(1.), sint(0.), phi(0.), muMom( 281 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.), massX(0.), massR(0.), eCut(0.); 282 G4DynamicParticle* aLept = nullptr; // lepto 282 G4DynamicParticle* aLept = nullptr; // lepton lv 283 283 284 G4int Z = targetNucleus.GetZ_asInt(); 284 G4int Z = targetNucleus.GetZ_asInt(); 285 G4int A = targetNucleus.GetA_asInt(); 285 G4int A = targetNucleus.GetA_asInt(); 286 G4double mTarg = targetNucleus.AtomicMass(A 286 G4double mTarg = targetNucleus.AtomicMass(A,Z); 287 G4int pdgP(0), qB(0); 287 G4int pdgP(0), qB(0); 288 // G4double mSum = G4ParticleTable::GetParti 288 // G4double mSum = G4ParticleTable::GetParticleTable()->FindParticle(2212)->GetPDGMass() + mPip; 289 289 290 G4int iPi = GetOnePionIndex(energy); 290 G4int iPi = GetOnePionIndex(energy); 291 G4double p1pi = GetNuMuOnePionProb( iPi, ene 291 G4double p1pi = GetNuMuOnePionProb( iPi, energy); 292 292 293 if( p1pi > G4UniformRand() && fCosTheta > 0 293 if( p1pi > G4UniformRand() && fCosTheta > 0.9 ) // && fQtransfer < 0.95*GeV ) // mu- & coherent pion + nucleus 294 { 294 { 295 // lvsum = lvp1 + lvpip1; 295 // lvsum = lvp1 + lvpip1; 296 lvsum = lvp1 + lvt1; 296 lvsum = lvp1 + lvt1; 297 // cost = fCosThetaPi; 297 // cost = fCosThetaPi; 298 cost = fCosTheta; 298 cost = fCosTheta; 299 sint = std::sqrt( (1.0 - cost)*(1.0 + cost 299 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) ); 300 phi = G4UniformRand()*CLHEP::twopi; 300 phi = G4UniformRand()*CLHEP::twopi; 301 eP = G4ThreeVector( sint*std::cos(phi), 301 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost ); 302 302 303 // muMom = sqrt(fEmuPi*fEmuPi-fMtau*fMtau) 303 // muMom = sqrt(fEmuPi*fEmuPi-fMtau*fMtau); 304 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 304 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 305 305 306 eP *= muMom; 306 eP *= muMom; 307 307 308 // lv2 = G4LorentzVector( eP, fEmuPi ); 308 // lv2 = G4LorentzVector( eP, fEmuPi ); 309 // lv2 = G4LorentzVector( eP, fEmu ); 309 // lv2 = G4LorentzVector( eP, fEmu ); 310 lv2 = fLVl; 310 lv2 = fLVl; 311 311 312 // lvX = lvsum - lv2; 312 // lvX = lvsum - lv2; 313 lvX = fLVh; 313 lvX = fLVh; 314 massX2 = lvX.m2(); 314 massX2 = lvX.m2(); 315 massX = lvX.m(); 315 massX = lvX.m(); 316 massR = fLVt.m(); 316 massR = fLVt.m(); 317 317 318 if ( massX2 <= 0. ) // vmg: very rarely ~ 318 if ( massX2 <= 0. ) // vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved 319 { 319 { 320 fCascade = true; 320 fCascade = true; 321 theParticleChange.SetEnergyChange(energy 321 theParticleChange.SetEnergyChange(energy); 322 theParticleChange.SetMomentumChange(aTra 322 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 323 return &theParticleChange; 323 return &theParticleChange; 324 } 324 } 325 fW2 = massX2; 325 fW2 = massX2; 326 326 327 if( pName == "anti_nu_tau" ) aLep 327 if( pName == "anti_nu_tau" ) aLept = new G4DynamicParticle( theTauPlus, lv2 ); 328 // else if( pName == "anti_nu_tau") aLept 328 // else if( pName == "anti_nu_tau") aLept = new G4DynamicParticle( theTauPlus, lv2 ); 329 else 329 else 330 { 330 { 331 theParticleChange.SetEnergyChange(energy 331 theParticleChange.SetEnergyChange(energy); 332 theParticleChange.SetMomentumChange(aTra 332 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 333 return &theParticleChange; 333 return &theParticleChange; 334 } 334 } 335 if( pName == "anti_nu_tau" ) pdgP = 211; 335 if( pName == "anti_nu_tau" ) pdgP = 211; 336 // else pdgP = -211; 336 // else pdgP = -211; 337 // eCut = fMpi + 0.5*(fMpi*fMpi-massX2)/mT 337 // eCut = fMpi + 0.5*(fMpi*fMpi-massX2)/mTarg; // massX -> fMpi 338 338 339 if( A > 1 ) 339 if( A > 1 ) 340 { 340 { 341 eCut = (fMpi + mTarg)*(fMpi + mTarg) - ( 341 eCut = (fMpi + mTarg)*(fMpi + mTarg) - (massX + massR)*(massX + massR); 342 eCut /= 2.*massR; 342 eCut /= 2.*massR; 343 eCut += massX; 343 eCut += massX; 344 } 344 } 345 else eCut = fM1 + fMpi; 345 else eCut = fM1 + fMpi; 346 346 347 if ( lvX.e() > eCut ) // && sqrt( GetW2() 347 if ( lvX.e() > eCut ) // && sqrt( GetW2() ) < 1.4*GeV ) // 348 { 348 { 349 CoherentPion( lvX, pdgP, targetNucleus); 349 CoherentPion( lvX, pdgP, targetNucleus); 350 } 350 } 351 else 351 else 352 { 352 { 353 fCascade = true; 353 fCascade = true; 354 theParticleChange.SetEnergyChange(energy 354 theParticleChange.SetEnergyChange(energy); 355 theParticleChange.SetMomentumChange(aTra 355 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 356 return &theParticleChange; 356 return &theParticleChange; 357 } 357 } 358 theParticleChange.AddSecondary( aLept, fSe 358 theParticleChange.AddSecondary( aLept, fSecID ); 359 359 360 return &theParticleChange; 360 return &theParticleChange; 361 } 361 } 362 else // lepton part in lab 362 else // lepton part in lab 363 { 363 { 364 lvsum = lvp1 + lvt1; 364 lvsum = lvp1 + lvt1; 365 cost = fCosTheta; 365 cost = fCosTheta; 366 sint = std::sqrt( (1.0 - cost)*(1.0 + cost 366 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) ); 367 phi = G4UniformRand()*CLHEP::twopi; 367 phi = G4UniformRand()*CLHEP::twopi; 368 eP = G4ThreeVector( sint*std::cos(phi), 368 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost ); 369 369 370 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 370 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 371 371 372 eP *= muMom; 372 eP *= muMom; 373 373 374 lv2 = G4LorentzVector( eP, fEmu ); 374 lv2 = G4LorentzVector( eP, fEmu ); 375 lv2 = fLVl; 375 lv2 = fLVl; 376 lvX = lvsum - lv2; 376 lvX = lvsum - lv2; 377 lvX = fLVh; 377 lvX = fLVh; 378 massX2 = lvX.m2(); 378 massX2 = lvX.m2(); 379 379 380 if ( massX2 <= 0. ) // vmg: very rarely ~ 380 if ( massX2 <= 0. ) // vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved 381 { 381 { 382 fCascade = true; 382 fCascade = true; 383 theParticleChange.SetEnergyChange(energy 383 theParticleChange.SetEnergyChange(energy); 384 theParticleChange.SetMomentumChange(aTra 384 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 385 return &theParticleChange; 385 return &theParticleChange; 386 } 386 } 387 fW2 = massX2; 387 fW2 = massX2; 388 388 389 if( pName == "anti_nu_tau" ) aLep 389 if( pName == "anti_nu_tau" ) aLept = new G4DynamicParticle( theTauPlus, lv2 ); 390 // else if( pName == "anti_nu_tau") aLept 390 // else if( pName == "anti_nu_tau") aLept = new G4DynamicParticle( theTauPlus, lv2 ); 391 else 391 else 392 { 392 { 393 theParticleChange.SetEnergyChange(energy 393 theParticleChange.SetEnergyChange(energy); 394 theParticleChange.SetMomentumChange(aTra 394 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 395 return &theParticleChange; 395 return &theParticleChange; 396 } 396 } 397 theParticleChange.AddSecondary( aLept, fSe 397 theParticleChange.AddSecondary( aLept, fSecID ); 398 } 398 } 399 399 400 // hadron part 400 // hadron part 401 401 402 fRecoil = nullptr; 402 fRecoil = nullptr; 403 403 404 if( A == 1 ) 404 if( A == 1 ) 405 { 405 { 406 if( pName == "anti_nu_tau" ) qB = 2; 406 if( pName == "anti_nu_tau" ) qB = 2; 407 // else qB = 0; 407 // else qB = 0; 408 408 409 // if( G4UniformRand() > 0.1 ) // > 0.999 409 // if( G4UniformRand() > 0.1 ) // > 0.9999 ) // > 0.0001 ) // 410 { 410 { 411 ClusterDecay( lvX, qB ); 411 ClusterDecay( lvX, qB ); 412 } 412 } 413 return &theParticleChange; 413 return &theParticleChange; 414 } 414 } 415 /* 415 /* 416 // else 416 // else 417 { 417 { 418 if( pName == "anti_nu_tau" ) pdgP = 211 418 if( pName == "anti_nu_tau" ) pdgP = 211; 419 else pdgP = -211; 419 else pdgP = -211; 420 420 421 421 422 if ( fQtransfer < 0.95*GeV ) // < 0.35*G 422 if ( fQtransfer < 0.95*GeV ) // < 0.35*GeV ) // 423 { 423 { 424 if( lvX.m() > mSum ) CoherentPion( lvX, pdgP 424 if( lvX.m() > mSum ) CoherentPion( lvX, pdgP, targetNucleus); 425 } 425 } 426 } 426 } 427 return &theParticleChange; 427 return &theParticleChange; 428 } 428 } 429 */ 429 */ 430 G4Nucleus recoil; 430 G4Nucleus recoil; 431 G4double rM(0.), ratio = G4double(Z)/G4doubl 431 G4double rM(0.), ratio = G4double(Z)/G4double(A); 432 432 433 if( ratio > G4UniformRand() ) // proton is e 433 if( ratio > G4UniformRand() ) // proton is excited 434 { 434 { 435 fProton = true; 435 fProton = true; 436 recoil = G4Nucleus(A-1,Z-1); 436 recoil = G4Nucleus(A-1,Z-1); 437 fRecoil = &recoil; 437 fRecoil = &recoil; 438 rM = recoil.AtomicMass(A-1,Z-1); 438 rM = recoil.AtomicMass(A-1,Z-1); 439 439 440 if( pName == "anti_nu_tau" ) // (++) state 440 if( pName == "anti_nu_tau" ) // (++) state -> p + pi+ 441 { 441 { 442 fMt = G4ParticleTable::GetParticleTable( 442 fMt = G4ParticleTable::GetParticleTable()->FindParticle(2212)->GetPDGMass() 443 + G4ParticleTable::GetParticleTable( 443 + G4ParticleTable::GetParticleTable()->FindParticle(211)->GetPDGMass(); 444 } 444 } 445 else // (0) state -> p + pi-, n + pi0 445 else // (0) state -> p + pi-, n + pi0 446 { 446 { 447 // fMt = G4ParticleTable::GetParticleTab 447 // fMt = G4ParticleTable::GetParticleTable()->FindParticle(2212)->GetPDGMass() 448 // + G4ParticleTable::GetParticleTab 448 // + G4ParticleTable::GetParticleTable()->FindParticle(-211)->GetPDGMass(); 449 } 449 } 450 } 450 } 451 else // excited neutron 451 else // excited neutron 452 { 452 { 453 fProton = false; 453 fProton = false; 454 recoil = G4Nucleus(A-1,Z); 454 recoil = G4Nucleus(A-1,Z); 455 fRecoil = &recoil; 455 fRecoil = &recoil; 456 rM = recoil.AtomicMass(A-1,Z); 456 rM = recoil.AtomicMass(A-1,Z); 457 457 458 if( pName == "anti_nu_tau" ) // (+) state 458 if( pName == "anti_nu_tau" ) // (+) state -> n + pi+ 459 { 459 { 460 fMt = G4ParticleTable::GetParticleTable( 460 fMt = G4ParticleTable::GetParticleTable()->FindParticle(2112)->GetPDGMass() 461 + G4ParticleTable::GetParticleTable( 461 + G4ParticleTable::GetParticleTable()->FindParticle(211)->GetPDGMass(); 462 } 462 } 463 else // (-) state -> n + pi-, // n + pi0 463 else // (-) state -> n + pi-, // n + pi0 464 { 464 { 465 // fMt = G4ParticleTable::GetParticleTab 465 // fMt = G4ParticleTable::GetParticleTable()->FindParticle(2112)->GetPDGMass() 466 // + G4ParticleTable::GetParticleTab 466 // + G4ParticleTable::GetParticleTable()->FindParticle(-211)->GetPDGMass(); 467 } 467 } 468 } 468 } 469 // G4int index = GetEnergyIndex(energy 469 // G4int index = GetEnergyIndex(energy); 470 G4int nepdg = aParticle->GetDefinition()->Ge 470 G4int nepdg = aParticle->GetDefinition()->GetPDGEncoding(); 471 471 472 G4double qeTotRat; // = GetNuMuQeTotRat(inde 472 G4double qeTotRat; // = GetNuMuQeTotRat(index, energy); 473 qeTotRat = CalculateQEratioA( Z, A, energy, 473 qeTotRat = CalculateQEratioA( Z, A, energy, nepdg); 474 474 475 G4ThreeVector dX = (lvX.vect()).unit(); 475 G4ThreeVector dX = (lvX.vect()).unit(); 476 G4double eX = lvX.e(); // excited nucleon 476 G4double eX = lvX.e(); // excited nucleon 477 G4double mX = sqrt(massX2); 477 G4double mX = sqrt(massX2); 478 // G4double pX = sqrt( eX*eX - mX*mX ); 478 // G4double pX = sqrt( eX*eX - mX*mX ); 479 // G4double sumE = eX + rM; 479 // G4double sumE = eX + rM; 480 480 481 if( qeTotRat > G4UniformRand() || mX <= fMt 481 if( qeTotRat > G4UniformRand() || mX <= fMt ) // || eX <= 1232.*MeV) // QE 482 { 482 { 483 fString = false; 483 fString = false; 484 484 485 if( fProton ) 485 if( fProton ) 486 { 486 { 487 fPDGencoding = 2212; 487 fPDGencoding = 2212; 488 fMr = proton_mass_c2; 488 fMr = proton_mass_c2; 489 recoil = G4Nucleus(A-1,Z-1); 489 recoil = G4Nucleus(A-1,Z-1); 490 fRecoil = &recoil; 490 fRecoil = &recoil; 491 rM = recoil.AtomicMass(A-1,Z-1); 491 rM = recoil.AtomicMass(A-1,Z-1); 492 } 492 } 493 else // if( pName == "anti_nu_tau" ) 493 else // if( pName == "anti_nu_tau" ) 494 { 494 { 495 fPDGencoding = 2112; 495 fPDGencoding = 2112; 496 fMr = G4ParticleTable::GetParticleTabl 496 fMr = G4ParticleTable::GetParticleTable()-> 497 FindParticle(fPDGencoding)->GetPDGMass(); // 497 FindParticle(fPDGencoding)->GetPDGMass(); // 939.5654133*MeV; 498 recoil = G4Nucleus(A-1,Z); 498 recoil = G4Nucleus(A-1,Z); 499 fRecoil = &recoil; 499 fRecoil = &recoil; 500 rM = recoil.AtomicMass(A-1,Z); 500 rM = recoil.AtomicMass(A-1,Z); 501 } 501 } 502 // sumE = eX + rM; 502 // sumE = eX + rM; 503 G4double eTh = fMr + 0.5*(fMr*fMr - mX*mX) 503 G4double eTh = fMr + 0.5*(fMr*fMr - mX*mX)/rM; 504 504 505 if( eX <= eTh ) // vmg, very rarely out of 505 if( eX <= eTh ) // vmg, very rarely out of kinematics 506 { 506 { 507 fString = true; 507 fString = true; 508 theParticleChange.SetEnergyChange(energy 508 theParticleChange.SetEnergyChange(energy); 509 theParticleChange.SetMomentumChange(aTra 509 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit()); 510 return &theParticleChange; 510 return &theParticleChange; 511 } 511 } 512 // FinalBarion( fLVh, 0, fPDGencoding ); / 512 // FinalBarion( fLVh, 0, fPDGencoding ); // p(n)+deexcited recoil 513 FinalBarion( lvX, 0, fPDGencoding ); // p( 513 FinalBarion( lvX, 0, fPDGencoding ); // p(n)+deexcited recoil 514 } 514 } 515 else // if ( eX < 9500000.*GeV ) // < 25.*G 515 else // if ( eX < 9500000.*GeV ) // < 25.*GeV) // < 95.*GeV ) // < 2.5*GeV ) //cluster decay 516 { 516 { 517 if ( fProton && pName == "anti_nu_tau 517 if ( fProton && pName == "anti_nu_tau" ) qB = 2; 518 // else if( fProton && pName == "anti_nu_ 518 // else if( fProton && pName == "anti_nu_tau" ) qB = 0; 519 else if( !fProton && pName == "anti_nu_tau 519 else if( !fProton && pName == "anti_nu_tau" ) qB = 1; 520 // else if( !fProton && pName == "anti_nu_ 520 // else if( !fProton && pName == "anti_nu_tau" ) qB = -1; 521 521 522 522 523 ClusterDecay( lvX, qB ); 523 ClusterDecay( lvX, qB ); 524 } 524 } 525 return &theParticleChange; 525 return &theParticleChange; 526 } 526 } 527 527 528 528 529 ////////////////////////////////////////////// 529 ///////////////////////////////////////////////////////////////////// 530 ////////////////////////////////////////////// 530 //////////////////////////////////////////////////////////////////// 531 ////////////////////////////////////////////// 531 /////////////////////////////////////////////////////////////////// 532 532 533 ////////////////////////////////////////////// 533 ///////////////////////////////////////////////// 534 // 534 // 535 // sample x, then Q2 535 // sample x, then Q2 536 536 537 void G4ANuTauNucleusCcModel::SampleLVkr(const 537 void G4ANuTauNucleusCcModel::SampleLVkr(const G4HadProjectile & aTrack, G4Nucleus& targetNucleus) 538 { 538 { 539 fBreak = false; 539 fBreak = false; 540 G4int A = targetNucleus.GetA_asInt(), iTer(0 540 G4int A = targetNucleus.GetA_asInt(), iTer(0), iTerMax(100); 541 G4int Z = targetNucleus.GetZ_asInt(); 541 G4int Z = targetNucleus.GetZ_asInt(); 542 G4double e3(0.), pMu2(0.), pX2(0.), nMom(0.) 542 G4double e3(0.), pMu2(0.), pX2(0.), nMom(0.), rM(0.), hM(0.), tM = targetNucleus.AtomicMass(A,Z); 543 G4double Ex(0.), ei(0.), nm2(0.); 543 G4double Ex(0.), ei(0.), nm2(0.); 544 G4double cost(1.), sint(0.), phi(0.), muMom( 544 G4double cost(1.), sint(0.), phi(0.), muMom(0.); 545 G4ThreeVector eP, bst; 545 G4ThreeVector eP, bst; 546 const G4HadProjectile* aParticle = &aTrack; 546 const G4HadProjectile* aParticle = &aTrack; 547 G4LorentzVector lvp1 = aParticle->Get4Moment 547 G4LorentzVector lvp1 = aParticle->Get4Momentum(); 548 548 549 if( A == 1 ) // hydrogen, no Fermi motion ?? 549 if( A == 1 ) // hydrogen, no Fermi motion ??? 550 { 550 { 551 fNuEnergy = aParticle->GetTotalEnergy(); 551 fNuEnergy = aParticle->GetTotalEnergy(); 552 iTer = 0; 552 iTer = 0; 553 553 554 do 554 do 555 { 555 { 556 fXsample = SampleXkr(fNuEnergy); 556 fXsample = SampleXkr(fNuEnergy); 557 fQtransfer = SampleQkr(fNuEnergy, fXsamp 557 fQtransfer = SampleQkr(fNuEnergy, fXsample); 558 fQ2 = fQtransfer*fQtransfer; 558 fQ2 = fQtransfer*fQtransfer; 559 559 560 if( fXsample > 0. ) 560 if( fXsample > 0. ) 561 { 561 { 562 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // 562 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // sample excited hadron mass 563 fEmu = fNuEnergy - fQ2/2./fM1/fXsample 563 fEmu = fNuEnergy - fQ2/2./fM1/fXsample; 564 } 564 } 565 else 565 else 566 { 566 { 567 fW2 = fM1*fM1; 567 fW2 = fM1*fM1; 568 fEmu = fNuEnergy; 568 fEmu = fNuEnergy; 569 } 569 } 570 e3 = fNuEnergy + fM1 - fEmu; 570 e3 = fNuEnergy + fM1 - fEmu; 571 571 572 if( e3 < sqrt(fW2) ) G4cout<<"energyX = 572 if( e3 < sqrt(fW2) ) G4cout<<"energyX = "<<e3/GeV<<", fW = "<<sqrt(fW2)/GeV<<G4endl; 573 573 574 pMu2 = fEmu*fEmu - fMtau*fMtau; 574 pMu2 = fEmu*fEmu - fMtau*fMtau; 575 575 576 if(pMu2 < 0.) { fBreak = true; return; } 576 if(pMu2 < 0.) { fBreak = true; return; } 577 577 578 pX2 = e3*e3 - fW2; 578 pX2 = e3*e3 - fW2; 579 579 580 fCosTheta = fNuEnergy*fNuEnergy + pMu2 580 fCosTheta = fNuEnergy*fNuEnergy + pMu2 - pX2; 581 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2); 581 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2); 582 iTer++; 582 iTer++; 583 } 583 } 584 while( ( abs(fCosTheta) > 1. || fEmu < fMt 584 while( ( abs(fCosTheta) > 1. || fEmu < fMtau ) && iTer < iTerMax ); 585 585 586 if( iTer >= iTerMax ) { fBreak = true; ret 586 if( iTer >= iTerMax ) { fBreak = true; return; } 587 587 588 if( abs(fCosTheta) > 1.) // vmg: due to bi 588 if( abs(fCosTheta) > 1.) // vmg: due to big Q2/x values. To be improved ... 589 { 589 { 590 G4cout<<"H2: fCosTheta = "<<fCosTheta<<" 590 G4cout<<"H2: fCosTheta = "<<fCosTheta<<", fEmu = "<<fEmu<<G4endl; 591 // fCosTheta = -1. + 2.*G4UniformRand(); 591 // fCosTheta = -1. + 2.*G4UniformRand(); 592 if(fCosTheta < -1.) fCosTheta = -1.; 592 if(fCosTheta < -1.) fCosTheta = -1.; 593 if(fCosTheta > 1.) fCosTheta = 1.; 593 if(fCosTheta > 1.) fCosTheta = 1.; 594 } 594 } 595 // LVs 595 // LVs 596 596 597 G4LorentzVector lvt1 = G4LorentzVector( 0 597 G4LorentzVector lvt1 = G4LorentzVector( 0., 0., 0., fM1 ); 598 G4LorentzVector lvsum = lvp1 + lvt1; 598 G4LorentzVector lvsum = lvp1 + lvt1; 599 599 600 cost = fCosTheta; 600 cost = fCosTheta; 601 sint = std::sqrt( (1.0 - cost)*(1.0 + cost 601 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) ); 602 phi = G4UniformRand()*CLHEP::twopi; 602 phi = G4UniformRand()*CLHEP::twopi; 603 eP = G4ThreeVector( sint*std::cos(phi), 603 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost ); 604 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 604 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 605 eP *= muMom; 605 eP *= muMom; 606 fLVl = G4LorentzVector( eP, fEmu ); 606 fLVl = G4LorentzVector( eP, fEmu ); 607 607 608 fLVh = lvsum - fLVl; 608 fLVh = lvsum - fLVl; 609 fLVt = G4LorentzVector( 0., 0., 0., 0. ); 609 fLVt = G4LorentzVector( 0., 0., 0., 0. ); // no recoil 610 } 610 } 611 else // Fermi motion, Q2 in nucleon rest fra 611 else // Fermi motion, Q2 in nucleon rest frame 612 { 612 { 613 G4Nucleus recoil1( A-1, Z ); 613 G4Nucleus recoil1( A-1, Z ); 614 rM = recoil1.AtomicMass(A-1,Z); 614 rM = recoil1.AtomicMass(A-1,Z); 615 do 615 do 616 { 616 { 617 // nMom = NucleonMomentumBR( targetNucle 617 // nMom = NucleonMomentumBR( targetNucleus ); // BR 618 nMom = GgSampleNM( targetNucleus ); // G 618 nMom = GgSampleNM( targetNucleus ); // Gg 619 Ex = GetEx(A-1, fProton); 619 Ex = GetEx(A-1, fProton); 620 ei = tM - sqrt( (rM + Ex)*(rM + Ex) + nM 620 ei = tM - sqrt( (rM + Ex)*(rM + Ex) + nMom*nMom ); 621 // ei = 0.5*( tM - s2M - 2*eX ); 621 // ei = 0.5*( tM - s2M - 2*eX ); 622 622 623 nm2 = ei*ei - nMom*nMom; 623 nm2 = ei*ei - nMom*nMom; 624 iTer++; 624 iTer++; 625 } 625 } 626 while( nm2 < 0. && iTer < iTerMax ); 626 while( nm2 < 0. && iTer < iTerMax ); 627 627 628 if( iTer >= iTerMax ) { fBreak = true; ret 628 if( iTer >= iTerMax ) { fBreak = true; return; } 629 629 630 G4ThreeVector nMomDir = nMom*G4RandomDirec 630 G4ThreeVector nMomDir = nMom*G4RandomDirection(); 631 631 632 if( !f2p2h || A < 3 ) // 1p1h 632 if( !f2p2h || A < 3 ) // 1p1h 633 { 633 { 634 // hM = tM - rM; 634 // hM = tM - rM; 635 635 636 fLVt = G4LorentzVector( -nMomDir, sqrt( 636 fLVt = G4LorentzVector( -nMomDir, sqrt( (rM + Ex)*(rM + Ex) + nMom*nMom ) ); // rM ); // 637 fLVh = G4LorentzVector( nMomDir, ei ); 637 fLVh = G4LorentzVector( nMomDir, ei ); // hM); // 638 } 638 } 639 else // 2p2h 639 else // 2p2h 640 { 640 { 641 G4Nucleus recoil(A-2,Z-1); 641 G4Nucleus recoil(A-2,Z-1); 642 rM = recoil.AtomicMass(A-2,Z-1)+sqrt(nMo 642 rM = recoil.AtomicMass(A-2,Z-1)+sqrt(nMom*nMom+fM1*fM1); 643 hM = tM - rM; 643 hM = tM - rM; 644 644 645 fLVt = G4LorentzVector( nMomDir, sqrt( r 645 fLVt = G4LorentzVector( nMomDir, sqrt( rM*rM+nMom*nMom ) ); 646 fLVh = G4LorentzVector(-nMomDir, sqrt( h 646 fLVh = G4LorentzVector(-nMomDir, sqrt( hM*hM+nMom*nMom ) ); 647 } 647 } 648 // G4cout<<hM<<", "; 648 // G4cout<<hM<<", "; 649 // bst = fLVh.boostVector(); 649 // bst = fLVh.boostVector(); 650 650 651 // lvp1.boost(-bst); // -> nucleon rest sy 651 // lvp1.boost(-bst); // -> nucleon rest system, where Q2 transfer is ??? 652 652 653 fNuEnergy = lvp1.e(); 653 fNuEnergy = lvp1.e(); 654 // G4double mN = fLVh.m(); // better mN = 654 // G4double mN = fLVh.m(); // better mN = fM1 !? vmg 655 iTer = 0; 655 iTer = 0; 656 656 657 do // no FM!?, 5.4.20 vmg 657 do // no FM!?, 5.4.20 vmg 658 { 658 { 659 fXsample = SampleXkr(fNuEnergy); 659 fXsample = SampleXkr(fNuEnergy); 660 fQtransfer = SampleQkr(fNuEnergy, fXsamp 660 fQtransfer = SampleQkr(fNuEnergy, fXsample); 661 fQ2 = fQtransfer*fQtransfer; 661 fQ2 = fQtransfer*fQtransfer; 662 662 663 // G4double mR = mN + fM1*(A-1.)*std::ex 663 // G4double mR = mN + fM1*(A-1.)*std::exp(-2.0*fQtransfer/mN); // recoil mass in+el 664 664 665 if( fXsample > 0. ) 665 if( fXsample > 0. ) 666 { 666 { 667 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // 667 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // sample excited hadron mass 668 668 669 // fW2 = mN*mN - fQ2 + fQ2/fXsample; / 669 // fW2 = mN*mN - fQ2 + fQ2/fXsample; // sample excited hadron mass 670 // fEmu = fNuEnergy - fQ2/2./mR/fXsamp 670 // fEmu = fNuEnergy - fQ2/2./mR/fXsample; // fM1->mN 671 671 672 fEmu = fNuEnergy - fQ2/2./fM1/fXsample 672 fEmu = fNuEnergy - fQ2/2./fM1/fXsample; // fM1->mN 673 } 673 } 674 else 674 else 675 { 675 { 676 // fW2 = mN*mN; 676 // fW2 = mN*mN; 677 677 678 fW2 = fM1*fM1; 678 fW2 = fM1*fM1; 679 fEmu = fNuEnergy; 679 fEmu = fNuEnergy; 680 } 680 } 681 // if(fEmu < 0.) G4cout<<"fEmu = "<<fEmu 681 // if(fEmu < 0.) G4cout<<"fEmu = "<<fEmu<<" hM = "<<hM<<G4endl; 682 // e3 = fNuEnergy + mR - fEmu; 682 // e3 = fNuEnergy + mR - fEmu; 683 683 684 e3 = fNuEnergy + fM1 - fEmu; 684 e3 = fNuEnergy + fM1 - fEmu; 685 685 686 // if( e3 < sqrt(fW2) ) G4cout<<"energy 686 // if( e3 < sqrt(fW2) ) G4cout<<"energyX = "<<e3/GeV<<", fW = "<<sqrt(fW2)/GeV<<G4endl; 687 687 688 pMu2 = fEmu*fEmu - fMtau*fMtau; 688 pMu2 = fEmu*fEmu - fMtau*fMtau; 689 pX2 = e3*e3 - fW2; 689 pX2 = e3*e3 - fW2; 690 690 691 if(pMu2 < 0.) { fBreak = true; return; } 691 if(pMu2 < 0.) { fBreak = true; return; } 692 692 693 fCosTheta = fNuEnergy*fNuEnergy + pMu2 693 fCosTheta = fNuEnergy*fNuEnergy + pMu2 - pX2; 694 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2); 694 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2); 695 iTer++; 695 iTer++; 696 } 696 } 697 while( ( abs(fCosTheta) > 1. || fEmu < fMt 697 while( ( abs(fCosTheta) > 1. || fEmu < fMtau ) && iTer < iTerMax ); 698 698 699 if( iTer >= iTerMax ) { fBreak = true; ret 699 if( iTer >= iTerMax ) { fBreak = true; return; } 700 700 701 if( abs(fCosTheta) > 1.) // vmg: due to bi 701 if( abs(fCosTheta) > 1.) // vmg: due to big Q2/x values. To be improved ... 702 { 702 { 703 G4cout<<"FM: fCosTheta = "<<fCosTheta<<" 703 G4cout<<"FM: fCosTheta = "<<fCosTheta<<", fEmu = "<<fEmu<<G4endl; 704 // fCosTheta = -1. + 2.*G4UniformRand(); 704 // fCosTheta = -1. + 2.*G4UniformRand(); 705 if( fCosTheta < -1.) fCosTheta = -1.; 705 if( fCosTheta < -1.) fCosTheta = -1.; 706 if( fCosTheta > 1.) fCosTheta = 1.; 706 if( fCosTheta > 1.) fCosTheta = 1.; 707 } 707 } 708 // LVs 708 // LVs 709 // G4LorentzVector lvt1 = G4LorentzVector 709 // G4LorentzVector lvt1 = G4LorentzVector( 0., 0., 0., mN ); // fM1 ); 710 710 711 G4LorentzVector lvt1 = G4LorentzVector( 0 711 G4LorentzVector lvt1 = G4LorentzVector( 0., 0., 0., fM1 ); // fM1 ); 712 G4LorentzVector lvsum = lvp1 + lvt1; 712 G4LorentzVector lvsum = lvp1 + lvt1; 713 713 714 cost = fCosTheta; 714 cost = fCosTheta; 715 sint = std::sqrt( (1.0 - cost)*(1.0 + cost 715 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) ); 716 phi = G4UniformRand()*CLHEP::twopi; 716 phi = G4UniformRand()*CLHEP::twopi; 717 eP = G4ThreeVector( sint*std::cos(phi), 717 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost ); 718 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 718 muMom = sqrt(fEmu*fEmu-fMtau*fMtau); 719 eP *= muMom; 719 eP *= muMom; 720 fLVl = G4LorentzVector( eP, fEmu ); 720 fLVl = G4LorentzVector( eP, fEmu ); 721 fLVh = lvsum - fLVl; 721 fLVh = lvsum - fLVl; 722 722 723 // if( fLVh.e() < mN || fLVh.m2() < 0.) { 723 // if( fLVh.e() < mN || fLVh.m2() < 0.) { fBreak = true; return; } 724 724 725 if( fLVh.e() < fM1 || fLVh.m2() < 0.) { fB 725 if( fLVh.e() < fM1 || fLVh.m2() < 0.) { fBreak = true; return; } 726 726 727 // back to lab system 727 // back to lab system 728 728 729 // fLVl.boost(bst); 729 // fLVl.boost(bst); 730 // fLVh.boost(bst); 730 // fLVh.boost(bst); 731 } 731 } 732 //G4cout<<iTer<<", "<<fBreak<<"; "; 732 //G4cout<<iTer<<", "<<fBreak<<"; "; 733 } 733 } 734 734 735 // 735 // 736 // 736 // 737 /////////////////////////// 737 /////////////////////////// 738 738