238{
240 vector<G4ThreeVector> theProductDisplacementVector(nbProducts);
241
242 typedef map<const G4MoleculeDefinition*, G4double> RMSmap;
243 RMSmap theRMSmap;
244
246
247 switch (decayType) {
248 case Ionisation_DissociationDecay:
249 {
253 }
255
256 if (RdmValue < 0.5) {
257
259
261 } else {
262
264
266 }
267
268 for (
G4int i = 0; i < nbProducts; i++) {
270 G4double theRMSDisplacement = theRMSmap[pProduct->GetDefinition()];
271
272 if (theRMSDisplacement == 0.0) {
274 } else {
275 auto RandDirection =
277 theProductDisplacementVector[i] = RandDirection;
278 }
279 }
280 break;
281 }
282 case A1B1_DissociationDecay:
283 {
287 }
288
289 constexpr G4double theRMSDisplacement = 2.4 * nanometer;
291
292 for (
G4int i = 0; i < nbProducts; i++) {
294
296 theProductDisplacementVector[i] = -1.0 / 18.0 * RandDirection;
298 theProductDisplacementVector[i] = +17.0 / 18.0 * RandDirection;
299 }
300 }
301 break;
302 }
303 case B1A1_DissociationDecay:
304 {
308 }
309
310 constexpr G4double theRMSDisplacement = 0.8 * nanometer;
312
314 for (
G4int i = 0; i < nbProducts; ++i) {
316 if (pProduct->GetDefinition() == G4H2::Definition()) {
317
318
319
320
321 theProductDisplacementVector[i] = -16.0 / 18.0 * RandDirection;
323
324
325
326
327 G4ThreeVector OxygenDisplacement = +2.0 / 18.0 * RandDirection;
328 constexpr G4double OHRMSDisplacement = 1.1 * nanometer;
329
330 auto OHDisplacement =
332
333 if (NbOfOH == 0) {
334 OHDisplacement = 0.5 * OHDisplacement;
335 } else {
336 OHDisplacement = -0.5 * OHDisplacement;
337 }
338
339 theProductDisplacementVector[i] =
340 OHDisplacement + OxygenDisplacement;
341
342 ++NbOfOH;
343 }
344 }
345 break;
346 }
347 case B1A1_DissociationDecay2:
348 {
352 }
353
355 for (
G4int i = 0; i < nbProducts; ++i) {
358
361
362 constexpr G4double HRMSDisplacement = 1.6 * nanometer;
363
364 auto HDisplacement =
366
367 if (NbOfH == 0) {
368 HDisplacement = 0.5 * HDisplacement;
369 } else {
370 HDisplacement = -0.5 * HDisplacement;
371 }
372 theProductDisplacementVector[i] = HDisplacement;
373
374 ++NbOfH;
375 }
376 }
377 break;
378 }
379 case AutoIonisation:
380 {
384 }
385
387
388 if (RdmValue < 0.5) {
389
391
393 } else {
394
396
398 }
399
400 for (
G4int i = 0; i < nbProducts; i++) {
402 auto theRMSDisplacement = theRMSmap[pProduct->GetDefinition()];
403
404 if (theRMSDisplacement == 0) {
406 } else {
407 auto RandDirection =
409 theProductDisplacementVector[i] = RandDirection;
410 }
413 }
414 }
415 break;
416 }
417 case DissociativeAttachment:
418 {
422 }
423 constexpr G4double theRMSDisplacement = 0.8 * nanometer;
425
427 for (
G4int i = 0; i < nbProducts; ++i) {
429 if (pProduct->GetDefinition() == G4H2::Definition()) {
430
431
432
433
434 theProductDisplacementVector[i] = -16.0 / 18.0 * RandDirection;
436
437
438
439
440 G4ThreeVector OxygenDisplacement = +2.0 / 18.0 * RandDirection;
441 constexpr G4double OHRMSDisplacement = 1.1 * nanometer;
442
443 auto OHDisplacement =
445
446 if (NbOfOH == 0) {
447 OHDisplacement = 0.5 * OHDisplacement;
448 } else {
449 OHDisplacement = -0.5 * OHDisplacement;
450 }
451 theProductDisplacementVector[i] = OHDisplacement +
452 OxygenDisplacement;
453 ++NbOfOH;
454 }
455 }
456 break;
457 }
458 case DoubleIonisation_DissociationDecay1:
459 {
461 G4cout <<
"DoubleIonisation_DissociationDecay1" <<
G4endl;
463 }
464
465
466
467
470
471 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
472
474
476 num_H3O++;
477 if (num_H3O == 2) {
478 constexpr G4double H3Op_rms = 0.3 * nanometer;
480 }
481 }
482
483 theProductDisplacementVector[i]
485
486 }
487
488 break;
489 }
490 case DoubleIonisation_DissociationDecay2:
491 {
493 G4cout <<
"DoubleIonisation_DissociationDecay2" <<
G4endl;
495 }
496
497
498
499
504
507
508 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
509
511
513 num_H3O++;
514 if (num_H3O == 2) {
515 constexpr G4double OH_rms = 0.3 * nanometer;
516 theProductDisplacementVector[i]
518 theProductDisplacementVector[i] += OH_disp;
519 continue;
520 }
522 theProductDisplacementVector[i] = OH_disp;
523 continue;
524 }
525
526 theProductDisplacementVector[i]
528
529 }
530
531 break;
532 }
533 case DoubleIonisation_DissociationDecay3:
534 {
536 G4cout <<
"DoubleIonisation_DissociationDecay3" <<
G4endl;
538 }
539
540
541
542
545
546 for (
G4int i = 0; i < nbProducts; i++) {
547
549
550 theProductDisplacementVector[i]
552
553 }
554
555 break;
556 }
557 case TripleIonisation_DissociationDecay:
558 {
560 G4cout <<
"TripleIonisation_DissociationDecay" <<
G4endl;
562 }
563
564
565
566
567
568
569
570
571
572
573
577
580
581 for (
G4int i = 0, num_H3O = 0; i < nbProducts; i++) {
582
584
586 num_H3O++;
587 if (num_H3O == 3) {
588 constexpr G4double H3Op_rms = 0.3 * nanometer;
589 theProductDisplacementVector[i]
591 theProductDisplacementVector[i] += OH_disp;
592 continue;
593 }
595 theProductDisplacementVector[i] = OH_disp;
596 continue;
597 }
598
599 theProductDisplacementVector[i]
601
602 }
603
604 break;
605 }
606 case QuadrupleIonisation_DissociationDecay:
607 {
609 G4cout <<
"QuadrupleIonisation_DissociationDecay" <<
G4endl;
611 }
612
613
614
615
616
617
618
619
620
621
622
623
624
628
633
634 for (
G4int i = 0, num_H3O = 0, num_OH = 0; i < nbProducts; i++) {
635
637
639
640 num_H3O++;
641 constexpr G4double H3Op_rms = 0.3 * nanometer;
642
643 if (num_H3O == 3) {
644 theProductDisplacementVector[i]
646 theProductDisplacementVector[i] += OH_disp1;
647 continue;
648 } else if (num_H3O == 4) {
649 theProductDisplacementVector[i]
651 theProductDisplacementVector[i] += OH_disp2;
652 continue;
653 }
654
656
657 num_OH++;
658 if (num_OH == 1) {
659 theProductDisplacementVector[i] = OH_disp1;
660 } else {
661 theProductDisplacementVector[i] = OH_disp2;
662 }
663
664 continue;
665 }
666
667 theProductDisplacementVector[i]
669
670 }
671
672 break;
673 }
674
675 }
676 return theProductDisplacementVector;
677}
G4GLOB_DLL std::ostream G4cout
G4ThreeVector radialDistributionOfElectron() const
static G4Electron_aq * Definition()
static G4H3O * Definition()
static G4Hydrogen * Definition()
const G4MoleculeDefinition * GetDefinition() const
Product * GetProduct(int) const
G4int GetNbProducts() const
const G4String & GetName() const
static G4OH * Definition()
static G4Oxygen * Definition()