Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4VIntraNuclearTransportModel.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// GEANT 4 class implementation file
29//
30// History: first implementation, A. Feliciello, 30th June 1998
31// Removed delete of DeExcitation model, deleted elsewhere.
32// F.W.Jones, 06-JUL-99
33// V.Ivanchenko 03.01.2012
34// Added G4VPreCompoundModel pointer to the constructor and cleanup
35// V. Uzhinsky Nov. 2012
36// Added method PropagateNuclNucl for simulation of nucleus-nucleus inter.
37// -----------------------------------------------------------------------------
38
40
42 const G4String& modName, G4VPreCompoundModel* ptr)
43 : G4HadronicInteraction(modName),theTransportModelName(modName),
44 the3DNucleus(nullptr),theDeExcitation(ptr),thePrimaryProjectile(nullptr)
45{}
46
48{}
49
50void G4VIntraNuclearTransportModel::ModelDescription(std::ostream& outFile) const
51{
52 outFile << "G4VIntraNuclearTransportModel is abstract class.\n";
53 G4Exception("G4VIntraNuclearTransportModel::ModelDescription()","G4VINT01",
55 "G4VIntraNuclearTransportModel is abstract class, no description available");
56}
57
59{
60 outFile << "G4VIntraNuclearTransportModel is abstract class, missing description.\n";
61}
62
66{
67 G4Exception("G4VIntraNuclearTransportModel::Propagate()","G4VINT02",
69 "Propagate method for nucleus-nucleus interactions not implemented");
70 return nullptr;
71}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
Definition: G4Exception.cc:59
std::vector< G4ReactionProduct * > G4ReactionProductVector
virtual G4ReactionProductVector * PropagateNuclNucl(G4KineticTrackVector *theSecondaries, G4V3DNucleus *theNucleus, G4V3DNucleus *theProjectileNucleus)
virtual void ModelDescription(std::ostream &outFile) const
G4VIntraNuclearTransportModel(const G4String &mName="CascadeModel", G4VPreCompoundModel *ptr=nullptr)
virtual void PropagateModelDescription(std::ostream &outFile) const