Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4HadronicAbsorptionFritiofWithBinaryCascade.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26//---------------------------------------------------------------------------
27//
28// ClassName: G4HadronicAbsorptionFritiofWithBinaryCascade
29//
30// Author: Alberto Ribon
31//
32// Date: July 2019
33//
34// Modified:
35//
36// Class Description:
37//
38// Intermediate class for hadronic absorption at rest using FTF/BIC.
39//
40//---------------------------------------------------------------------------
41
42#include <iostream>
43
44#include "G4SystemOfUnits.hh"
46#include "G4PreCompoundModel.hh"
48#include "G4FTFModel.hh"
51#include "G4TheoFSGenerator.hh"
52#include "G4BinaryCascade.hh"
54#include "G4ParticleTypes.hh"
57
58// Constructor
61 : G4HadronStoppingProcess( "hFritiofWithBinaryCascadeCaptureAtRest" ),
62 pdefApplicable( pdef ) {
63
64 G4TheoFSGenerator* theModel = new G4TheoFSGenerator( "FTFB" );
65 G4FTFModel* theStringModel = new G4FTFModel;
66 theStringModel->SetFragmentationModel(new G4ExcitedStringDecay());
67
68 G4BinaryCascade* theCascade = new G4BinaryCascade;
69
70 theModel->SetHighEnergyGenerator( theStringModel );
71 theModel->SetTransport( theCascade );
72
73 G4double theMin = 0.0*GeV;
75 theModel->SetMinEnergy( theMin );
76 theModel->SetMaxEnergy( theMax );
77
78 RegisterMe( theModel );
79}
80
82}
83
84// Applies to constructor-specified particle, or to all known cases
86IsApplicable( const G4ParticleDefinition& particle ) {
87 // It is applicable only for anti_proton and anti_neutron, but not for
88 // light anti-ion because the propagate method for nucleus-nucleus interaction:
89 // G4VIntraNuclearTransportModel::Propagate()
90 // is not implemented.
91 return ( ( ( ! pdefApplicable ) &&
92 ( &particle == G4AntiProton::Definition() || &particle == G4AntiNeutron::Definition() ) )
93 || &particle == pdefApplicable );
94}
95
96
97// Documentation of purpose
99ProcessDescription( std::ostream& os ) const {
100 os << "Stopping and absorption of anti_proton and anti_neutron \n"
101 << "using Fritiof (FTF) string model coupled with Binary Cascade (BIC) model."
102 << std::endl;
103}
double G4double
Definition: G4Types.hh:83
bool G4bool
Definition: G4Types.hh:86
static G4AntiNeutron * Definition()
static G4AntiProton * Definition()
Definition: G4AntiProton.cc:50
void SetMinEnergy(G4double anEnergy)
void SetMaxEnergy(const G4double anEnergy)
static G4HadronicParameters * Instance()
G4double GetMaxEnergy() const
void RegisterMe(G4HadronicInteraction *a)
void SetTransport(G4VIntraNuclearTransportModel *const value)
void SetHighEnergyGenerator(G4VHighEnergyGenerator *const value)
void SetFragmentationModel(G4VStringFragmentation *aModel)