54 {
57 if ( ! theAntiNucleonXS ) theAntiNucleonXS = new G4ComponentAntiNuclNuclearXS;
58 theAntiNucleonData = new G4CrossSectionInelastic( theAntiNucleonXS );
61
62 theQGSmodel = new G4TheoFSGenerator( "QGSP" );
63 G4QGSModel< G4QGSParticipants >* theStringModel = new G4QGSModel< G4QGSParticipants >;
64 G4ExcitedStringDecay* theStringDecay = new G4ExcitedStringDecay( new G4QGSMFragmentation );
66 G4GeneratorPrecompoundInterface* theCascade = new G4GeneratorPrecompoundInterface();
67 theQGSmodel->SetTransport( theCascade );
68 theQGSmodel->SetHighEnergyGenerator( theStringModel );
69 if ( quasiElastic ) theQGSmodel->SetQuasiElasticChannel( new G4QuasiElasticChannel );
70 theQGSmodel->SetTransport(theCascade);
71 theQGSmodel->SetMinEnergy( theMin );
72 theQGSmodel->SetMaxEnergy( theMax );
73
74 theFTFmodel = new G4TheoFSGenerator( "FTFP" );
75 G4FTFModel* theStringModel2 = new G4FTFModel;
77 G4GeneratorPrecompoundInterface* theCascade2 = new G4GeneratorPrecompoundInterface;
78 theFTFmodel->SetHighEnergyGenerator( theStringModel2 );
80 if ( quasiElasticFTF ) theFTFmodel->SetQuasiElasticChannel( new G4QuasiElasticChannel );
81 theFTFmodel->SetTransport( theCascade2 );
82 theFTFmodel->SetMinEnergy( theMin );
83 theFTFmodel->SetMaxEnergy( theMax );
84}
G4VComponentCrossSection * GetComponentCrossSection(const G4String &name)
static G4CrossSectionDataSetRegistry * Instance()
static G4HadronicParameters * Instance()
G4double GetMinEnergyTransitionQGS_FTF() const
G4double GetMaxEnergy() const
void SetFragmentationModel(G4VStringFragmentation *aModel)