186 G4double RMSMotherMoleculeDisplacement(0.0);
189 case Ionisation_DissociationDecay:
190 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
192 case A1B1_DissociationDecay:
193 RMSMotherMoleculeDisplacement = 0.0 * nanometer;
195 case B1A1_DissociationDecay:
196 RMSMotherMoleculeDisplacement = 0.0 * nanometer;
198 case B1A1_DissociationDecay2:
199 RMSMotherMoleculeDisplacement = 0.0 * nanometer;
202 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
204 case DissociativeAttachment:
205 RMSMotherMoleculeDisplacement = 0.0 * nanometer;
207 case DoubleIonisation_DissociationDecay1:
208 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
210 case DoubleIonisation_DissociationDecay2:
211 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
213 case DoubleIonisation_DissociationDecay3:
214 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
216 case TripleIonisation_DissociationDecay:
217 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
219 case QuadrupleIonisation_DissociationDecay:
220 RMSMotherMoleculeDisplacement = 2.0 * nanometer;
224 if (RMSMotherMoleculeDisplacement == 0) {
231 return RandDirection;
240 vector<G4ThreeVector> theProductDisplacementVector(nbProducts);
242 typedef map<const G4MoleculeDefinition*, G4double> RMSmap;
248 case Ionisation_DissociationDecay:
256 if (RdmValue < 0.5) {
268 for (
G4int i = 0; i < nbProducts; i++) {
270 G4double theRMSDisplacement = theRMSmap[pProduct->GetDefinition()];
272 if (theRMSDisplacement == 0.0) {
277 theProductDisplacementVector[i] = RandDirection;
282 case A1B1_DissociationDecay:
289 constexpr G4double theRMSDisplacement = 2.4 * nanometer;
292 for (
G4int i = 0; i < nbProducts; i++) {
296 theProductDisplacementVector[i] = -1.0 / 18.0 * RandDirection;
298 theProductDisplacementVector[i] = +17.0 / 18.0 * RandDirection;
303 case B1A1_DissociationDecay:
310 constexpr G4double theRMSDisplacement = 0.8 * nanometer;
314 for (
G4int i = 0; i < nbProducts; ++i) {
316 if (pProduct->GetDefinition() == G4H2::Definition()) {
321 theProductDisplacementVector[i] = -16.0 / 18.0 * RandDirection;
327 G4ThreeVector OxygenDisplacement = +2.0 / 18.0 * RandDirection;
328 constexpr G4double OHRMSDisplacement = 1.1 * nanometer;
330 auto OHDisplacement =
334 OHDisplacement = 0.5 * OHDisplacement;
336 OHDisplacement = -0.5 * OHDisplacement;
339 theProductDisplacementVector[i] =
340 OHDisplacement + OxygenDisplacement;
347 case B1A1_DissociationDecay2:
355 for (
G4int i = 0; i < nbProducts; ++i) {
362 constexpr G4double HRMSDisplacement = 1.6 * nanometer;
368 HDisplacement = 0.5 * HDisplacement;
370 HDisplacement = -0.5 * HDisplacement;
372 theProductDisplacementVector[i] = HDisplacement;
388 if (RdmValue < 0.5) {
400 for (
G4int i = 0; i < nbProducts; i++) {
402 auto theRMSDisplacement = theRMSmap[pProduct->GetDefinition()];
404 if (theRMSDisplacement == 0) {
409 theProductDisplacementVector[i] = RandDirection;
417 case DissociativeAttachment:
423 constexpr G4double theRMSDisplacement = 0.8 * nanometer;
427 for (
G4int i = 0; i < nbProducts; ++i) {
429 if (pProduct->GetDefinition() == G4H2::Definition()) {
434 theProductDisplacementVector[i] = -16.0 / 18.0 * RandDirection;
440 G4ThreeVector OxygenDisplacement = +2.0 / 18.0 * RandDirection;
441 constexpr G4double OHRMSDisplacement = 1.1 * nanometer;
443 auto OHDisplacement =
447 OHDisplacement = 0.5 * OHDisplacement;
449 OHDisplacement = -0.5 * OHDisplacement;
451 theProductDisplacementVector[i] = OHDisplacement +
458 case DoubleIonisation_DissociationDecay1:
461 G4cout <<
"DoubleIonisation_DissociationDecay1" <<
G4endl;
471 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
478 constexpr G4double H3Op_rms = 0.3 * nanometer;
483 theProductDisplacementVector[i]
490 case DoubleIonisation_DissociationDecay2:
493 G4cout <<
"DoubleIonisation_DissociationDecay2" <<
G4endl;
508 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
515 constexpr G4double OH_rms = 0.3 * nanometer;
516 theProductDisplacementVector[i]
518 theProductDisplacementVector[i] += OH_disp;
522 theProductDisplacementVector[i] = OH_disp;
526 theProductDisplacementVector[i]
533 case DoubleIonisation_DissociationDecay3:
536 G4cout <<
"DoubleIonisation_DissociationDecay3" <<
G4endl;
546 for (
G4int i = 0; i < nbProducts; i++) {
550 theProductDisplacementVector[i]
557 case TripleIonisation_DissociationDecay:
560 G4cout <<
"TripleIonisation_DissociationDecay" <<
G4endl;
581 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
588 constexpr G4double H3Op_rms = 0.3 * nanometer;
589 theProductDisplacementVector[i]
591 theProductDisplacementVector[i] += OH_disp;
595 theProductDisplacementVector[i] = OH_disp;
599 theProductDisplacementVector[i]
606 case QuadrupleIonisation_DissociationDecay:
609 G4cout <<
"QuadrupleIonisation_DissociationDecay" <<
G4endl;
634 for (
G4int i = 0, num_H3O = 0, num_OH = 0; i < nbProducts; i++) {
641 constexpr G4double H3Op_rms = 0.3 * nanometer;
644 theProductDisplacementVector[i]
646 theProductDisplacementVector[i] += OH_disp1;
648 }
else if (num_H3O == 4) {
649 theProductDisplacementVector[i]
651 theProductDisplacementVector[i] += OH_disp2;
659 theProductDisplacementVector[i] = OH_disp1;
661 theProductDisplacementVector[i] = OH_disp2;
667 theProductDisplacementVector[i]
676 return theProductDisplacementVector;