G4ParticleHPInelasticCompFS

public G4ParticleHPFinalState

读取高精度数据(角分布、gamma)

void Init (G4double A, G4double Z, G4int M, G4String & dirName, G4String & aSFType, G4ParticleDefinition*);
  • dataType==3
    • G4ParticleHPVector
  • dataType==4
    • G4ParticleHPAngular
  • dataType==5
    • G4ParticleHPEnergyDistribution
  • dataType==6
    • G4ParticleHPEnAngCorrelation
  • dataType==12
    • G4ParticleHPPhotonDist
  • dataType==13
    • G4ParticleHPPhotonDist
  • dataType==14
  • dataType==15
getenv("G4NEUTRONHPDATA")

"/Inelastic/Gammas/"

class

  public:

  G4ParticleHPInelasticCompFS()
  {

    QI.resize(51);
    LR.resize(51);
    for(G4int i=0; i<51; i++)
    {
      hasXsec = true; 
      theXsection[i] = 0;
      theEnergyDistribution[i] = 0;
      theAngularDistribution[i] = 0;
      theEnergyAngData[i] = 0;
      theFinalStatePhotons[i] = 0;
      QI[i]=0.0;
      LR[i]=0;
    }

  }
  virtual ~G4ParticleHPInelasticCompFS()
  {
    for(G4int i=0; i<51; i++)
    {
      if(theXsection[i] != 0) delete theXsection[i];
      if(theEnergyDistribution[i] != 0) delete theEnergyDistribution[i];
      if(theAngularDistribution[i] != 0) delete theAngularDistribution[i];
      if(theEnergyAngData[i] != 0) delete theEnergyAngData[i];
      if(theFinalStatePhotons[i] != 0) delete theFinalStatePhotons[i];
    }
  }
  void Init (G4double A, G4double Z, G4int M, G4String & dirName, G4String & aSFType, G4ParticleDefinition*);
  void InitGammas(G4double AR, G4double ZR);
  virtual G4HadFinalState * ApplyYourself(const G4HadProjectile & theTrack) = 0;
  virtual G4ParticleHPFinalState * New() = 0;
  virtual G4double GetXsec(G4double anEnergy)
  {
    return std::max(0., theXsection[50]->GetY(anEnergy));
  }
  virtual G4ParticleHPVector * GetXsec() { return theXsection[50]; }
  G4int SelectExitChannel(G4double eKinetic);
  void CompositeApply(const G4HadProjectile & theTrack, G4ParticleDefinition * aHadron);
  inline void InitDistributionInitialState(G4ReactionProduct & anIncidentPart, 
                                           G4ReactionProduct & aTarget, 
                                           G4int it)
  {
    if(theAngularDistribution[it]!=0) 
    {
      theAngularDistribution[it]->SetTarget(aTarget);
      theAngularDistribution[it]->SetProjectileRP(anIncidentPart);
    }
    if(theEnergyAngData[it]!=0)
    {
      theEnergyAngData[it]->SetTarget(aTarget);
      theEnergyAngData[it]->SetProjectileRP(anIncidentPart);
    }
  }

protected:

  G4ParticleHPVector * theXsection[51];
  G4ParticleHPEnergyDistribution * theEnergyDistribution[51];
  G4ParticleHPAngular * theAngularDistribution[51];
  G4ParticleHPEnAngCorrelation * theEnergyAngData[51];

  G4ParticleHPPhotonDist * theFinalStatePhotons[51];

  G4ParticleHPDeExGammas theGammas;
  G4String gammaPath;

  //G4double theCurrentA;
  //G4double theCurrentZ;

   protected:
      std::vector < G4double >  QI;
      std::vector <G4int > LR;

   private:
      //                       proj                 targ                 had                  mu of had   
      void two_body_reaction ( G4DynamicParticle* , G4DynamicParticle* , G4DynamicParticle* , G4double mu ); 

      G4NRESP71M03 nresp71_model;
      G4bool use_nresp71_model( const G4ParticleDefinition* aDefinition, const G4int it , const G4ReactionProduct& theTarget , G4ReactionProduct& boosted);
© Hongyi Wu            updated: 2018-09-02 00:08:14

results matching ""

    No results matching ""