57 const G4int z[6] = {0, 1, 1, 1, 2, 2};
58 const G4int a[6] = {1, 1, 2, 3, 3, 4};
59 for(
G4int i=0; i<6; ++i) {
85 G4double deltaE, mass, mass1(0.0), mass2(0.0);
90 for(
G4int ia=0; ia<Amax; ++ia) {
96 G4int Zres = Z - Zfr[i];
97 G4int Ares = A - Afr[i];
98 if(Zres >= 0 && Ares >= Zres && Ares > 0) {
100 G4double de = mass - m1 - masses[i];
111 if(index < 0) {
break; }
114 G4double e2 = 0.5*((mass - mass1)*(mass + mass1) + mass2*mass2)/mass;
115 if(e2 < mass2) {
break; }
121 G4double sinTheta = std::sqrt(1. - cosTheta * cosTheta);
123 G4double mom = std::sqrt((e2 - mass2)*(e2 + mass2));
125 mom * sinTheta * std::sin(phi),
131 theResult->push_back(fr);
140 if( theResult->size() > 0) {
Hep3Vector boostVector() const
static G4double GetNuclearMass(const G4double A, const G4double Z)
G4UnstableFragmentBreakUp()
static G4NistManager * Instance()
virtual G4FragmentVector * BreakUp(const G4Fragment &fragment)
virtual G4FragmentVector * BreakUpFragment(G4Fragment *fragment)
G4double GetCreationTime() const
const G4LorentzVector & GetMomentum() const
HepLorentzVector & boost(double, double, double)
void SetMomentum(const G4LorentzVector &value)
std::vector< G4Fragment * > G4FragmentVector
void SetCreationTime(G4double time)
void SetZandA_asInt(G4int Znew, G4int Anew)
virtual G4double GetEmissionProbability(G4Fragment *fragment)
virtual G4Fragment * EmittedFragment(G4Fragment *fragment)
virtual ~G4UnstableFragmentBreakUp()