128 if ( system->GetTotalNumberOfParticipant() < 2 ) {
return; }
130 for (
G4int j = 1 ; j < system->GetTotalNumberOfParticipant() ; ++j )
132 G4ThreeVector rj = system->GetParticipant( j )->GetPosition();
135 for (
G4int i = 0 ; i < j ; ++i )
137 G4ThreeVector ri = system->GetParticipant( i )->GetPosition();
144 G4double gammaij = ( p4i + p4j ).gamma();
152 rbrb = irelcr * rbrb;
153 G4double gamma2_ij = gammaij*gammaij;
155 rr2[i][j] = rij2 + gamma2_ij * rbrb*rbrb;
156 rr2[j][i] = rr2[i][j];
158 rbij[i][j] = gamma2_ij * rbrb;
159 rbij[j][i] = - rbij[i][j];
165 pp2[j][i] = pp2[i][j];
174 rh1 =
G4Exp( expa1 );
181 G4int ibry = system->GetParticipant(i)->GetBaryonNumber();
182 G4int jbry = system->GetParticipant(j)->GetBaryonNumber();
184 rha[i][j] = ibry*jbry*rh1;
185 rha[j][i] = rha[i][j];
192 G4int icharge = system->GetParticipant(i)->GetChargeInUnitOfEplus();
193 G4int jcharge = system->GetParticipant(j)->GetChargeInUnitOfEplus();
197 if ( rrs*c0sw < 5.8 )
202 xerf = std::erf ( rrs*c0sw );
212 rhe[i][j] = icharge*jcharge * erfij;
213 rhe[j][i] = rhe[i][j];
214 rhc[i][j] = icharge*jcharge * ( - erfij + clw * rh1 ) / rrs2;
215 rhc[j][i] = rhc[i][j];
222 G4ThreeVector ri = system->GetParticipant( i )->GetPosition();
225 for (
G4int j = 0 ; j < system->GetTotalNumberOfParticipant() ; ++j )
227 if ( j == i ) {
continue; }
229 G4ThreeVector rj = system->GetParticipant( j )->GetPosition();
236 G4double gammaij = ( p4i + p4j ).gamma();
244 rbrb = irelcr * rbrb;
245 G4double gamma2_ij = gammaij*gammaij;
247 rr2[i][j] = rij2 + gamma2_ij * rbrb*rbrb;
248 rr2[j][i] = rr2[i][j];
250 rbij[i][j] = gamma2_ij * rbrb;
251 rbij[j][i] = - rbij[i][j];
257 pp2[j][i] = pp2[i][j];
266 rh1 =
G4Exp( expa1 );
273 G4int ibry = system->GetParticipant(i)->GetBaryonNumber();
274 G4int jbry = system->GetParticipant(j)->GetBaryonNumber();
276 rha[i][j] = ibry*jbry*rh1;
277 rha[j][i] = rha[i][j];
284 G4int icharge = system->GetParticipant(i)->GetChargeInUnitOfEplus();
285 G4int jcharge = system->GetParticipant(j)->GetChargeInUnitOfEplus();
289 if ( rrs*c0sw < 5.8 )
294 xerf = std::erf ( rrs*c0sw );
304 rhe[i][j] = icharge*jcharge * erfij;
305 rhe[j][i] = rhe[i][j];
306 rhc[i][j] = icharge*jcharge * ( - erfij + clw * rh1 ) / rrs2;
307 rhc[j][i] = rhc[i][j];
313 ffr.resize( system->GetTotalNumberOfParticipant() );
314 ffp.resize( system->GetTotalNumberOfParticipant() );
315 rh3d.resize( system->GetTotalNumberOfParticipant() );
317 for (
G4int i = 0 ; i < system->GetTotalNumberOfParticipant() ; ++i )
320 for (
G4int j = 0 ; j < system->GetTotalNumberOfParticipant() ; ++j )
327 for (
G4int i = 0 ; i < system->GetTotalNumberOfParticipant() ; ++i )
329 G4ThreeVector ri = system->GetParticipant( i )->GetPosition();
336 G4double p_zero = std::sqrt( p4i.
e()*p4i.
e() + 2*p4i.
m()*Vi);
343 for (
G4int j = 0 ; j < system->GetTotalNumberOfParticipant() ; ++j )
345 G4ThreeVector rj = system->GetParticipant( j )->GetPosition();
350 G4int icharge = system->GetParticipant(i)->GetChargeInUnitOfEplus();
351 G4int jcharge = system->GetParticipant(j)->GetChargeInUnitOfEplus();
353 G4int inuc = system->GetParticipant(i)->GetNuc();
354 G4int jnuc = system->GetParticipant(j)->GetNuc();
357 + c3g * rha[j][i] * ( rh3d[j] + rh3d[i] )
358 + csg * rha[j][i] * jnuc * inuc
359 * ( 1. - 2. * std::abs( jcharge - icharge ) )
370 ffr[i] = ffr[i] + 2*ccrr* ( rij + grbb*cij );
371 ffp[i] = ffp[i] - 2*ccpp* ( rij + grbb*betaij );
407 G4int n = system->GetTotalNumberOfParticipant();
409 std::vector < G4double > rhoa ( n , 0.0 );
410 std::vector < G4double > rho3 ( n , 0.0 );
411 std::vector < G4double > rhos ( n , 0.0 );
412 std::vector < G4double > rhoc ( n , 0.0 );
414 for (
G4int i = 0 ; i < n ; ++i )
416 G4int icharge = system->GetParticipant(i)->GetChargeInUnitOfEplus();
417 G4int inuc = system->GetParticipant(i)->GetNuc();
419 for (
G4int j = 0 ; j < n ; ++j )
421 G4int jcharge = system->GetParticipant(j)->GetChargeInUnitOfEplus();
422 G4int jnuc = system->GetParticipant(j)->GetNuc();
424 rhoa[i] += rha[j][i];
425 rhoc[i] += rhe[j][i];
426 rhos[i] += rha[j][i] * jnuc * inuc
427 * ( 1 - 2 * std::abs ( jcharge - icharge ) );
434 return c0 * std::accumulate( rhoa.cbegin() , rhoa.cend() , 0.0 )
435 + c3 * std::accumulate( rho3.cbegin() , rho3.cend() , 0.0 )
436 + cs * std::accumulate( rhos.cbegin() , rhos.cend() , 0.0 )
437 + cl * std::accumulate( rhoc.cbegin() , rhoc.cend() , 0.0 );
495 G4int n = system->GetTotalNumberOfParticipant();
499 std::vector< G4ThreeVector > f0r, f0p;
503 for (
G4int i = 0 ; i < n ; ++i )
505 G4ThreeVector ri = system->GetParticipant( i )->GetPosition();
506 G4ThreeVector p3i = system->GetParticipant( i )->GetMomentum();
514 system->GetParticipant( i )->SetPosition( ri );
515 system->GetParticipant( i )->SetMomentum( p3i );
525 for (
G4int i = 0 ; i < n ; ++i )
527 G4ThreeVector ri = system->GetParticipant( i )->GetPosition();
528 G4ThreeVector p3i = system->GetParticipant( i )->GetMomentum();
530 ri += dt1* f0r[i] + dt2* ffr[i];
531 p3i += dt1* f0p[i] + dt2* ffp[i];
533 system->GetParticipant( i )->SetPosition( ri );
534 system->GetParticipant( i )->SetMomentum( p3i );
550 G4int n = system->GetTotalNumberOfParticipant();
551 std::vector < G4double > rhoa;
554 for (
G4int i = 0 ; i < n ; ++i )
558 if ( system->GetParticipant( i )->GetBaryonNumber() == 1 )
560 for (
G4int j = 0 ; j < n ; ++j )
562 if ( system->GetParticipant( j )->GetBaryonNumber() == 1 )
563 rhoa[i] += rha[i][j];
571 std::vector < G4bool > is_already_belong_some_cluster;
574 std::multimap < G4int , G4int > comb_map;
575 std::multimap < G4int , G4int > assign_map;
578 std::vector < G4int > mascl;
579 std::vector < G4int > num;
582 is_already_belong_some_cluster.resize ( n );
584 std::vector < G4int > is_assigned_to ( n , -1 );
585 std::multimap < G4int , G4int > clusters;
587 for (
G4int i = 0 ; i < n ; ++i )
591 is_already_belong_some_cluster[i] =
false;
596 G4int cluster_id = -1;
597 for (
G4int i = 0 ; i < n-1 ; ++i )
599 G4bool hasThisCompany =
false;
601 if ( system->GetParticipant( i )->GetBaryonNumber() == 1 )
604 for (
G4int j = j1 ; j < n ; ++j )
606 std::vector < G4int > cluster_participants;
607 if ( system->GetParticipant( j )->GetBaryonNumber() == 1 )
612 * ( rhoa[ i ] + rhoa[ j ] )
613 * ( rhoa[ i ] + rhoa[ j ] );
616 if ( rdist2 < rcc2 && pdist2 < pcc2 )
618 if ( is_assigned_to [ j ] == -1 )
620 if ( is_assigned_to [ i ] == -1 )
622 if ( clusters.size() != 0 )
624 id = clusters.rbegin()->first + 1;
630 clusters.insert ( std::multimap<G4int,G4int>::value_type (
id , i ) );
631 is_assigned_to [ i ] = id;
632 clusters.insert ( std::multimap<G4int,G4int>::value_type (
id , j ) );
633 is_assigned_to [ j ] = id;
637 clusters.insert ( std::multimap<G4int,G4int>::value_type ( is_assigned_to [ i ] , j ) );
638 is_assigned_to [ j ] = is_assigned_to [ i ];
644 if ( is_assigned_to [ i ] == -1 )
646 clusters.insert ( std::multimap<G4int,G4int>::value_type ( is_assigned_to [ j ] , i ) );
647 is_assigned_to [ i ] = is_assigned_to [ j ];
652 if ( is_assigned_to [ i ] != is_assigned_to [ j ] )
655 std::multimap< G4int , G4int > clusters_tmp;
656 G4int target_cluster_id;
657 if ( is_assigned_to [ i ] > is_assigned_to [ j ] )
659 target_cluster_id = is_assigned_to [ i ];
663 target_cluster_id = is_assigned_to [ j ];
665 for (
auto it = clusters.cbegin() ; it != clusters.cend() ; ++it )
667 if ( it->first == target_cluster_id )
669 is_assigned_to [ it->second ] = is_assigned_to [ j ];
670 clusters_tmp.insert(std::multimap<G4int,G4int>::value_type(is_assigned_to[j], it->second));
674 clusters_tmp.insert(std::multimap<G4int,G4int>::value_type(it->first, it->second));
677 clusters = std::move(clusters_tmp);
682 comb_map.insert( std::multimap<G4int,G4int>::value_type ( i , j ) );
683 cluster_participants.push_back ( j );
685 if ( assign_map.find( cluster_id ) == assign_map.end() )
687 is_already_belong_some_cluster[i] =
true;
688 assign_map.insert ( std::multimap<G4int,G4int>::value_type ( cluster_id , i ) );
689 hasThisCompany =
true;
691 assign_map.insert ( std::multimap<G4int,G4int>::value_type ( cluster_id , j ) );
692 is_already_belong_some_cluster[j] =
true;
702 if ( hasThisCompany ==
true ) { ++cluster_id; }
708 std::multimap< G4int , G4int > sorted_cluster_map;
709 for (
G4int i = 0 ; i <= id ; ++i )
711 sorted_cluster_map.insert ( std::multimap<G4int,G4int>::value_type ( (
G4int) clusters.count( i ) , i ) );
715 std::vector < G4QMDNucleus* > result;
716 for (
auto it = sorted_cluster_map.crbegin(); it != sorted_cluster_map.crend(); ++it )
718 if ( it->first != 0 )
721 for (
auto itt = clusters.cbegin(); itt != clusters.cend(); ++itt )
723 if ( it->second == itt->first )
725 nucleus->
SetParticipant( system->GetParticipant ( itt->second ) );
728 result.push_back( nucleus );
733 for (
auto it = result.cbegin(); it != result.cend(); ++it )
735 system->SubtractSystem ( *it );