125 G4int n = theSystem->GetTotalNumberOfParticipant();
128 for (
G4int i = 0 ; i < n ; i++ )
130 theSystem->GetParticipant( i )->UnsetHitMark();
131 theSystem->GetParticipant( i )->UnsetHitMark();
138 for (
G4int i = 0 ; i < n ; i++ )
143 if ( theSystem->GetParticipant( i )->GetDefinition()->IsShortLived() )
149 G4ThreeVector p0 = theSystem->GetParticipant( i )->GetMomentum();
150 G4ThreeVector r0 = theSystem->GetParticipant( i )->GetPosition();
154 G4double eini = theMeanField->GetTotalEnergy();
156 G4int n0 = theSystem->GetTotalNumberOfParticipant();
159 G4bool isThisEnergyOK =
false;
161 G4int maximumNumberOfTrial=4;
162 for (
G4int ii = 0 ; ii < maximumNumberOfTrial ; ii++ )
178 for ( G4KineticTrackVector::iterator it
179 = secs->begin() ; it != secs->end() ; it++ )
190 theSystem->GetParticipant( i )->SetDefinition( (*it)->GetDefinition() );
191 theSystem->GetParticipant( i )->SetMomentum( (*it)->Get4Momentum().v()/GeV );
192 theSystem->GetParticipant( i )->SetPosition( (*it)->GetPosition()/fermi );
199 theSystem->SetParticipant (
new G4QMDParticipant ( (*it)->GetDefinition() , (*it)->Get4Momentum().v()/GeV , (*it)->GetPosition()/fermi ) );
212 theMeanField->Update();
220 G4double efin = theMeanField->GetTotalEnergy();
224 if ( std::abs ( eini - efin ) < fepse*10 )
227 isThisEnergyOK =
true;
233 theSystem->GetParticipant( i )->SetDefinition( pd0 );
234 theSystem->GetParticipant( i )->SetPosition( r0 );
235 theSystem->GetParticipant( i )->SetMomentum( p0 );
239 for (
G4int i0i =
id-2 ; 0 <= i0i ; i0i-- ) {
242 theSystem->DeleteParticipant( i0i+n0 );
245 theMeanField->Update();
252 if ( isThisEnergyOK ==
true )
254 if ( theMeanField->IsPauliBlocked ( i ) !=
true )
258 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
260 if ( theMeanField->IsPauliBlocked ( i0i+n0 ) ==
true )
280 theSystem->GetParticipant( i )->SetHitMark();
281 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
283 theSystem->GetParticipant( i0i+n0 )->SetHitMark();
292 if ( isThisEnergyOK ==
true )
295 theSystem->GetParticipant( i )->SetDefinition( pd0 );
296 theSystem->GetParticipant( i )->SetPosition( r0 );
297 theSystem->GetParticipant( i )->SetMomentum( p0 );
299 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
304 theSystem->DeleteParticipant( i0+n0-i0i-1 );
307 theMeanField->Update();
317 n = theSystem->GetTotalNumberOfParticipant();
321 for (
G4int i = 1 ; i < theSystem->GetTotalNumberOfParticipant() ; i++ )
325 if ( theSystem->GetParticipant( i )->IsThisHit() )
continue;
328 G4ThreeVector ri = theSystem->GetParticipant( i )->GetPosition();
330 G4double rmi = theSystem->GetParticipant( i )->GetMass();
336 for (
G4int j = 0 ; j < i ; j++ )
349 if ( theSystem->GetParticipant( i )->IsThisHit() )
continue;
350 if ( theSystem->GetParticipant( j )->IsThisHit() )
continue;
355 if ( theSystem->GetParticipant( i )->IsThisProjectile() )
357 if ( theSystem->GetParticipant( j )->IsThisProjectile() )
continue;
359 else if ( theSystem->GetParticipant( i )->IsThisTarget() )
361 if ( theSystem->GetParticipant( j )->IsThisTarget() )
continue;
365 G4ThreeVector rj = theSystem->GetParticipant( j )->GetPosition();
367 G4double rmj = theSystem->GetParticipant( j )->GetMass();
372 G4double rr2 = theMeanField->GetRR2( i , j );
375 if ( rr2 > fdeltar*fdeltar )
continue;
380 G4double srt = std::sqrt( (p4i+p4j)*(p4i+p4j) );
387 if ( rmi < 0.94 && rmj < 0.94 )
390 cutoff = rmi + rmj + 0.02;
404 if ( srt < cutoff )
continue;
413 G4double aij = 1.0 - ( rmi*rmj /pij ) * ( rmi*rmj /pij );
414 G4double bij = pidr / rmi - pjdr*rmi/pij;
415 G4double cij = rsq + ( pidr / rmi ) * ( pidr / rmi );
416 G4double brel = std::sqrt ( std::abs ( cij - bij*bij/aij ) );
418 if ( brel > fbcmax )
continue;
421 G4double bji = -pjdr/rmj + pidr * rmj /pij;
423 G4double ti = ( pidr/rmi - bij / aij ) * p4i.
e() / rmi;
424 G4double tj = (-pjdr/rmj - bji / aij ) * p4j.
e() / rmj;
441 if ( std::abs ( ti + tj ) > deltaT )
continue;
452 if ( prcm <= 0.00001 )
continue;
483 if ( energetically_forbidden ==
true )
490 theSystem->GetParticipant( i )->SetMomentum( p4i.
vect() );
491 theSystem->GetParticipant( i )->SetDefinition( pdi );
492 theSystem->GetParticipant( i )->SetPosition( ri );
494 theSystem->GetParticipant( j )->SetMomentum( p4j.
vect() );
495 theSystem->GetParticipant( j )->SetDefinition( pdj );
496 theSystem->GetParticipant( j )->SetPosition( rj );
498 theMeanField->Cal2BodyQuantities( i );
499 theMeanField->Cal2BodyQuantities( j );
506 G4bool absorption =
false;
507 if ( n == theSystem->GetTotalNumberOfParticipant()+1 ) absorption =
true;
518 theSystem->GetParticipant( i )->UnsetInitialMark();
519 if ( !absorption ) theSystem->GetParticipant( j )->UnsetInitialMark();
521 theSystem->GetParticipant( i )->SetHitMark();
522 if ( !absorption ) theSystem->GetParticipant( j )->SetHitMark();
524 theSystem->IncrementCollisionCounter();
569 G4int k = theSystem->GetTotalNumberOfParticipant();
586 G4double eini = theMeanField->GetTotalEnergy();
594 G4ThreeVector ri0 = ( theSystem->GetParticipant( i )->GetPosition() )*fermi;
595 G4ThreeVector rj0 = ( theSystem->GetParticipant( j )->GetPosition() )*fermi;
597 for (
G4int iitry = 0 ; iitry < 4 ; iitry++ )
609 secs = theScatterer->Scatter( kt1 , kt2 );
619 if ( secs->size() == 2 )
621 for ( G4KineticTrackVector::iterator it
622 = secs->begin() ; it != secs->end() ; it++ )
626 theSystem->GetParticipant( i )->SetDefinition( (*it)->GetDefinition() );
627 p4ix_new = (*it)->Get4Momentum()/GeV;
629 theSystem->GetParticipant( i )->SetMomentum( p4ix_new.
v() );
639 if((*it)->GetDefinition()->IsShortLived())
644 for(G4KineticTrackVector::iterator jter=dec->begin(); jter != dec->end(); jter++)
650 theSystem->SetParticipant(
new G4QMDParticipant( (*jter)->GetDefinition() , (*jter)->Get4Momentum().v()/GeV , (*jter)->GetPosition()/fermi ) );
654 theSystem->GetParticipant( k )->SetDefinition( (*jter)->GetDefinition() );
657 p4kx_new = (*jter)->Get4Momentum()/GeV;
658 theSystem->GetParticipant( k )->SetMomentum( p4kx_new.
v() );
664 theSystem->GetParticipant( j )->SetDefinition( (*jter)->GetDefinition() );
665 p4jx_new = (*jter)->Get4Momentum()/GeV;
666 theSystem->GetParticipant( j )->SetMomentum( p4jx_new.
v() );
675 std::cout <<
"************ Multi-particle decay ************" << std::endl;
690 theSystem->GetParticipant( j )->SetDefinition( (*it)->GetDefinition() );
691 p4jx_new = (*it)->Get4Momentum()/GeV;
693 theSystem->GetParticipant( j )->SetMomentum( p4jx_new.
v() );
701 else if ( secs->size() == 1 )
708 if(secs->front()->GetDefinition()->IsShortLived())
712 for(G4KineticTrackVector::iterator jter=dec->begin(); jter != dec->end(); jter++)
717 theSystem->GetParticipant( i )->SetDefinition( (*jter)->GetDefinition() );
718 p4ix_new = (*jter)->Get4Momentum()/GeV;
719 theSystem->GetParticipant( i )->SetMomentum( p4ix_new.
v() );
723 theSystem->GetParticipant( j )->SetDefinition( (*jter)->GetDefinition() );
724 p4jx_new = (*jter)->Get4Momentum()/GeV;
725 theSystem->GetParticipant( j )->SetMomentum( p4jx_new.
v() );
731 std::cout <<
"************ Multi-particle decay ************" << std::endl;
739 theSystem->GetParticipant( i )->SetDefinition( secs->front()->GetDefinition() );
740 p4ix_new = secs->front()->Get4Momentum()/GeV;
741 theSystem->GetParticipant( i )->SetMomentum( p4ix_new.
v() );
757 if ( secs->size() > 2 )
760 G4cout <<
"G4LightIonQMDCollision secs size > 2; " << secs->size() <<
G4endl;
762 for ( G4KineticTrackVector::iterator it
763 = secs->begin() ; it != secs->end() ; it++ )
765 G4cout <<
"G4QMDSCATTERER AFTER " << (*it)->GetDefinition()->GetParticleName() <<
" " << (*it)->Get4Momentum()/GeV <<
G4endl;
771 for ( G4KineticTrackVector::iterator it
772 = secs->begin() ; it != secs->end() ; it++ )
785 theMeanField->Update();
790 absorbed = theSystem->EraseParticipant( j );
791 theMeanField->Update();
796 G4double efin = theMeanField->GetTotalEnergy();
809 if ( std::abs ( eini - efin ) < fepse )
864 theSystem->InsertParticipant( absorbed , j );
865 theMeanField->Update();
867 else if ( pion_prod )
870 theSystem->EraseParticipant( k );
871 theMeanField->Update();
872 theSystem->GetParticipant( i )->SetDefinition( pdi0 );
873 theSystem->GetParticipant( i )->SetMomentum( p4i.
v() );
874 theSystem->GetParticipant( j )->SetDefinition( pdj0 );
875 theSystem->GetParticipant( j )->SetMomentum( p4j.
v() );
876 theMeanField->Update();
881 theSystem->GetParticipant( i )->SetDefinition( pdi0 );
882 theSystem->GetParticipant( i )->SetMomentum( p4i.
v() );
884 theSystem->GetParticipant( j )->SetDefinition( pdj0 );
885 theSystem->GetParticipant( j )->SetMomentum( p4j.
v() );
886 theMeanField->Update();
901 if ( !( theMeanField->IsPauliBlocked ( i ) ==
true || theMeanField->IsPauliBlocked ( j ) ==
true ) )
911 if ( theMeanField->IsPauliBlocked ( i-1 ) ==
false )
930 theSystem->InsertParticipant( absorbed , j );
931 theMeanField->Update();
933 else if ( pion_prod )
936 theSystem->EraseParticipant( k );
937 theMeanField->Update();
938 theSystem->GetParticipant( i )->SetDefinition( pdi0 );
939 theSystem->GetParticipant( i )->SetMomentum( p4i.
v() );
940 theSystem->GetParticipant( j )->SetDefinition( pdj0 );
941 theSystem->GetParticipant( j )->SetMomentum( p4j.
v() );
942 theMeanField->Update();
947 theSystem->GetParticipant( i )->SetDefinition( pdi0 );
948 theSystem->GetParticipant( i )->SetMomentum( p4i.
v() );
950 theSystem->GetParticipant( j )->SetDefinition( pdj0 );
951 theSystem->GetParticipant( j )->SetMomentum( p4j.
v() );
952 theMeanField->Update();
971 G4double rmi = theSystem->GetParticipant( i )->GetMass();
972 G4int zi = theSystem->GetParticipant( i )->GetChargeInUnitOfEplus();
975 G4double rmj = theSystem->GetParticipant( j )->GetMass();
976 G4int zj = theSystem->GetParticipant( j )->GetChargeInUnitOfEplus();
998 elastic = 35.0 / ( 1. + csrt * 100.0 ) + 20.0;
1002 elastic = ( - std::atan( ( csrt - 0.4286 ) * 1.5 - 0.8 )
1003 * 2. / pi + 1.0 ) * 9.65 + 7.0;
1008 if ( csrt < 0.4286 )
1010 elastic = 28.0 / ( 1. + csrt * 100.0 ) + 27.0;
1014 elastic = ( - std::atan( ( csrt - 0.4286 ) * 1.5 - 0.8 )
1015 * 2. / pi + 1.0 ) * 12.34 + 10.0;
1038 G4double a = 6.0 * as / (1.0 + as);
1044 if( std::abs(c1) > 1.0 ) c1 = 2.0 * x - 1.0;
1057 if ( pcm.
x() == 0.0 && pcm.
y() == 0 )
1063 t2 = std::atan2( pcm.
y() , pcm.
x() );
1067 G4double s1 = std::sqrt ( 1.0 - c1*c1 );
1068 G4double s2 = std::sqrt ( 1.0 - c2*c2 );
1078 pcm.
setX( pr * ( ss*ct2 - s1*st1*st2) );
1079 pcm.
setY( pr * ( ss*st2 + s1*st1*ct2) );
1080 pcm.
setZ( pr * ( c1*c2 - s1*s2*ct1) );
1084 G4double epot = theMeanField->GetTotalPotential();
1096 for (
G4int itry = 0 ; itry < 4 ; itry++ )
1099 G4double eicm = std::sqrt ( rmi*rmi + pcm*pcm );
1102 G4double trans = gamma * ( gamma * pibeta / ( gamma + 1 ) + eicm );
1106 G4double ejcm = std::sqrt ( rmj*rmj + pcm*pcm );
1107 trans = gamma * ( gamma * pibeta / ( gamma + 1 ) + ejcm );
1119 theSystem->GetParticipant( i )->SetMomentum( pi_new );
1120 theSystem->GetParticipant( j )->SetMomentum( pj_new );
1125 theMeanField->Cal2BodyQuantities( i );
1126 theMeanField->Cal2BodyQuantities( j );
1130 G4double efin = theMeanField->GetTotalEnergy();
1139 if ( std::abs ( eini - efin ) < fepse )
1151 if ( std::abs ( eini - efin ) < fepse )
return result;
1153 G4double cona = ( eini - efin + etwo ) / gamma;
1154 G4double fac2 = 1.0 / ( 4.0 * cona*cona * pr*pr ) *
1155 ( ( cona*cona - ( rmi*rmi + rmj*rmj ) )*( cona*cona - ( rmi*rmi + rmj*rmj ) )
1156 - 4.0 * rmi*rmi * rmj*rmj );
1160 G4double fact = std::sqrt ( fac2 );