122 G4int n = theSystem->GetTotalNumberOfParticipant();
125 for (
G4int i = 0 ; i < n ; i++ )
127 theSystem->GetParticipant( i )->UnsetHitMark();
128 theSystem->GetParticipant( i )->UnsetHitMark();
135 for (
G4int i = 0 ; i < n ; i++ )
140 if ( theSystem->GetParticipant( i )->GetDefinition()->IsShortLived() )
146 G4ThreeVector p0 = theSystem->GetParticipant( i )->GetMomentum();
147 G4ThreeVector r0 = theSystem->GetParticipant( i )->GetPosition();
151 G4double eini = theMeanField->GetTotalPotential() + p40.
e();
153 G4int n0 = theSystem->GetTotalNumberOfParticipant();
156 G4bool isThisEnergyOK =
false;
158 G4int maximumNumberOfTrial=4;
159 for (
G4int ii = 0 ; ii < maximumNumberOfTrial ; ii++ )
175 for ( G4KineticTrackVector::iterator it
176 = secs->begin() ; it != secs->end() ; it++ )
187 theSystem->GetParticipant( i )->SetDefinition( (*it)->GetDefinition() );
188 theSystem->GetParticipant( i )->SetMomentum( (*it)->Get4Momentum().v()/GeV );
189 theSystem->GetParticipant( i )->SetPosition( (*it)->GetPosition()/fermi );
191 et += (*it)->Get4Momentum().e()/GeV;
196 theSystem->SetParticipant (
new G4QMDParticipant ( (*it)->GetDefinition() , (*it)->Get4Momentum().v()/GeV , (*it)->GetPosition()/fermi ) );
197 et += (*it)->Get4Momentum().e()/GeV;
209 theMeanField->Update();
217 G4double efin = theMeanField->GetTotalPotential() + et;
221 if ( std::abs ( eini - efin ) < fepse*10 )
224 isThisEnergyOK =
true;
230 theSystem->GetParticipant( i )->SetDefinition( pd0 );
231 theSystem->GetParticipant( i )->SetPosition( r0 );
232 theSystem->GetParticipant( i )->SetMomentum( p0 );
236 for (
G4int i0i =
id-2 ; 0 <= i0i ; i0i-- ) {
239 theSystem->DeleteParticipant( i0i+n0 );
242 theMeanField->Update();
249 if ( isThisEnergyOK ==
true )
251 if ( theMeanField->IsPauliBlocked ( i ) !=
true )
255 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
257 if ( theMeanField->IsPauliBlocked ( i0i+n0 ) ==
true )
277 theSystem->GetParticipant( i )->SetHitMark();
278 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
280 theSystem->GetParticipant( i0i+n0 )->SetHitMark();
289 if ( isThisEnergyOK ==
true )
292 theSystem->GetParticipant( i )->SetDefinition( pd0 );
293 theSystem->GetParticipant( i )->SetPosition( r0 );
294 theSystem->GetParticipant( i )->SetMomentum( p0 );
296 for (
G4int i0i = 0 ; i0i < i0 ; i0i++ )
301 theSystem->DeleteParticipant( i0+n0-i0i-1 );
304 theMeanField->Update();
314 n = theSystem->GetTotalNumberOfParticipant();
318 for (
G4int i = 1 ; i < theSystem->GetTotalNumberOfParticipant() ; i++ )
322 if ( theSystem->GetParticipant( i )->IsThisHit() )
continue;
324 G4ThreeVector ri = theSystem->GetParticipant( i )->GetPosition();
326 G4double rmi = theSystem->GetParticipant( i )->GetMass();
332 for (
G4int j = 0 ; j < i ; j++ )
345 if ( theSystem->GetParticipant( i )->IsThisHit() )
continue;
346 if ( theSystem->GetParticipant( j )->IsThisHit() )
continue;
351 if ( theSystem->GetParticipant( i )->IsThisProjectile() )
353 if ( theSystem->GetParticipant( j )->IsThisProjectile() )
continue;
355 else if ( theSystem->GetParticipant( i )->IsThisTarget() )
357 if ( theSystem->GetParticipant( j )->IsThisTarget() )
continue;
361 G4ThreeVector rj = theSystem->GetParticipant( j )->GetPosition();
363 G4double rmj = theSystem->GetParticipant( j )->GetMass();
368 G4double rr2 = theMeanField->GetRR2( i , j );
371 if ( rr2 > fdeltar*fdeltar )
continue;
376 G4double srt = std::sqrt( (p4i+p4j)*(p4i+p4j) );
383 if ( rmi < 0.94 && rmj < 0.94 )
386 cutoff = rmi + rmj + 0.02;
400 if ( srt < cutoff )
continue;
409 G4double aij = 1.0 - ( rmi*rmj /pij ) * ( rmi*rmj /pij );
410 G4double bij = pidr / rmi - pjdr*rmi/pij;
411 G4double cij = rsq + ( pidr / rmi ) * ( pidr / rmi );
412 G4double brel = std::sqrt ( std::abs ( cij - bij*bij/aij ) );
414 if ( brel > fbcmax )
continue;
417 G4double bji = -pjdr/rmj + pidr * rmj /pij;
419 G4double ti = ( pidr/rmi - bij / aij ) * p4i.
e() / rmi;
420 G4double tj = (-pjdr/rmj - bji / aij ) * p4j.
e() / rmj;
437 if ( std::abs ( ti + tj ) > deltaT )
continue;
448 if ( prcm <= 0.00001 )
continue;
479 if ( energetically_forbidden ==
true )
486 theSystem->GetParticipant( i )->SetMomentum( p4i.
vect() );
487 theSystem->GetParticipant( i )->SetDefinition( pdi );
488 theSystem->GetParticipant( i )->SetPosition( ri );
490 theSystem->GetParticipant( j )->SetMomentum( p4j.
vect() );
491 theSystem->GetParticipant( j )->SetDefinition( pdj );
492 theSystem->GetParticipant( j )->SetPosition( rj );
494 theMeanField->Cal2BodyQuantities( i );
495 theMeanField->Cal2BodyQuantities( j );
502 G4bool absorption =
false;
503 if ( n == theSystem->GetTotalNumberOfParticipant()+1 ) absorption =
true;
514 theSystem->GetParticipant( i )->UnsetInitialMark();
515 if ( !absorption ) theSystem->GetParticipant( j )->UnsetInitialMark();
517 theSystem->GetParticipant( i )->SetHitMark();
518 if ( !absorption ) theSystem->GetParticipant( j )->SetHitMark();
520 theSystem->IncrementCollisionCounter();
576 G4double epot = theMeanField->GetTotalPotential();
586 G4ThreeVector ri0 = ( theSystem->GetParticipant( i )->GetPosition() )*fermi;
587 G4ThreeVector rj0 = ( theSystem->GetParticipant( j )->GetPosition() )*fermi;
589 for (
G4int iitry = 0 ; iitry < 4 ; iitry++ )
600 secs = theScatterer->Scatter( kt1 , kt2 );
610 if ( secs->size() == 2 )
612 for ( G4KineticTrackVector::iterator it
613 = secs->begin() ; it != secs->end() ; it++ )
617 theSystem->GetParticipant( i )->SetDefinition( (*it)->GetDefinition() );
618 p4ix_new = (*it)->Get4Momentum()/GeV;
620 theSystem->GetParticipant( i )->SetMomentum( p4ix_new.
v() );
624 theSystem->GetParticipant( j )->SetDefinition( (*it)->GetDefinition() );
625 p4jx_new = (*it)->Get4Momentum()/GeV;
627 theSystem->GetParticipant( j )->SetMomentum( p4jx_new.
v() );
633 else if ( secs->size() == 1 )
639 theSystem->GetParticipant( i )->SetDefinition( secs->front()->GetDefinition() );
640 p4ix_new = secs->front()->Get4Momentum()/GeV;
641 theSystem->GetParticipant( i )->SetMomentum( p4ix_new.
v() );
646 if ( secs->size() > 2 )
649 G4cout <<
"G4QMDCollision secs size > 2; " << secs->size() <<
G4endl;
651 for ( G4KineticTrackVector::iterator it
652 = secs->begin() ; it != secs->end() ; it++ )
654 G4cout <<
"G4QMDSCATTERER AFTER " << (*it)->GetDefinition()->GetParticleName() <<
" " << (*it)->Get4Momentum()/GeV <<
G4endl;
660 for ( G4KineticTrackVector::iterator it
661 = secs->begin() ; it != secs->end() ; it++ )
672 theMeanField->Cal2BodyQuantities( i );
673 theMeanField->Cal2BodyQuantities( j );
677 absorbed = theSystem->EraseParticipant( j );
678 theMeanField->Update();
681 epot = theMeanField->GetTotalPotential();
683 G4double efin = epot + p4ix_new.
e() + p4jx_new.
e();
694 if ( std::abs ( eini - efin ) < fepse )
712 theSystem->InsertParticipant( absorbed , j );
713 theMeanField->Update();
728 if ( !( theMeanField->IsPauliBlocked ( i ) ==
true || theMeanField->IsPauliBlocked ( j ) ==
true ) )
738 if ( theMeanField->IsPauliBlocked ( i-1 ) ==
false )
757 theSystem->InsertParticipant( absorbed , j );
758 theMeanField->Update();
777 G4double rmi = theSystem->GetParticipant( i )->GetMass();
778 G4int zi = theSystem->GetParticipant( i )->GetChargeInUnitOfEplus();
781 G4double rmj = theSystem->GetParticipant( j )->GetMass();
782 G4int zj = theSystem->GetParticipant( j )->GetChargeInUnitOfEplus();
804 elastic = 35.0 / ( 1. + csrt * 100.0 ) + 20.0;
808 elastic = ( - std::atan( ( csrt - 0.4286 ) * 1.5 - 0.8 )
809 * 2. / pi + 1.0 ) * 9.65 + 7.0;
816 elastic = 28.0 / ( 1. + csrt * 100.0 ) + 27.0;
820 elastic = ( - std::atan( ( csrt - 0.4286 ) * 1.5 - 0.8 )
821 * 2. / pi + 1.0 ) * 12.34 + 10.0;
850 if( std::abs(c1) > 1.0 ) c1 = 2.0 * x - 1.0;
863 if ( pcm.
x() == 0.0 && pcm.
y() == 0 )
869 t2 = std::atan2( pcm.
y() , pcm.
x() );
873 G4double s1 = std::sqrt ( 1.0 - c1*c1 );
874 G4double s2 = std::sqrt ( 1.0 - c2*c2 );
884 pcm.
setX( pr * ( ss*ct2 - s1*st1*st2) );
885 pcm.
setY( pr * ( ss*st2 + s1*st1*ct2) );
886 pcm.
setZ( pr * ( c1*c2 - s1*s2*ct1) );
890 G4double epot = theMeanField->GetTotalPotential();
902 for (
G4int itry = 0 ; itry < 4 ; itry++ )
905 G4double eicm = std::sqrt ( rmi*rmi + pcm*pcm );
908 G4double trans = gamma * ( gamma * pibeta / ( gamma + 1 ) + eicm );
912 G4double ejcm = std::sqrt ( rmj*rmj + pcm*pcm );
913 trans = gamma * ( gamma * pibeta / ( gamma + 1 ) + ejcm );
925 theSystem->GetParticipant( i )->SetMomentum( pi_new );
926 theSystem->GetParticipant( j )->SetMomentum( pj_new );
928 G4double pi_new_e = (theSystem->GetParticipant( i )->Get4Momentum()).e();
929 G4double pj_new_e = (theSystem->GetParticipant( j )->Get4Momentum()).e();
931 theMeanField->Cal2BodyQuantities( i );
932 theMeanField->Cal2BodyQuantities( j );
934 epot = theMeanField->GetTotalPotential();
936 G4double efin = epot + pi_new_e + pj_new_e ;
946 if ( std::abs ( eini - efin ) < fepse )
958 if ( std::abs ( eini - efin ) < fepse )
return result;
960 G4double cona = ( eini - efin + etwo ) / gamma;
961 G4double fac2 = 1.0 / ( 4.0 * cona*cona * pr*pr ) *
962 ( ( cona*cona - ( rmi*rmi + rmj*rmj ) )*( cona*cona - ( rmi*rmi + rmj*rmj ) )
963 - 4.0 * rmi*rmi * rmj*rmj );