9 #include <simulation/physicslist/KaonPhysics.h> 
   11 #include "G4ProcessManager.hh" 
   12 #include "G4HadronInelasticProcess.hh" 
   13 #include "G4HadronElasticProcess.hh" 
   14 #include "G4HadronicAbsorptionBertini.hh" 
   16 #include "G4CascadeInterface.hh" 
   17 #include "G4TheoFSGenerator.hh" 
   18 #include "G4FTFModel.hh" 
   19 #include "G4ExcitedStringDecay.hh" 
   20 #include "G4LundStringFragmentation.hh" 
   21 #include "G4GeneratorPrecompoundInterface.hh" 
   22 #include "G4HadronElastic.hh" 
   24 #include "G4CrossSectionElastic.hh" 
   25 #include "G4CrossSectionInelastic.hh" 
   26 #include "G4ComponentGGHadronNucleusXsc.hh" 
   27 #include "G4SystemOfUnits.hh" 
   30 using namespace Simulation;
 
   33 KaonPhysics::KaonPhysics()
 
   34   : m_ftfp(nullptr), m_stringModel(nullptr), m_stringDecay(nullptr),
 
   35     m_fragModel(nullptr), m_preCompoundModel(nullptr)
 
   39 KaonPhysics::~KaonPhysics()
 
   44   delete m_preCompoundModel;
 
   48 void KaonPhysics::ConstructParticle()
 
   52 void KaonPhysics::ConstructProcess()
 
   54   G4ProcessManager* procMan;
 
   57   G4HadronElastic* elModel = 
new G4HadronElastic();
 
   60   G4CascadeInterface* loInelModel = 
new G4CascadeInterface;
 
   61   loInelModel->SetMinEnergy(0.0);
 
   62   loInelModel->SetMaxEnergy(12.0 * GeV);
 
   65   m_ftfp = 
new G4TheoFSGenerator(
"FTFP");
 
   66   m_stringModel = 
new G4FTFModel;
 
   68     new G4ExcitedStringDecay(m_fragModel = 
new G4LundStringFragmentation);
 
   69   m_stringModel->SetFragmentationModel(m_stringDecay);
 
   70   m_preCompoundModel = 
new G4GeneratorPrecompoundInterface();
 
   72   m_ftfp->SetHighEnergyGenerator(m_stringModel);
 
   73   m_ftfp->SetTransport(m_preCompoundModel);
 
   74   m_ftfp->SetMinEnergy(10 * GeV);
 
   75   m_ftfp->SetMaxEnergy(100 * TeV);
 
   78   G4VCrossSectionDataSet* kinelCS =
 
   79     new G4CrossSectionInelastic(
new G4ComponentGGHadronNucleusXsc);
 
   82   G4VCrossSectionDataSet* kelCS =
 
   83     new G4CrossSectionElastic(
new G4ComponentGGHadronNucleusXsc);
 
   89   procMan = G4KaonPlus::KaonPlus()->GetProcessManager();
 
   92   G4HadronElasticProcess* kpProcEl = 
new G4HadronElasticProcess;
 
   93   kpProcEl->RegisterMe(elModel);
 
   94   kpProcEl->AddDataSet(kelCS);
 
   95   procMan->AddDiscreteProcess(kpProcEl);
 
   98   G4HadronInelasticProcess* kpProcInel = 
new G4HadronInelasticProcess(
"kaon+Inelastic", G4KaonPlus::Definition());
 
   99   kpProcInel->RegisterMe(loInelModel);
 
  100   kpProcInel->RegisterMe(m_ftfp);
 
  101   kpProcInel->AddDataSet(kinelCS);
 
  102   procMan->AddDiscreteProcess(kpProcInel);
 
  108   procMan = G4KaonMinus::KaonMinus()->GetProcessManager();
 
  111   G4HadronElasticProcess* kmProcEl = 
new G4HadronElasticProcess;
 
  112   kmProcEl->RegisterMe(elModel);
 
  113   kmProcEl->AddDataSet(kelCS);
 
  114   procMan->AddDiscreteProcess(kmProcEl);
 
  117   G4HadronInelasticProcess* kmProcInel = 
new G4HadronInelasticProcess(
"kaon-Inelastic", G4KaonMinus::Definition());
 
  118   kmProcInel->RegisterMe(loInelModel);
 
  119   kmProcInel->RegisterMe(m_ftfp);
 
  120   kmProcInel->AddDataSet(kinelCS);
 
  121   procMan->AddDiscreteProcess(kmProcInel);
 
  124   G4HadronicAbsorptionBertini* bertAbsorb = 
new G4HadronicAbsorptionBertini;
 
  125   procMan->AddRestProcess(bertAbsorb);
 
  131   procMan = G4KaonZeroLong::KaonZeroLong()->GetProcessManager();
 
  134   G4HadronElasticProcess* k0LProcEl = 
new G4HadronElasticProcess;
 
  135   k0LProcEl->RegisterMe(elModel);
 
  136   k0LProcEl->AddDataSet(kelCS);
 
  137   procMan->AddDiscreteProcess(k0LProcEl);
 
  140   G4HadronInelasticProcess* k0LProcInel = 
new G4HadronInelasticProcess(
"kaon0LInelastic", G4KaonZeroLong::Definition());
 
  141   k0LProcInel->RegisterMe(loInelModel);
 
  142   k0LProcInel->RegisterMe(m_ftfp);
 
  143   k0LProcInel->AddDataSet(kinelCS);
 
  144   procMan->AddDiscreteProcess(k0LProcInel);
 
  150   procMan = G4KaonZeroShort::KaonZeroShort()->GetProcessManager();
 
  153   G4HadronElasticProcess* k0SProcEl = 
new G4HadronElasticProcess;
 
  154   k0SProcEl->RegisterMe(elModel);
 
  155   k0SProcEl->AddDataSet(kelCS);
 
  156   procMan->AddDiscreteProcess(k0SProcEl);
 
  159   G4HadronInelasticProcess* k0SProcInel = 
new G4HadronInelasticProcess(
"kaon0SInelastic", G4KaonZeroShort::Definition());
 
  160   k0SProcInel->RegisterMe(loInelModel);
 
  161   k0SProcInel->RegisterMe(m_ftfp);
 
  162   k0SProcInel->AddDataSet(kinelCS);
 
  163   procMan->AddDiscreteProcess(k0SProcInel);
 
Abstract base class for different kinds of events.