Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/processes/hadronic/models/quasi_elastic/include/G4QuasiElRatios.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  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 //
 29 // GEANT4 physics class: G4QuasiElRatios -- header file
 30 // M.V. Kossov, ITEP(Moscow), 24-OCT-01
 31 // The last update: M.V. Kossov, CERN/ITEP (Moscow) 15-Oct-2006
 32 // ----------------------------------------------------------------------
 33 // This class has been extracted from the CHIPS model. 
 34 // All the dependencies on CHIPS classes have been removed.
 35 // Short description: Provides percentage of quasi-free and quasi-elastic
 36 // reactions in the inelastic reactions.
 37 // ----------------------------------------------------------------------
 38 
 39 #ifndef G4QuasiElRatios_h
 40 #define G4QuasiElRatios_h 1
 41 
 42 #include "globals.hh"
 43 #include "G4ios.hh"
 44 #include "Randomize.hh"
 45 #include <vector>
 46 #include "G4LorentzVector.hh"
 47 
 48 #include "G4ChipsProtonElasticXS.hh"
 49 #include "G4ChipsNeutronElasticXS.hh"
 50 
 51 
 52 class G4QuasiElRatios
 53 {
 54     
 55 public:
 56     G4QuasiElRatios();                 // Constructor
 57     
 58     ~G4QuasiElRatios();                 // Destructor
 59     
 60     // Pair(QuasiFree/Inelastic,QuasiElastic/QuasiFree)
 61     std::pair<G4double,G4double> GetRatios(G4double pIU, G4int prPDG, G4int tgZ, G4int tgN);
 62     // ChargeExchange/QuasiElastic factor pair<for protons (Z), for neutrons(N)>
 63     std::pair<G4double,G4double> GetChExFactor(G4double pIU, G4int pPDG, G4int Z, G4int N);
 64     // scatter (pPDG,p4M) on a virtual nucleon (NPDG,N4M), result: final pair(newN4M,newp4M)
 65     // if(newN4M.e()==0.) - below threshold, XS=0, no scattering of the projectile happened
 66     std::pair<G4LorentzVector,G4LorentzVector> Scatter(G4int NPDG, G4LorentzVector N4M,
 67                                                        G4int pPDG, G4LorentzVector p4M);
 68     // ChExer (pPDG,p4M) on a virtual nucleon (NPDG,N4M), result: final pair(newN4M,newp4M)
 69     // if(newN4M.e()==0.) - keep projectile, XS=0, no interaction of the progectile happened
 70     // User should himself change the charge (PDG) (e.g. pn->np, pi+n->pi0p, pi-p->pi0n etc.)
 71     // Recepy: change target n to p or taget p to n and conserve enrgy, changing projectile
 72     // Do not use for the nucleon, as it is already included in quasielastic, and for pi0.
 73     std::pair<G4LorentzVector,G4LorentzVector> ChExer(G4int NPDG, G4LorentzVector N4M,
 74                                                       G4int pPDG, G4LorentzVector p4M);
 75     // Mean hN El and Tot XS(IU) for the isotopic (Z,N): on p -> (Z=1,N=0), on n -> (Z=0,N=1)
 76     std::pair<G4double,G4double> GetElTot(G4double pIU, G4int hPDG, G4int Z, G4int N); //(IU)
 77     
 78     // Calculate ChEx/El ratio coefficient (p is in independent units, (Z,N) is a target)
 79     G4double ChExElCoef(G4double p, G4int Z, G4int N, G4int pPDG);
 80     
 81     // For hadron PDG with momentum Mom (GeV/c) on F(p/n) calculate <sig_el,sig_tot> pair(mb)
 82     // F=true corresponds to the Nroton target, F=false corresponds to the Proton target
 83     std::pair<G4double,G4double> GetElTotXS(G4double Mom, G4int PDG, G4bool F);//<sigEl,sigT>
 84     std::pair<G4double,G4double> FetchElTot(G4double pGeV,G4int PDG,G4bool F);//<E,T>fromAMDB
 85     
 86     G4bool RelDecayIn2(G4LorentzVector& theMomentum, G4LorentzVector& f4Mom, 
 87                        G4LorentzVector& s4Mom, G4LorentzVector& dir,
 88                        G4double maxCost = 1., G4double minCost = -1.);
 89     
 90 private:
 91     G4ChipsProtonElasticXS* PCSmanager;
 92     G4ChipsNeutronElasticXS* NCSmanager;
 93     
 94     // These working member functions are in CHIPS units and must not be used externally
 95     G4double GetQF2IN_Ratio(G4double TotCS_mb, G4int A); // QuasiFree/Inelastic (fast)
 96     G4double CalcQF2IN_Ratio(G4double TCSmb, G4int A); // R=QuasuFree/Inelastic (sig_t in mb)
 97     std::pair<G4double,G4double> CalcElTot(G4double pGeV,G4int Index);//(sigEl,sigTot)(Index)
 98     
 99     // Body
100 private:
101     std::vector<G4double*> *vT;     // Vector of pointers to LinTable
102     std::vector<G4double*> *vL;     // Vector of pointers to LogTable
103     std::vector<std::pair<G4double,G4double>*> *vX; // Vector of ETPointers to LogTable
104     
105     G4double lastSRatio;             // The last sigma value for which R was calculated
106     G4double lastRRatio;             // The last ratio R which was calculated
107     std::vector<G4int> vARatio;
108     std::vector<G4double> vHRatio;     // Vector of max s initialized in the LinTable
109     std::vector<G4int> vNRatio;    // Vector of topBin number initialized in LinTable
110     std::vector<G4double> vMRatio;     // Vector of rel max ln(s) initialized in LogTable
111     std::vector<G4int> vKRatio;     // Vector of topBin number initialized in LogTable
112  
113     G4int     lastARatio;             // theLast of calculated A
114     G4double  lastHRatio;            // theLast of max s initialized in the LinTable
115     G4int     lastNRatio;             // theLast of topBin number initialized in LinTable
116     G4double  lastMRatio;            // theLast of rel max ln(s) initialized in LogTable
117     G4int     lastKRatio;             // theLast of topBin number initialized in LogTable
118     G4double* lastTRatio;             // theLast of pointer to LinTable in the C++ heap
119     G4double* lastLRatio;             // theLast of pointer to LogTable in the C++ heap
120     
121     G4double lastPtot;              // The last momentum for which XS was calculated
122     G4int    lastHtot;               // The last projPDG for which XS was calculated
123     G4bool   lastFtot;            // The last nucleon for which XS was calculated
124     std::pair<G4double,G4double> lastRtot; // The last result
125     std::vector<G4int>  vItot;      // Vector of index for which XS was calculated
126     std::vector<G4double> vMtot;      // Vector of rel max ln(p) initialized in LogTable
127     std::vector<G4int> vKtot;      // Vector of topBin number initialized in LogTable
128     G4int     lastItot;              // The Last index for which XS was calculated
129     G4double  lastMtot;             // The Last rel max ln(p) initialized in LogTable
130     G4int     lastKtot;             // The Last topBin number initialized in LogTable
131     std::pair<G4double,G4double>* lastXtot; // The Last ETPointers to LogTable in heap
132 
133 
134     
135     
136 };
137 #endif
138