Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 // 26 // 27 // The lust update: M.V. Kossov, CERN/ITEP(Mos 27 // The lust update: M.V. Kossov, CERN/ITEP(Moscow) 17-May-09 28 // 28 // 29 // 29 // 30 // G4 Physics class: G4ChipsNeutronInelasticXS 30 // G4 Physics class: G4ChipsNeutronInelasticXS for gamma+A cross sections 31 // Created: M.V. Kossov, CERN/ITEP(Moscow), 17 31 // Created: M.V. Kossov, CERN/ITEP(Moscow), 17-May-2009 32 // The last update: M.V. Kossov, CERN/ITEP (Mo 32 // The last update: M.V. Kossov, CERN/ITEP (Moscow) 21-May-04 33 // 33 // 34 // ******************************************* 34 // **************************************************************************************** 35 // Short description: Cross-sections extracted 35 // Short description: Cross-sections extracted (by W.Pokorski) from the CHIPS package for 36 // neutron-nuclear interactions. Original aut 36 // neutron-nuclear interactions. Original author: M. Kossov 37 // ------------------------------------------- 37 // ------------------------------------------------------------------------------------- 38 // 38 // 39 39 40 #include "G4ChipsNeutronInelasticXS.hh" 40 #include "G4ChipsNeutronInelasticXS.hh" 41 #include "G4SystemOfUnits.hh" 41 #include "G4SystemOfUnits.hh" 42 #include "G4DynamicParticle.hh" 42 #include "G4DynamicParticle.hh" 43 #include "G4ParticleDefinition.hh" 43 #include "G4ParticleDefinition.hh" 44 #include "G4Neutron.hh" 44 #include "G4Neutron.hh" 45 #include "G4Log.hh" << 46 #include "G4Exp.hh" << 47 << 48 45 49 // factory 46 // factory 50 #include "G4CrossSectionFactory.hh" 47 #include "G4CrossSectionFactory.hh" 51 // 48 // 52 G4_DECLARE_XS_FACTORY(G4ChipsNeutronInelasticX 49 G4_DECLARE_XS_FACTORY(G4ChipsNeutronInelasticXS); 53 50 54 // Initialization of the 51 // Initialization of the 55 52 56 G4ChipsNeutronInelasticXS::G4ChipsNeutronInela 53 G4ChipsNeutronInelasticXS::G4ChipsNeutronInelasticXS():G4VCrossSectionDataSet(Default_Name()) 57 { 54 { 58 lastLEN=0; // Pointer to the lastArray of Lo 55 lastLEN=0; // Pointer to the lastArray of LowEn CS 59 lastHEN=0; // Pointer to the lastArray of Hi 56 lastHEN=0; // Pointer to the lastArray of HighEnCS 60 lastN=0; // The last N of calculated nucle 57 lastN=0; // The last N of calculated nucleus 61 lastZ=0; // The last Z of calculated nucle 58 lastZ=0; // The last Z of calculated nucleus 62 lastP=0.; // Last used in cross section Mom 59 lastP=0.; // Last used in cross section Momentum 63 lastTH=0.; // Last threshold momentum 60 lastTH=0.; // Last threshold momentum 64 lastCS=0.; // Last value of the Cross Sectio 61 lastCS=0.; // Last value of the Cross Section 65 lastI=0; // The last position in the DAMDB 62 lastI=0; // The last position in the DAMDB 66 HEthresh=0.;// HE threshold for the CS calcu 63 HEthresh=0.;// HE threshold for the CS calculation 67 LEN = new std::vector<G4double*>; 64 LEN = new std::vector<G4double*>; 68 HEN = new std::vector<G4double*>; 65 HEN = new std::vector<G4double*>; 69 } 66 } 70 67 71 G4ChipsNeutronInelasticXS::~G4ChipsNeutronInel 68 G4ChipsNeutronInelasticXS::~G4ChipsNeutronInelasticXS() 72 { 69 { 73 std::size_t lens=LEN->size(); << 70 G4int lens=LEN->size(); 74 for(std::size_t i=0; i<lens; ++i) delete[] ( << 71 for(G4int i=0; i<lens; ++i) delete[] (*LEN)[i]; 75 delete LEN; 72 delete LEN; 76 std::size_t hens=HEN->size(); << 73 G4int hens=HEN->size(); 77 for(std::size_t i=0; i<hens; ++i) delete[] ( << 74 for(G4int i=0; i<hens; ++i) delete[] (*HEN)[i]; 78 delete HEN; 75 delete HEN; 79 } 76 } 80 77 81 void << 78 G4bool G4ChipsNeutronInelasticXS::IsIsoApplicable(const G4DynamicParticle* Pt, G4int, G4int, 82 G4ChipsNeutronInelasticXS::CrossSectionDescrip << 83 { << 84 outFile << "G4ChipsNeutronInelasticXS prov << 85 << "section for neutron nucleus sc << 86 << "momentum. The cross section is << 87 << "CHIPS parameterization of cros << 88 } << 89 << 90 G4bool G4ChipsNeutronInelasticXS::IsIsoApplica << 91 const G4Element*, 79 const G4Element*, 92 const G4Material*) 80 const G4Material*) 93 { 81 { 94 return true; << 82 G4ParticleDefinition* particle = Pt->GetDefinition(); >> 83 if (particle == G4Neutron::Neutron() ) return true; >> 84 return false; 95 } 85 } 96 86 97 87 98 G4double G4ChipsNeutronInelasticXS::GetIsoCros 88 G4double G4ChipsNeutronInelasticXS::GetIsoCrossSection(const G4DynamicParticle* Pt, G4int tgZ, G4int A, 99 const G4Isotope*, 89 const G4Isotope*, 100 const G4Element*, 90 const G4Element*, 101 const G4Material*) 91 const G4Material*) 102 { 92 { 103 G4double pMom=Pt->GetTotalMomentum(); 93 G4double pMom=Pt->GetTotalMomentum(); 104 G4int tgN = A - tgZ; 94 G4int tgN = A - tgZ; 105 95 106 return GetChipsCrossSection(pMom, tgZ, tgN, 96 return GetChipsCrossSection(pMom, tgZ, tgN, 2112); 107 } 97 } 108 98 109 // The main member function giving the collisi 99 // The main member function giving the collision cross section (P is in IU, CS is in mb) 110 // Make pMom in independent units ! (Now it is 100 // Make pMom in independent units ! (Now it is MeV) 111 G4double G4ChipsNeutronInelasticXS::GetChipsCr 101 G4double G4ChipsNeutronInelasticXS::GetChipsCrossSection(G4double pMom, G4int tgZ, G4int tgN, G4int) 112 { 102 { >> 103 static G4ThreadLocal G4int j; // A#0f Z/N-records already tested in AMDB >> 104 static G4ThreadLocal std::vector <G4int> *colN_G4MT_TLS_ = 0 ; if (!colN_G4MT_TLS_) colN_G4MT_TLS_ = new std::vector <G4int> ; std::vector <G4int> &colN = *colN_G4MT_TLS_; // Vector of N for calculated nuclei (isotops) >> 105 static G4ThreadLocal std::vector <G4int> *colZ_G4MT_TLS_ = 0 ; if (!colZ_G4MT_TLS_) colZ_G4MT_TLS_ = new std::vector <G4int> ; std::vector <G4int> &colZ = *colZ_G4MT_TLS_; // Vector of Z for calculated nuclei (isotops) >> 106 static G4ThreadLocal std::vector <G4double> *colP_G4MT_TLS_ = 0 ; if (!colP_G4MT_TLS_) colP_G4MT_TLS_ = new std::vector <G4double> ; std::vector <G4double> &colP = *colP_G4MT_TLS_; // Vector of last momenta for the reaction >> 107 static G4ThreadLocal std::vector <G4double> *colTH_G4MT_TLS_ = 0 ; if (!colTH_G4MT_TLS_) colTH_G4MT_TLS_ = new std::vector <G4double> ; std::vector <G4double> &colTH = *colTH_G4MT_TLS_; // Vector of energy thresholds for the reaction >> 108 static G4ThreadLocal std::vector <G4double> *colCS_G4MT_TLS_ = 0 ; if (!colCS_G4MT_TLS_) colCS_G4MT_TLS_ = new std::vector <G4double> ; std::vector <G4double> &colCS = *colCS_G4MT_TLS_; // Vector of last cross sections for the reaction >> 109 // ***---*** End of the mandatory Static Definitions of the Associative Memory ***---*** >> 110 113 111 114 G4bool in=false; // By d 112 G4bool in=false; // By default the isotope must be found in the AMDB 115 if(tgN!=lastN || tgZ!=lastZ) // The 113 if(tgN!=lastN || tgZ!=lastZ) // The nucleus was not the last used isotope 116 { 114 { 117 in = false; // By d 115 in = false; // By default the isotope haven't be found in AMDB 118 lastP = 0.; // New 116 lastP = 0.; // New momentum history (nothing to compare with) 119 lastN = tgN; // The 117 lastN = tgN; // The last N of the calculated nucleus 120 lastZ = tgZ; // The 118 lastZ = tgZ; // The last Z of the calculated nucleus 121 lastI = (G4int)colN.size(); // Size << 119 lastI = colN.size(); // Size of the Associative Memory DB in the heap 122 j = 0; // A#0f 120 j = 0; // A#0f records found in DB for this projectile 123 if(lastI) for(G4int i=0; i<lastI; ++i) // << 121 if(lastI) for(G4int i=0; i<lastI; i++) // AMDB exists, try to find the (Z,N) isotope 124 { 122 { 125 if(colN[i]==tgN && colZ[i]==tgZ) // Try 123 if(colN[i]==tgN && colZ[i]==tgZ) // Try the record "i" in the AMDB 126 { 124 { 127 lastI=i; // Reme 125 lastI=i; // Remember the index for future fast/last use 128 lastTH =colTH[i]; // The 126 lastTH =colTH[i]; // The last THreshold (A-dependent) 129 if(pMom<=lastTH) 127 if(pMom<=lastTH) 130 { 128 { 131 return 0.; // Ener 129 return 0.; // Energy is below the Threshold value 132 } 130 } 133 lastP =colP [i]; // Last 131 lastP =colP [i]; // Last Momentum (A-dependent) 134 lastCS =colCS[i]; // Last 132 lastCS =colCS[i]; // Last CrossSect (A-dependent) 135 in = true; // This 133 in = true; // This is the case when the isotop is found in DB 136 // Momentum pMom is in IU ! @@ Units 134 // Momentum pMom is in IU ! @@ Units 137 lastCS=CalculateCrossSection(-1,j,2112 135 lastCS=CalculateCrossSection(-1,j,2112,lastZ,lastN,pMom); // read & update 138 if(lastCS<=0. && pMom>lastTH) // Corr 136 if(lastCS<=0. && pMom>lastTH) // Correct the threshold (@@ No intermediate Zeros) 139 { 137 { 140 lastCS=0.; 138 lastCS=0.; 141 lastTH=pMom; 139 lastTH=pMom; 142 } 140 } 143 break; // Go o 141 break; // Go out of the LOOP 144 } 142 } 145 j++; // Incr 143 j++; // Increment a#0f records found in DB 146 } 144 } 147 if(!in) // This 145 if(!in) // This isotope has not been calculated previously 148 { 146 { 149 //!!The slave functions must provide cro 147 //!!The slave functions must provide cross-sections in millibarns (mb) !! (not in IU) 150 lastCS=CalculateCrossSection(0,j,2112,la 148 lastCS=CalculateCrossSection(0,j,2112,lastZ,lastN,pMom); //calculate & create 151 //if(lastCS>0.) // It 149 //if(lastCS>0.) // It means that the AMBD was initialized 152 //{ 150 //{ 153 151 154 lastTH = 0; //ThresholdEnergy(tgZ, tgN); 152 lastTH = 0; //ThresholdEnergy(tgZ, tgN); // The Threshold Energy which is now the last 155 colN.push_back(tgN); 153 colN.push_back(tgN); 156 colZ.push_back(tgZ); 154 colZ.push_back(tgZ); 157 colP.push_back(pMom); 155 colP.push_back(pMom); 158 colTH.push_back(lastTH); 156 colTH.push_back(lastTH); 159 colCS.push_back(lastCS); 157 colCS.push_back(lastCS); 160 //} // M.K. Presence of H1 with high thresho 158 //} // M.K. Presence of H1 with high threshold breaks the syncronization 161 return lastCS*millibarn; 159 return lastCS*millibarn; 162 } // End of creation of the new set of par 160 } // End of creation of the new set of parameters 163 else 161 else 164 { 162 { 165 colP[lastI]=pMom; 163 colP[lastI]=pMom; 166 colCS[lastI]=lastCS; 164 colCS[lastI]=lastCS; 167 } 165 } 168 } // End of parameters udate 166 } // End of parameters udate 169 else if(pMom<=lastTH) 167 else if(pMom<=lastTH) 170 { 168 { 171 return 0.; // Mome 169 return 0.; // Momentum is below the Threshold Value -> CS=0 172 } 170 } 173 else // It i 171 else // It is the last used -> use the current tables 174 { 172 { 175 lastCS=CalculateCrossSection(1,j,2112,last 173 lastCS=CalculateCrossSection(1,j,2112,lastZ,lastN,pMom); // Only read and UpdateDB 176 lastP=pMom; 174 lastP=pMom; 177 } 175 } 178 return lastCS*millibarn; 176 return lastCS*millibarn; 179 } 177 } 180 178 181 // The main member function giving the gamma-A 179 // The main member function giving the gamma-A cross section (E in GeV, CS in mb) 182 G4double G4ChipsNeutronInelasticXS::CalculateC 180 G4double G4ChipsNeutronInelasticXS::CalculateCrossSection(G4int F, G4int I, 183 G4int, 181 G4int, G4int targZ, G4int targN, G4double Momentum) 184 { 182 { 185 static const G4double THmin=1.; // defa 183 static const G4double THmin=1.; // default minimum Momentum (MeV/c) Threshold 186 static const G4double THmiG=THmin*.001; // m 184 static const G4double THmiG=THmin*.001; // minimum Momentum (GeV/c) Threshold 187 static const G4double dP=10.; // step 185 static const G4double dP=10.; // step for the LEN (Low ENergy) table MeV/c 188 static const G4double dPG=dP*.001; // step 186 static const G4double dPG=dP*.001; // step for the LEN (Low ENergy) table GeV/c 189 static const G4int nL=105; // A#of 187 static const G4int nL=105; // A#of LEN points in E (step 10 MeV/c) 190 static const G4double Pmin=THmin+(nL-1)*dP; 188 static const G4double Pmin=THmin+(nL-1)*dP; // minP for the HighE part with safety 191 static const G4double Pmax=227000.; // maxP 189 static const G4double Pmax=227000.; // maxP for the HEN (High ENergy) part 227 GeV 192 static const G4int nH=224; // A#of 190 static const G4int nH=224; // A#of HEN points in lnE 193 static const G4double milP=G4Log(Pmin);// Lo << 191 static const G4double milP=std::log(Pmin);// Low logarithm energy for the HEN part 194 static const G4double malP=G4Log(Pmax);// Hi << 192 static const G4double malP=std::log(Pmax);// High logarithm energy (each 2.75 percent) 195 static const G4double dlP=(malP-milP)/(nH-1) 193 static const G4double dlP=(malP-milP)/(nH-1); // Step in log energy in the HEN part 196 static const G4double milPG=G4Log(.001*Pmin) << 194 static const G4double milPG=std::log(.001*Pmin);// Low logarithmEnergy for HEN part GeV/c 197 // 195 // >> 196 // Associative memory for acceleration >> 197 //static std::vector <G4double> spA; // shadowing coefficients (A-dependent) >> 198 G4double sigma=0.; >> 199 if(F&&I) sigma=0.; // @@ *!* Fake line *!* to use F & I !!!Temporary!!! >> 200 //G4double A=targN+targZ; // A of the target 198 if(F<=0) // This 201 if(F<=0) // This isotope was not the last used isotop 199 { 202 { 200 if(F<0) // This 203 if(F<0) // This isotope was found in DAMDB =-----=> RETRIEVE 201 { 204 { 202 G4int sync=(G4int)LEN->size(); << 205 G4int sync=LEN->size(); 203 if(sync<=I) G4cerr<<"*!*G4ChipsNetronNuc 206 if(sync<=I) G4cerr<<"*!*G4ChipsNetronNuclCS::CalcCrossSect:Sync="<<sync<<"<="<<I<<G4endl; 204 lastLEN=(*LEN)[I]; // Poin 207 lastLEN=(*LEN)[I]; // Pointer to prepared LowEnergy cross sections 205 lastHEN=(*HEN)[I]; // Poin 208 lastHEN=(*HEN)[I]; // Pointer to prepared High Energy cross sections 206 } 209 } 207 else // This 210 else // This isotope wasn't calculated before => CREATE 208 { 211 { 209 lastLEN = new G4double[nL]; // Allo 212 lastLEN = new G4double[nL]; // Allocate memory for the new LEN cross sections 210 lastHEN = new G4double[nH]; // Allo 213 lastHEN = new G4double[nH]; // Allocate memory for the new HEN cross sections 211 // --- Instead of making a separate func 214 // --- Instead of making a separate function --- 212 G4double P=THmiG; // Tabl 215 G4double P=THmiG; // Table threshold in GeV/c 213 for(G4int k=0; k<nL; k++) 216 for(G4int k=0; k<nL; k++) 214 { 217 { 215 lastLEN[k] = CrossSectionLin(targZ, ta 218 lastLEN[k] = CrossSectionLin(targZ, targN, P); 216 P+=dPG; 219 P+=dPG; 217 } 220 } 218 G4double lP=milPG; 221 G4double lP=milPG; 219 for(G4int n=0; n<nH; n++) 222 for(G4int n=0; n<nH; n++) 220 { 223 { 221 lastHEN[n] = CrossSectionLog(targZ, ta 224 lastHEN[n] = CrossSectionLog(targZ, targN, lP); 222 lP+=dlP; 225 lP+=dlP; 223 } 226 } 224 // --- End of possible separate function 227 // --- End of possible separate function 225 // *** The synchronization check *** 228 // *** The synchronization check *** 226 G4int sync=(G4int)LEN->size(); << 229 G4int sync=LEN->size(); 227 if(sync!=I) 230 if(sync!=I) 228 { 231 { 229 G4cerr<<"***G4ChipsNetronNuclearCS::Ca 232 G4cerr<<"***G4ChipsNetronNuclearCS::CalcCrossSect: Sync="<<sync<<"#"<<I<<", Z=" <<targZ 230 <<", N="<<targN<<", F="<<F<<G4en 233 <<", N="<<targN<<", F="<<F<<G4endl; 231 //G4Exception("G4ProtonNuclearCS::Calc 234 //G4Exception("G4ProtonNuclearCS::CalculateCS:","39",FatalException,"overflow DB"); 232 } 235 } 233 LEN->push_back(lastLEN); // rem 236 LEN->push_back(lastLEN); // remember the Low Energy Table 234 HEN->push_back(lastHEN); // rem 237 HEN->push_back(lastHEN); // remember the High Energy Table 235 } // End of creation of the new set of par 238 } // End of creation of the new set of parameters 236 } // End of parameters udate 239 } // End of parameters udate 237 // =------------------= NOW the Magic Formul 240 // =------------------= NOW the Magic Formula =---------------------------= 238 G4double sigma; << 239 if (Momentum<lastTH) return 0.; // It m 241 if (Momentum<lastTH) return 0.; // It must be already checked in the interface class 240 else if (Momentum<Pmin) // High 242 else if (Momentum<Pmin) // High Energy region 241 { 243 { 242 sigma=EquLinearFit(Momentum,nL,THmin,dP,la 244 sigma=EquLinearFit(Momentum,nL,THmin,dP,lastLEN); 243 } 245 } 244 else if (Momentum<Pmax) // High 246 else if (Momentum<Pmax) // High Energy region 245 { 247 { 246 G4double lP=G4Log(Momentum); << 248 G4double lP=std::log(Momentum); 247 sigma=EquLinearFit(lP,nH,milP,dlP,lastHEN) 249 sigma=EquLinearFit(lP,nH,milP,dlP,lastHEN); 248 } 250 } 249 else // UHE 251 else // UHE region (calculation, not frequent) 250 { 252 { 251 G4double P=0.001*Momentum; // Appr 253 G4double P=0.001*Momentum; // Approximation formula is for P in GeV/c 252 sigma=CrossSectionFormula(targZ, targN, P, << 254 sigma=CrossSectionFormula(targZ, targN, P, std::log(P)); 253 } 255 } 254 if(sigma<0.) return 0.; 256 if(sigma<0.) return 0.; 255 return sigma; 257 return sigma; 256 } 258 } 257 259 258 // Calculation formula for proton-nuclear inel 260 // Calculation formula for proton-nuclear inelastic cross-section (mb) (P in GeV/c) 259 G4double G4ChipsNeutronInelasticXS::CrossSecti 261 G4double G4ChipsNeutronInelasticXS::CrossSectionLin(G4int tZ, G4int tN, G4double P) 260 { 262 { 261 //==> n (Z=0) 263 //==> n (Z=0) 262 static const G4int N0=1; 264 static const G4int N0=1; 263 static const G4double pZ0N1[4]={1., 0., 0., 265 static const G4double pZ0N1[4]={1., 0., 0., 1.}; 264 static const std::pair<G4int, const G4double 266 static const std::pair<G4int, const G4double*> Z0N1(1,pZ0N1); 265 static const std::pair<G4int, const G4double 267 static const std::pair<G4int, const G4double*> Z0[N0]={Z0N1}; 266 //==> H (Z=1) *** no protons, which are trea 268 //==> H (Z=1) *** no protons, which are treated separately *** 267 static const G4int N1=2; 269 static const G4int N1=2; 268 static const G4double pZ1N1[4]={6.E-8, 0., 0 270 static const G4double pZ1N1[4]={6.E-8, 0., 0., 1.}; 269 static const std::pair<G4int, const G4double 271 static const std::pair<G4int, const G4double*> Z1N1(1,pZ1N1); 270 static const G4double pZ1N2[4]={9.E-8, 0., 0 272 static const G4double pZ1N2[4]={9.E-8, 0., 0., 1.}; 271 static const std::pair<G4int, const G4double 273 static const std::pair<G4int, const G4double*> Z1N2(2,pZ1N2); 272 static const std::pair<G4int, const G4double 274 static const std::pair<G4int, const G4double*> Z1[N1]={Z1N1, Z1N2}; 273 //==> He(Z=2) 275 //==> He(Z=2) 274 static const G4int N2=2; 276 static const G4int N2=2; 275 static const G4double pZ2N1[4]={1.E-13, 9000 277 static const G4double pZ2N1[4]={1.E-13, 9000., 1.E-4, 2.E-4}; 276 static const std::pair<G4int, const G4double 278 static const std::pair<G4int, const G4double*> Z2N1(1,pZ2N1); 277 static const G4double pZ2N2[4]={7.E-4, 0., 0 279 static const G4double pZ2N2[4]={7.E-4, 0., 0., 1.}; 278 static const std::pair<G4int, const G4double 280 static const std::pair<G4int, const G4double*> Z2N2(2,pZ2N2); 279 static const std::pair<G4int, const G4double 281 static const std::pair<G4int, const G4double*> Z2[N2]={Z2N1, Z2N2}; 280 //==> Li(Z=3) 282 //==> Li(Z=3) 281 static const G4int N3=2; 283 static const G4int N3=2; 282 static const G4double pZ3N3[4]={1.E-9, 3200. 284 static const G4double pZ3N3[4]={1.E-9, 3200., .021, 1.5E-5}; 283 static const std::pair<G4int, const G4double 285 static const std::pair<G4int, const G4double*> Z3N1(3,pZ3N3); 284 static const G4double pZ3N4[4]={3.E-9, 200., 286 static const G4double pZ3N4[4]={3.E-9, 200., .051, 2.5E-4}; 285 static const std::pair<G4int, const G4double 287 static const std::pair<G4int, const G4double*> Z3N2(4,pZ3N4); 286 static const std::pair<G4int, const G4double 288 static const std::pair<G4int, const G4double*> Z3[N3]={Z3N1, Z3N2}; 287 //==> Be(Z=4) 289 //==> Be(Z=4) 288 static const G4int N4=1; 290 static const G4int N4=1; 289 static const G4double pZ4N5[4]={9.E-9, 400., 291 static const G4double pZ4N5[4]={9.E-9, 400., .088, 4.E-4}; 290 static const std::pair<G4int, const G4double 292 static const std::pair<G4int, const G4double*> Z4N5(5,pZ4N5); 291 static const std::pair<G4int, const G4double 293 static const std::pair<G4int, const G4double*> Z4[N4]={Z4N5}; 292 //==> B (Z=5) 294 //==> B (Z=5) 293 static const G4int N5=2; 295 static const G4int N5=2; 294 static const G4double pZ5N5[4]={2.E-10, 2700 296 static const G4double pZ5N5[4]={2.E-10, 2700., .009, 4.E-4}; 295 static const std::pair<G4int, const G4double 297 static const std::pair<G4int, const G4double*> Z5N5(5,pZ5N5); 296 static const G4double pZ5N6[4]={2.E-8, 110., 298 static const G4double pZ5N6[4]={2.E-8, 110., .030, 1.E-4}; 297 static const std::pair<G4int, const G4double 299 static const std::pair<G4int, const G4double*> Z5N6(6,pZ5N6); 298 static const std::pair<G4int, const G4double 300 static const std::pair<G4int, const G4double*> Z5[N5]={Z5N5, Z5N6}; 299 //==> C (Z=6) 301 //==> C (Z=6) 300 static const G4int N6=2; 302 static const G4int N6=2; 301 static const G4double pZ6N6[4]={1.5E-7, 300. 303 static const G4double pZ6N6[4]={1.5E-7, 300., .129, 5.E-4}; // *** Only Nat Mix *** 302 static const std::pair<G4int, const G4double 304 static const std::pair<G4int, const G4double*> Z6N6(6,pZ6N6); 303 static const G4double pZ6N7[4]={1.5E-7, 300. 305 static const G4double pZ6N7[4]={1.5E-7, 300., .129, 5.E-4}; // *** Only Nat Mix *** 304 static const std::pair<G4int, const G4double 306 static const std::pair<G4int, const G4double*> Z6N7(7,pZ6N7); 305 static const std::pair<G4int, const G4double 307 static const std::pair<G4int, const G4double*> Z6[N6]={Z6N6, Z6N7}; 306 //==> N (Z=7) 308 //==> N (Z=7) 307 static const G4int N7=2; 309 static const G4int N7=2; 308 static const G4double pZ7N7[4]={5.E-8, 500., 310 static const G4double pZ7N7[4]={5.E-8, 500., .085, 2.E-4}; 309 static const std::pair<G4int, const G4double 311 static const std::pair<G4int, const G4double*> Z7N7(7,pZ7N7); 310 static const G4double pZ7N8[4]={5.E-8, 140., 312 static const G4double pZ7N8[4]={5.E-8, 140., .15, 9.E-4}; 311 static const std::pair<G4int, const G4double 313 static const std::pair<G4int, const G4double*> Z7N8(8,pZ7N8); 312 static const std::pair<G4int, const G4double 314 static const std::pair<G4int, const G4double*> Z7[N7]={Z7N7, Z7N8}; 313 //==> O (Z=8) 315 //==> O (Z=8) 314 static const G4int N8=3; 316 static const G4int N8=3; 315 static const G4double pZ8N8[4]={7.E-8, 0., . 317 static const G4double pZ8N8[4]={7.E-8, 0., .021, 1.5E-5}; 316 static const std::pair<G4int, const G4double 318 static const std::pair<G4int, const G4double*> Z8N8(8,pZ8N8); 317 static const G4double pZ8N9[4]={2.E-8, 170., 319 static const G4double pZ8N9[4]={2.E-8, 170., .062, 1.E-3}; 318 static const std::pair<G4int, const G4double 320 static const std::pair<G4int, const G4double*> Z8N9(9,pZ8N9); 319 static const G4double pZ8N10[4]={1.E-9, 0., 321 static const G4double pZ8N10[4]={1.E-9, 0., .051, 2.5E-4}; // *** No DATA *** 320 static const std::pair<G4int, const G4double 322 static const std::pair<G4int, const G4double*> Z8N10(10,pZ8N10); 321 static const std::pair<G4int, const G4double 323 static const std::pair<G4int, const G4double*> Z8[N8]={Z8N8, Z8N9, Z8N10}; 322 //==> F (Z=9) 324 //==> F (Z=9) 323 static const G4int N9=1; 325 static const G4int N9=1; 324 static const G4double pZ9N10[4]={1.E-11, 300 326 static const G4double pZ9N10[4]={1.E-11, 3000., .026, 3.E-5}; 325 static const std::pair<G4int, const G4double 327 static const std::pair<G4int, const G4double*> Z9N10(10,pZ9N10); 326 static const std::pair<G4int, const G4double 328 static const std::pair<G4int, const G4double*> Z9[N9]={Z9N10}; 327 //==> Ne(Z=10) 329 //==> Ne(Z=10) 328 static const G4int N10=3; 330 static const G4int N10=3; 329 static const G4double pZ10N10[4]={4.E-8, 0., 331 static const G4double pZ10N10[4]={4.E-8, 0., .021, 1.5E-5}; // *** No DATA *** 330 static const std::pair<G4int, const G4double 332 static const std::pair<G4int, const G4double*> Z10N10(10,pZ10N10); 331 static const G4double pZ10N11[4]={4.E-8, 0., 333 static const G4double pZ10N11[4]={4.E-8, 0., .021, 1.5E-5}; // *** No DATA *** 332 static const std::pair<G4int, const G4double 334 static const std::pair<G4int, const G4double*> Z10N11(11,pZ10N11); 333 static const G4double pZ10N12[4]={4.E-8, 0., 335 static const G4double pZ10N12[4]={4.E-8, 0., .051, 2.5E-4}; // *** No DATA *** 334 static const std::pair<G4int, const G4double 336 static const std::pair<G4int, const G4double*> Z10N12(12,pZ10N12); 335 static const std::pair<G4int, const G4double 337 static const std::pair<G4int, const G4double*> Z10[N10]={Z10N10, Z10N11, Z10N12}; 336 //==> Na(Z=11) 338 //==> Na(Z=11) 337 static const G4int N11=1; 339 static const G4int N11=1; 338 static const G4double pZ11N12[4]={8.E-10, 50 340 static const G4double pZ11N12[4]={8.E-10, 500., .05, 3.E-4}; 339 static const std::pair<G4int, const G4double 341 static const std::pair<G4int, const G4double*> Z11N12(12,pZ11N12); 340 static const std::pair<G4int, const G4double 342 static const std::pair<G4int, const G4double*> Z11[N11]={Z11N12}; 341 //==> Mg(Z=12) 343 //==> Mg(Z=12) 342 static const G4int N12=3; 344 static const G4int N12=3; 343 static const G4double pZ12N12[4]={2.E-9, 350 345 static const G4double pZ12N12[4]={2.E-9, 350., .065, 3.E-4}; 344 static const std::pair<G4int, const G4double 346 static const std::pair<G4int, const G4double*> Z12N12(12,pZ12N12); 345 static const G4double pZ12N13[4]={2.E-9, 350 347 static const G4double pZ12N13[4]={2.E-9, 350., .068, 2.E-4}; 346 static const std::pair<G4int, const G4double 348 static const std::pair<G4int, const G4double*> Z12N13(13,pZ12N13); 347 static const G4double pZ12N14[4]={2.E-9, 0., 349 static const G4double pZ12N14[4]={2.E-9, 0., .051, 2.5E-4}; 348 static const std::pair<G4int, const G4double 350 static const std::pair<G4int, const G4double*> Z12N14(14,pZ12N14); 349 static const std::pair<G4int, const G4double 351 static const std::pair<G4int, const G4double*> Z12[N12]={Z12N12, Z12N13, Z12N14}; 350 //==> Al(Z=13) 352 //==> Al(Z=13) 351 static const G4int N13=1; 353 static const G4int N13=1; 352 static const G4double pZ13N14[4]={9.E-9, 500 354 static const G4double pZ13N14[4]={9.E-9, 500., .075, 4.E-4}; 353 static const std::pair<G4int, const G4double 355 static const std::pair<G4int, const G4double*> Z13N14(14,pZ13N14); 354 static const std::pair<G4int, const G4double 356 static const std::pair<G4int, const G4double*> Z13[N13]={Z13N14}; 355 //==> Si(Z=14) 357 //==> Si(Z=14) 356 static const G4int N14=3; 358 static const G4int N14=3; 357 static const G4double pZ14N14[4]={4.E-9, 200 359 static const G4double pZ14N14[4]={4.E-9, 200., .076, 1.E-4}; 358 static const std::pair<G4int, const G4double 360 static const std::pair<G4int, const G4double*> Z14N14(14,pZ14N14); 359 static const G4double pZ14N15[4]={6.E-9, 500 361 static const G4double pZ14N15[4]={6.E-9, 500., .073, 4.E-4}; 360 static const std::pair<G4int, const G4double 362 static const std::pair<G4int, const G4double*> Z14N15(15,pZ14N15); 361 static const G4double pZ14N16[4]={4.E-9, 200 363 static const G4double pZ14N16[4]={4.E-9, 200., .076, 1.E-4}; 362 static const std::pair<G4int, const G4double 364 static const std::pair<G4int, const G4double*> Z14N16(16,pZ14N16); 363 static const std::pair<G4int, const G4double 365 static const std::pair<G4int, const G4double*> Z14[N14]={Z14N14, Z14N15, Z14N16}; 364 //==> P (Z=15) 366 //==> P (Z=15) 365 static const G4int N15=1; 367 static const G4int N15=1; 366 static const G4double pZ15N16[4]={6.E-9, 550 368 static const G4double pZ15N16[4]={6.E-9, 550., .077, 2.E-4}; 367 static const std::pair<G4int, const G4double 369 static const std::pair<G4int, const G4double*> Z15N16(16,pZ15N16); 368 static const std::pair<G4int, const G4double 370 static const std::pair<G4int, const G4double*> Z15[N15]={Z15N16}; 369 //==> S (Z=16) 371 //==> S (Z=16) 370 static const G4int N16=4; 372 static const G4int N16=4; 371 static const G4double pZ16N16[4]={1.5E-8, 50 373 static const G4double pZ16N16[4]={1.5E-8, 500., .087, 5.E-4}; 372 static const std::pair<G4int, const G4double 374 static const std::pair<G4int, const G4double*> Z16N16(16,pZ16N16); 373 static const G4double pZ16N17[4]={1.E-8, 300 375 static const G4double pZ16N17[4]={1.E-8, 300., .07, 4.E-3}; 374 static const std::pair<G4int, const G4double 376 static const std::pair<G4int, const G4double*> Z16N17(17,pZ16N17); 375 static const G4double pZ16N18[4]={2.E-8, 300 377 static const G4double pZ16N18[4]={2.E-8, 300., .094, 3.E-4}; 376 static const std::pair<G4int, const G4double 378 static const std::pair<G4int, const G4double*> Z16N18(18,pZ16N18); 377 static const G4double pZ16N20[4]={2.E-8, 200 379 static const G4double pZ16N20[4]={2.E-8, 200., .11, 3.E-4}; 378 static const std::pair<G4int, const G4double 380 static const std::pair<G4int, const G4double*> Z16N20(20,pZ16N20); 379 static const std::pair<G4int, const G4double 381 static const std::pair<G4int, const G4double*> Z16[N16]={Z16N16, Z16N17, Z16N18, Z16N20}; 380 //==> Cl(Z=17) 382 //==> Cl(Z=17) 381 static const G4int N17=2; 383 static const G4int N17=2; 382 static const G4double pZ17N18[4]={3.E-9, 300 384 static const G4double pZ17N18[4]={3.E-9, 300., .072, 4.E-4}; 383 static const std::pair<G4int, const G4double 385 static const std::pair<G4int, const G4double*> Z17N18(18,pZ17N18); 384 static const G4double pZ17N20[4]={5.E-9, 0., 386 static const G4double pZ17N20[4]={5.E-9, 0., .051, 2.5E-4}; 385 static const std::pair<G4int, const G4double 387 static const std::pair<G4int, const G4double*> Z17N20(20,pZ17N20); 386 static const std::pair<G4int, const G4double 388 static const std::pair<G4int, const G4double*> Z17[N17]={Z17N18, Z17N20}; 387 //==> Ar(Z=18) 389 //==> Ar(Z=18) 388 static const G4int N18=3; 390 static const G4int N18=3; 389 static const G4double pZ18N18[4]={2.5E-9, 30 391 static const G4double pZ18N18[4]={2.5E-9, 300., .074, 2.E-4}; 390 static const std::pair<G4int, const G4double 392 static const std::pair<G4int, const G4double*> Z18N18(18,pZ18N18); 391 static const G4double pZ18N20[4]={2.E-8, 400 393 static const G4double pZ18N20[4]={2.E-8, 400., .084, 4.E-4}; 392 static const std::pair<G4int, const G4double 394 static const std::pair<G4int, const G4double*> Z18N20(20,pZ18N20); 393 static const G4double pZ18N22[4]={1.E-9, 100 395 static const G4double pZ18N22[4]={1.E-9, 100., .065, 2.E-4}; 394 static const std::pair<G4int, const G4double 396 static const std::pair<G4int, const G4double*> Z18N22(22,pZ18N22); 395 static const std::pair<G4int, const G4double 397 static const std::pair<G4int, const G4double*> Z18[N18]={Z18N18, Z18N20, Z18N22}; 396 //==> K (Z=19) 398 //==> K (Z=19) 397 static const G4int N19=3; 399 static const G4int N19=3; 398 static const G4double pZ19N20[4]={3.E-9, 4., 400 static const G4double pZ19N20[4]={3.E-9, 4., .02, 2.E-4}; 399 static const std::pair<G4int, const G4double 401 static const std::pair<G4int, const G4double*> Z19N20(20,pZ19N20); 400 static const G4double pZ19N21[4]={3.E-9, 500 402 static const G4double pZ19N21[4]={3.E-9, 500., .062, 7.E-4}; 401 static const std::pair<G4int, const G4double 403 static const std::pair<G4int, const G4double*> Z19N21(21,pZ19N21); 402 static const G4double pZ19N22[4]={3.E-9, 400 404 static const G4double pZ19N22[4]={3.E-9, 400., .073, 3.E-4}; 403 static const std::pair<G4int, const G4double 405 static const std::pair<G4int, const G4double*> Z19N22(22,pZ19N22); 404 static const std::pair<G4int, const G4double 406 static const std::pair<G4int, const G4double*> Z19[N19]={Z19N20, Z19N21, Z19N22}; 405 //==> Ca(Z=20) 407 //==> Ca(Z=20) 406 static const G4int N20=6; 408 static const G4int N20=6; 407 static const G4double pZ20N20[4]={3.E-9, 0., 409 static const G4double pZ20N20[4]={3.E-9, 0., .021, 1.5E-5}; 408 static const std::pair<G4int, const G4double 410 static const std::pair<G4int, const G4double*> Z20N20(20,pZ20N20); 409 static const G4double pZ20N22[4]={2.E-9, 400 411 static const G4double pZ20N22[4]={2.E-9, 400., .072, 4.E-4}; 410 static const std::pair<G4int, const G4double 412 static const std::pair<G4int, const G4double*> Z20N22(22,pZ20N22); 411 static const G4double pZ20N23[4]={.3E-9, 280 413 static const G4double pZ20N23[4]={.3E-9, 280., .042, 2.5E-4}; 412 static const std::pair<G4int, const G4double 414 static const std::pair<G4int, const G4double*> Z20N23(23,pZ20N23); 413 static const G4double pZ20N24[4]={1.E-9, 300 415 static const G4double pZ20N24[4]={1.E-9, 300., .062, 2.E-4}; 414 static const std::pair<G4int, const G4double 416 static const std::pair<G4int, const G4double*> Z20N24(24,pZ20N24); 415 static const G4double pZ20N26[4]={1.5E-8, 40 417 static const G4double pZ20N26[4]={1.5E-8, 400., .064, 2.E-4}; 416 static const std::pair<G4int, const G4double 418 static const std::pair<G4int, const G4double*> Z20N26(26,pZ20N26); 417 static const G4double pZ20N28[4]={7.E-9, 0., 419 static const G4double pZ20N28[4]={7.E-9, 0., .051, 2.5E-4}; 418 static const std::pair<G4int, const G4double 420 static const std::pair<G4int, const G4double*> Z20N28(28,pZ20N28); 419 static const std::pair<G4int, const G4double 421 static const std::pair<G4int, const G4double*> Z20[N20]={Z20N20, Z20N22, Z20N23, 420 422 Z20N24, Z20N26, Z20N28}; 421 //==> Sc(Z=21) 423 //==> Sc(Z=21) 422 static const G4int N21=1; 424 static const G4int N21=1; 423 static const G4double pZ21N24[4]={5.E-9, 100 425 static const G4double pZ21N24[4]={5.E-9, 1000., .068, 6.E-4}; 424 static const std::pair<G4int, const G4double 426 static const std::pair<G4int, const G4double*> Z21N24(24,pZ21N24); 425 static const std::pair<G4int, const G4double 427 static const std::pair<G4int, const G4double*> Z21[N21]={Z21N24}; 426 //==> Ti(Z=22) 428 //==> Ti(Z=22) 427 static const G4int N22=5; 429 static const G4int N22=5; 428 static const G4double pZ22N24[4]={4.E-9, 900 430 static const G4double pZ22N24[4]={4.E-9, 900., .065, 6.E-4}; 429 static const std::pair<G4int, const G4double 431 static const std::pair<G4int, const G4double*> Z22N24(24,pZ22N24); 430 static const G4double pZ22N25[4]={4.E-9, 100 432 static const G4double pZ22N25[4]={4.E-9, 1000., .065, 1.E-3}; 431 static const std::pair<G4int, const G4double 433 static const std::pair<G4int, const G4double*> Z22N25(25,pZ22N25); 432 static const G4double pZ22N26[4]={4.E-9, 900 434 static const G4double pZ22N26[4]={4.E-9, 900., .066, 4.E-4}; 433 static const std::pair<G4int, const G4double 435 static const std::pair<G4int, const G4double*> Z22N26(26,pZ22N26); 434 static const G4double pZ22N27[4]={4.E-9, 800 436 static const G4double pZ22N27[4]={4.E-9, 800., .021, 3.E-4}; 435 static const std::pair<G4int, const G4double 437 static const std::pair<G4int, const G4double*> Z22N27(27,pZ22N27); 436 static const G4double pZ22N28[4]={4.E-9, 550 438 static const G4double pZ22N28[4]={4.E-9, 550., .067, 2.E-4}; 437 static const std::pair<G4int, const G4double 439 static const std::pair<G4int, const G4double*> Z22N28(28,pZ22N28); 438 static const std::pair<G4int, const G4double 440 static const std::pair<G4int, const G4double*> Z22[N22]={Z22N24, Z22N25, Z22N26, 439 441 Z22N27, Z22N28}; 440 //==> V (Z=23) 442 //==> V (Z=23) 441 static const G4int N23=2; 443 static const G4int N23=2; 442 static const G4double pZ23N27[4]={4.E-9, 700 444 static const G4double pZ23N27[4]={4.E-9, 700., .065, 1.E-3}; // *** Only Nat mix *** 443 static const std::pair<G4int, const G4double 445 static const std::pair<G4int, const G4double*> Z23N27(27,pZ23N27); 444 static const G4double pZ23N28[4]={4.E-9, 700 446 static const G4double pZ23N28[4]={4.E-9, 700., .065, 1.E-3}; // *** Only Nat mix *** 445 static const std::pair<G4int, const G4double 447 static const std::pair<G4int, const G4double*> Z23N28(28,pZ23N28); 446 static const std::pair<G4int, const G4double 448 static const std::pair<G4int, const G4double*> Z23[N23]={Z23N27, Z23N28}; 447 //==> Cr(Z=24) 449 //==> Cr(Z=24) 448 static const G4int N24=4; 450 static const G4int N24=4; 449 static const G4double pZ24N26[4]={1.E-9, 750 451 static const G4double pZ24N26[4]={1.E-9, 750., .056, 2.E-4}; 450 static const std::pair<G4int, const G4double 452 static const std::pair<G4int, const G4double*> Z24N26(26,pZ24N26); 451 static const G4double pZ24N28[4]={1.E-9, 350 453 static const G4double pZ24N28[4]={1.E-9, 350., .061, 1.E-4}; 452 static const std::pair<G4int, const G4double 454 static const std::pair<G4int, const G4double*> Z24N28(28,pZ24N28); 453 static const G4double pZ24N29[4]={.4E-9, 650 455 static const G4double pZ24N29[4]={.4E-9, 650., .056, 1.5E-4}; 454 static const std::pair<G4int, const G4double 456 static const std::pair<G4int, const G4double*> Z24N29(29,pZ24N29); 455 static const G4double pZ24N30[4]={1.E-9, 700 457 static const G4double pZ24N30[4]={1.E-9, 700., .054, 3.E-4}; 456 static const std::pair<G4int, const G4double 458 static const std::pair<G4int, const G4double*> Z24N30(30,pZ24N30); 457 static const std::pair<G4int, const G4double 459 static const std::pair<G4int, const G4double*> Z24[N24]={Z24N26, Z24N28, Z24N29, Z24N30}; 458 //==> Mn(Z=25) 460 //==> Mn(Z=25) 459 static const G4int N25=1; 461 static const G4int N25=1; 460 static const G4double pZ25N30[4]={.3E-9, 650 462 static const G4double pZ25N30[4]={.3E-9, 650., .042, 3.5E-4}; 461 static const std::pair<G4int, const G4double 463 static const std::pair<G4int, const G4double*> Z25N30(30,pZ25N30); 462 static const std::pair<G4int, const G4double 464 static const std::pair<G4int, const G4double*> Z25[N25]={Z25N30}; 463 //==> Fe(Z=26) 465 //==> Fe(Z=26) 464 static const G4int N26=4; 466 static const G4int N26=4; 465 static const G4double pZ26N28[4]={.9E-9, 200 467 static const G4double pZ26N28[4]={.9E-9, 200., .062, 1.E-4}; 466 static const std::pair<G4int, const G4double 468 static const std::pair<G4int, const G4double*> Z26N28(28,pZ26N28); 467 static const G4double pZ26N30[4]={.9E-9, 150 469 static const G4double pZ26N30[4]={.9E-9, 1500., .055, 5.E-5}; 468 static const std::pair<G4int, const G4double 470 static const std::pair<G4int, const G4double*> Z26N30(30,pZ26N30); 469 static const G4double pZ26N31[4]={.9E-9, 110 471 static const G4double pZ26N31[4]={.9E-9, 1100., .048, 9.E-4}; 470 static const std::pair<G4int, const G4double 472 static const std::pair<G4int, const G4double*> Z26N31(31,pZ26N31); 471 static const G4double pZ26N32[4]={.9E-9, 500 473 static const G4double pZ26N32[4]={.9E-9, 500., .055, 2.E-4}; 472 static const std::pair<G4int, const G4double 474 static const std::pair<G4int, const G4double*> Z26N32(32,pZ26N32); 473 static const std::pair<G4int, const G4double 475 static const std::pair<G4int, const G4double*> Z26[N26]={Z26N28, Z26N30, Z26N31, Z26N32}; 474 //==> Co(Z=27) 476 //==> Co(Z=27) 475 static const G4int N27=1; 477 static const G4int N27=1; 476 static const G4double pZ27N32[4]={.2E-9, 21. 478 static const G4double pZ27N32[4]={.2E-9, 21., .008, 3.E-6}; 477 static const std::pair<G4int, const G4double 479 static const std::pair<G4int, const G4double*> Z27N32(32,pZ27N32); 478 static const std::pair<G4int, const G4double 480 static const std::pair<G4int, const G4double*> Z27[N27]={Z27N32}; 479 //==> Ni(Z=28) 481 //==> Ni(Z=28) 480 static const G4int N28=5; 482 static const G4int N28=5; 481 static const G4double pZ28N30[4]={.3E-9, 0., 483 static const G4double pZ28N30[4]={.3E-9, 0., .021, 1.5E-5}; 482 static const std::pair<G4int, const G4double 484 static const std::pair<G4int, const G4double*> Z28N30(30,pZ28N30); 483 static const G4double pZ28N32[4]={.3E-9, 0., 485 static const G4double pZ28N32[4]={.3E-9, 0., .021, 1.5E-5}; 484 static const std::pair<G4int, const G4double 486 static const std::pair<G4int, const G4double*> Z28N32(32,pZ28N32); 485 static const G4double pZ28N33[4]={.3E-9, 0., 487 static const G4double pZ28N33[4]={.3E-9, 0., .021, 1.5E-5}; 486 static const std::pair<G4int, const G4double 488 static const std::pair<G4int, const G4double*> Z28N33(33,pZ28N33); 487 static const G4double pZ28N34[4]={.3E-9, 700 489 static const G4double pZ28N34[4]={.3E-9, 700., .0065, 2.E-6}; 488 static const std::pair<G4int, const G4double 490 static const std::pair<G4int, const G4double*> Z28N34(34,pZ28N34); 489 static const G4double pZ28N36[4]={.3E-9, 75. 491 static const G4double pZ28N36[4]={.3E-9, 75., .0107, 4.E-6}; 490 static const std::pair<G4int, const G4double 492 static const std::pair<G4int, const G4double*> Z28N36(36,pZ28N36); 491 static const std::pair<G4int, const G4double 493 static const std::pair<G4int, const G4double*> Z28[N28]={Z28N30, Z28N32, Z28N33, 492 494 Z28N34, Z28N36}; 493 //==> Cu(Z=29) 495 //==> Cu(Z=29) 494 static const G4int N29=2; 496 static const G4int N29=2; 495 static const G4double pZ29N34[4]={.1E-9, 35. 497 static const G4double pZ29N34[4]={.1E-9, 35., .005, 6.E-4}; 496 static const std::pair<G4int, const G4double 498 static const std::pair<G4int, const G4double*> Z29N34(34,pZ29N34); 497 static const G4double pZ29N36[4]={.2E-9, 23. 499 static const G4double pZ29N36[4]={.2E-9, 23., .01, 2.E-4}; 498 static const std::pair<G4int, const G4double 500 static const std::pair<G4int, const G4double*> Z29N36(36,pZ29N36); 499 static const std::pair<G4int, const G4double 501 static const std::pair<G4int, const G4double*> Z29[N29]={Z29N34, Z29N36}; 500 //==> Zn(Z=30) 502 //==> Zn(Z=30) 501 static const G4int N30=5; 503 static const G4int N30=5; 502 static const G4double pZ30N34[4]={.2E-9, 140 504 static const G4double pZ30N34[4]={.2E-9, 140., .02, 8.E-6}; // *** only NAT mix *** 503 static const std::pair<G4int, const G4double 505 static const std::pair<G4int, const G4double*> Z30N34(34,pZ30N34); 504 static const G4double pZ30N36[4]={.2E-9, 140 506 static const G4double pZ30N36[4]={.2E-9, 140., .02, 8.E-6}; // *** only NAT mix *** 505 static const std::pair<G4int, const G4double 507 static const std::pair<G4int, const G4double*> Z30N36(36,pZ30N36); 506 static const G4double pZ30N37[4]={.2E-9, 140 508 static const G4double pZ30N37[4]={.2E-9, 140., .02, 8.E-6}; // *** only NAT mix *** 507 static const std::pair<G4int, const G4double 509 static const std::pair<G4int, const G4double*> Z30N37(37,pZ30N37); 508 static const G4double pZ30N38[4]={.2E-9, 140 510 static const G4double pZ30N38[4]={.2E-9, 140., .02, 8.E-6}; // *** only NAT mix *** 509 static const std::pair<G4int, const G4double 511 static const std::pair<G4int, const G4double*> Z30N38(38,pZ30N38); 510 static const G4double pZ30N40[4]={.2E-9, 140 512 static const G4double pZ30N40[4]={.2E-9, 140., .02, 8.E-6}; // *** only NAT mix *** 511 static const std::pair<G4int, const G4double 513 static const std::pair<G4int, const G4double*> Z30N40(40,pZ30N40); 512 static const std::pair<G4int, const G4double 514 static const std::pair<G4int, const G4double*> Z30[N30]={Z30N34, Z30N36, Z30N37, 513 515 Z30N38, Z30N40}; 514 //==> Ga(Z=31) 516 //==> Ga(Z=31) 515 static const G4int N31=2; 517 static const G4int N31=2; 516 static const G4double pZ31N38[4]={.3E-9, 450 518 static const G4double pZ31N38[4]={.3E-9, 450., .050, 3.E-4}; 517 static const std::pair<G4int, const G4double 519 static const std::pair<G4int, const G4double*> Z31N38(38,pZ31N38); 518 static const G4double pZ31N40[4]={.3E-9, 600 520 static const G4double pZ31N40[4]={.3E-9, 600., .048, 2.E-4}; 519 static const std::pair<G4int, const G4double 521 static const std::pair<G4int, const G4double*> Z31N40(40,pZ31N40); 520 static const std::pair<G4int, const G4double 522 static const std::pair<G4int, const G4double*> Z31[N31]={Z31N38, Z31N40}; 521 //==> Ge(Z=32) 523 //==> Ge(Z=32) 522 static const G4int N32=5; 524 static const G4int N32=5; 523 static const G4double pZ32N38[4]={.2E-9, 200 525 static const G4double pZ32N38[4]={.2E-9, 200., .05, 2.E-4}; 524 static const std::pair<G4int, const G4double 526 static const std::pair<G4int, const G4double*> Z32N38(38,pZ32N38); 525 static const G4double pZ32N40[4]={.2E-9, 600 527 static const G4double pZ32N40[4]={.2E-9, 600., .05, 2.E-4}; 526 static const std::pair<G4int, const G4double 528 static const std::pair<G4int, const G4double*> Z32N40(40,pZ32N40); 527 static const G4double pZ32N41[4]={1.5E-11, 6 529 static const G4double pZ32N41[4]={1.5E-11, 600., .028, 3.E-4}; 528 static const std::pair<G4int, const G4double 530 static const std::pair<G4int, const G4double*> Z32N41(41,pZ32N41); 529 static const G4double pZ32N42[4]={9.E-11, 40 531 static const G4double pZ32N42[4]={9.E-11, 400., .048, 3.E-4}; 530 static const std::pair<G4int, const G4double 532 static const std::pair<G4int, const G4double*> Z32N42(42,pZ32N42); 531 static const G4double pZ32N44[4]={9.E-11, 40 533 static const G4double pZ32N44[4]={9.E-11, 400., .043, 3.E-4}; 532 static const std::pair<G4int, const G4double 534 static const std::pair<G4int, const G4double*> Z32N44(44,pZ32N44); 533 static const std::pair<G4int, const G4double 535 static const std::pair<G4int, const G4double*> Z32[N32]={Z32N38, Z32N40, Z32N41, 534 536 Z32N42, Z32N44}; 535 //==> As(Z=33) 537 //==> As(Z=33) 536 static const G4int N33=1; 538 static const G4int N33=1; 537 static const G4double pZ33N42[4]={1.E-11, 10 539 static const G4double pZ33N42[4]={1.E-11, 1000., .032, 1.E-4}; 538 static const std::pair<G4int, const G4double 540 static const std::pair<G4int, const G4double*> Z33N42(42,pZ33N42); 539 static const std::pair<G4int, const G4double 541 static const std::pair<G4int, const G4double*> Z33[N33]={Z33N42}; 540 //==> Se(Z=34) 542 //==> Se(Z=34) 541 static const G4int N34=6; 543 static const G4int N34=6; 542 static const G4double pZ34N40[4]={3.E-12, 50 544 static const G4double pZ34N40[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 543 static const std::pair<G4int, const G4double 545 static const std::pair<G4int, const G4double*> Z34N40(40,pZ34N40); 544 static const G4double pZ34N42[4]={3.E-12, 50 546 static const G4double pZ34N42[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 545 static const std::pair<G4int, const G4double 547 static const std::pair<G4int, const G4double*> Z34N42(42,pZ34N42); 546 static const G4double pZ34N43[4]={3.E-12, 50 548 static const G4double pZ34N43[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 547 static const std::pair<G4int, const G4double 549 static const std::pair<G4int, const G4double*> Z34N43(43,pZ34N43); 548 static const G4double pZ34N44[4]={3.E-12, 50 550 static const G4double pZ34N44[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 549 static const std::pair<G4int, const G4double 551 static const std::pair<G4int, const G4double*> Z34N44(44,pZ34N44); 550 static const G4double pZ34N46[4]={3.E-12, 50 552 static const G4double pZ34N46[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 551 static const std::pair<G4int, const G4double 553 static const std::pair<G4int, const G4double*> Z34N46(46,pZ34N46); 552 static const G4double pZ34N48[4]={3.E-12, 50 554 static const G4double pZ34N48[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 553 static const std::pair<G4int, const G4double 555 static const std::pair<G4int, const G4double*> Z34N48(48,pZ34N48); 554 static const std::pair<G4int, const G4double 556 static const std::pair<G4int, const G4double*> Z34[N34]={Z34N40, Z34N42, Z34N43, 555 557 Z34N44, Z34N46, Z34N48}; 556 //==> Br(Z=35) 558 //==> Br(Z=35) 557 static const G4int N35=2; 559 static const G4int N35=2; 558 static const G4double pZ35N44[4]={3.E-12, 50 560 static const G4double pZ35N44[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 559 static const std::pair<G4int, const G4double 561 static const std::pair<G4int, const G4double*> Z35N44(44,pZ35N44); 560 static const G4double pZ35N46[4]={3.E-12, 50 562 static const G4double pZ35N46[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 561 static const std::pair<G4int, const G4double 563 static const std::pair<G4int, const G4double*> Z35N46(46,pZ35N46); 562 static const std::pair<G4int, const G4double 564 static const std::pair<G4int, const G4double*> Z35[N35]={Z35N44, Z35N46}; 563 //==> Kr(Z=36) 565 //==> Kr(Z=36) 564 static const G4int N36=6; 566 static const G4int N36=6; 565 static const G4double pZ36N42[4]={3.E-12, 50 567 static const G4double pZ36N42[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 566 static const std::pair<G4int, const G4double 568 static const std::pair<G4int, const G4double*> Z36N42(42,pZ36N42); 567 static const G4double pZ36N44[4]={3.E-12, 50 569 static const G4double pZ36N44[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 568 static const std::pair<G4int, const G4double 570 static const std::pair<G4int, const G4double*> Z36N44(44,pZ36N44); 569 static const G4double pZ36N46[4]={3.E-12, 50 571 static const G4double pZ36N46[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 570 static const std::pair<G4int, const G4double 572 static const std::pair<G4int, const G4double*> Z36N46(46,pZ36N46); 571 static const G4double pZ36N47[4]={3.E-12, 50 573 static const G4double pZ36N47[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 572 static const std::pair<G4int, const G4double 574 static const std::pair<G4int, const G4double*> Z36N47(47,pZ36N47); 573 static const G4double pZ36N48[4]={3.E-12, 50 575 static const G4double pZ36N48[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 574 static const std::pair<G4int, const G4double 576 static const std::pair<G4int, const G4double*> Z36N48(48,pZ36N48); 575 static const G4double pZ36N50[4]={3.E-12, 50 577 static const G4double pZ36N50[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 576 static const std::pair<G4int, const G4double 578 static const std::pair<G4int, const G4double*> Z36N50(50,pZ36N50); 577 static const std::pair<G4int, const G4double 579 static const std::pair<G4int, const G4double*> Z36[N36]={Z36N42, Z36N44, Z36N46, 578 580 Z36N47, Z36N48, Z36N50}; 579 //==> Rb(Z=37) 581 //==> Rb(Z=37) 580 static const G4int N37=2; 582 static const G4int N37=2; 581 static const G4double pZ37N48[4]={3.E-12, 50 583 static const G4double pZ37N48[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 582 static const std::pair<G4int, const G4double 584 static const std::pair<G4int, const G4double*> Z37N48(48,pZ37N48); 583 static const G4double pZ37N50[4]={3.E-12, 50 585 static const G4double pZ37N50[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 584 static const std::pair<G4int, const G4double 586 static const std::pair<G4int, const G4double*> Z37N50(50,pZ37N50); 585 static const std::pair<G4int, const G4double 587 static const std::pair<G4int, const G4double*> Z37[N37]={Z37N48, Z37N50}; 586 //==> Sr(Z=38) 588 //==> Sr(Z=38) 587 static const G4int N38=4; 589 static const G4int N38=4; 588 static const G4double pZ38N46[4]={3.E-12, 50 590 static const G4double pZ38N46[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 589 static const std::pair<G4int, const G4double 591 static const std::pair<G4int, const G4double*> Z38N46(46,pZ38N46); 590 static const G4double pZ38N48[4]={3.E-12, 50 592 static const G4double pZ38N48[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 591 static const std::pair<G4int, const G4double 593 static const std::pair<G4int, const G4double*> Z38N48(48,pZ38N48); 592 static const G4double pZ38N49[4]={3.E-12, 50 594 static const G4double pZ38N49[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 593 static const std::pair<G4int, const G4double 595 static const std::pair<G4int, const G4double*> Z38N49(49,pZ38N49); 594 static const G4double pZ38N50[4]={3.E-12, 50 596 static const G4double pZ38N50[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 595 static const std::pair<G4int, const G4double 597 static const std::pair<G4int, const G4double*> Z38N50(50,pZ38N50); 596 static const std::pair<G4int, const G4double 598 static const std::pair<G4int, const G4double*> Z38[N38]={Z38N46, Z38N48, Z38N49, Z38N50}; 597 //==> Y (Z=39) 599 //==> Y (Z=39) 598 static const G4int N39=1; 600 static const G4int N39=1; 599 static const G4double pZ39N50[4]={3.E-12, 50 601 static const G4double pZ39N50[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 600 static const std::pair<G4int, const G4double 602 static const std::pair<G4int, const G4double*> Z39N50(50,pZ39N50); 601 static const std::pair<G4int, const G4double 603 static const std::pair<G4int, const G4double*> Z39[N39]={Z39N50}; 602 //==> Zr(Z=40) 604 //==> Zr(Z=40) 603 static const G4int N40=5; 605 static const G4int N40=5; 604 static const G4double pZ40N50[4]={3.E-12, 50 606 static const G4double pZ40N50[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 605 static const std::pair<G4int, const G4double 607 static const std::pair<G4int, const G4double*> Z40N50(50,pZ40N50); 606 static const G4double pZ40N51[4]={3.E-12, 50 608 static const G4double pZ40N51[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 607 static const std::pair<G4int, const G4double 609 static const std::pair<G4int, const G4double*> Z40N51(51,pZ40N51); 608 static const G4double pZ40N52[4]={3.E-12, 50 610 static const G4double pZ40N52[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 609 static const std::pair<G4int, const G4double 611 static const std::pair<G4int, const G4double*> Z40N52(52,pZ40N52); 610 static const G4double pZ40N54[4]={3.E-12, 50 612 static const G4double pZ40N54[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 611 static const std::pair<G4int, const G4double 613 static const std::pair<G4int, const G4double*> Z40N54(54,pZ40N54); 612 static const G4double pZ40N56[4]={3.E-12, 50 614 static const G4double pZ40N56[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 613 static const std::pair<G4int, const G4double 615 static const std::pair<G4int, const G4double*> Z40N56(56,pZ40N56); 614 static const std::pair<G4int, const G4double 616 static const std::pair<G4int, const G4double*> Z40[N40]={Z40N50, Z40N51, Z40N52, 615 617 Z40N54, Z40N56}; 616 //==> Nb(Z=41) 618 //==> Nb(Z=41) 617 static const G4int N41=1; 619 static const G4int N41=1; 618 static const G4double pZ41N52[4]={3.E-12, 50 620 static const G4double pZ41N52[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 619 static const std::pair<G4int, const G4double 621 static const std::pair<G4int, const G4double*> Z41N52(52,pZ41N52); 620 static const std::pair<G4int, const G4double 622 static const std::pair<G4int, const G4double*> Z41[N41]={Z41N52}; 621 //==> Mo(Z=42) 623 //==> Mo(Z=42) 622 static const G4int N42=7; 624 static const G4int N42=7; 623 static const G4double pZ42N50[4]={3.E-12, 50 625 static const G4double pZ42N50[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 624 static const std::pair<G4int, const G4double 626 static const std::pair<G4int, const G4double*> Z42N50(50,pZ42N50); 625 static const G4double pZ42N52[4]={3.E-12, 50 627 static const G4double pZ42N52[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 626 static const std::pair<G4int, const G4double 628 static const std::pair<G4int, const G4double*> Z42N52(52,pZ42N52); 627 static const G4double pZ42N53[4]={3.E-12, 50 629 static const G4double pZ42N53[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 628 static const std::pair<G4int, const G4double 630 static const std::pair<G4int, const G4double*> Z42N53(53,pZ42N53); 629 static const G4double pZ42N54[4]={3.E-12, 50 631 static const G4double pZ42N54[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 630 static const std::pair<G4int, const G4double 632 static const std::pair<G4int, const G4double*> Z42N54(54,pZ42N54); 631 static const G4double pZ42N55[4]={3.E-12, 50 633 static const G4double pZ42N55[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 632 static const std::pair<G4int, const G4double 634 static const std::pair<G4int, const G4double*> Z42N55(55,pZ42N55); 633 static const G4double pZ42N56[4]={3.E-12, 50 635 static const G4double pZ42N56[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 634 static const std::pair<G4int, const G4double 636 static const std::pair<G4int, const G4double*> Z42N56(56,pZ42N56); 635 static const G4double pZ42N58[4]={3.E-12, 50 637 static const G4double pZ42N58[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 636 static const std::pair<G4int, const G4double 638 static const std::pair<G4int, const G4double*> Z42N58(58,pZ42N58); 637 static const std::pair<G4int, const G4double 639 static const std::pair<G4int, const G4double*> Z42[N42]={Z42N50, Z42N52, Z42N53, Z42N54, 638 640 Z42N55, Z42N56, Z42N58}; 639 //==> Mo(Z=43) 641 //==> Mo(Z=43) 640 static const G4int N43=1; 642 static const G4int N43=1; 641 static const G4double pZ43N0[4]={3.E-12, 500 643 static const G4double pZ43N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 642 static const std::pair<G4int, const G4double 644 static const std::pair<G4int, const G4double*> Z43N0(0,pZ43N0); 643 static const std::pair<G4int, const G4double 645 static const std::pair<G4int, const G4double*> Z43[N43]={Z43N0}; 644 //==> Ru(Z=44) 646 //==> Ru(Z=44) 645 static const G4int N44=7; 647 static const G4int N44=7; 646 static const G4double pZ44N52[4]={3.E-12, 50 648 static const G4double pZ44N52[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 647 static const std::pair<G4int, const G4double 649 static const std::pair<G4int, const G4double*> Z44N52(52,pZ44N52); 648 static const G4double pZ44N54[4]={3.E-12, 50 650 static const G4double pZ44N54[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 649 static const std::pair<G4int, const G4double 651 static const std::pair<G4int, const G4double*> Z44N54(54,pZ44N54); 650 static const G4double pZ44N55[4]={3.E-12, 50 652 static const G4double pZ44N55[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 651 static const std::pair<G4int, const G4double 653 static const std::pair<G4int, const G4double*> Z44N55(55,pZ44N55); 652 static const G4double pZ44N56[4]={3.E-12, 50 654 static const G4double pZ44N56[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 653 static const std::pair<G4int, const G4double 655 static const std::pair<G4int, const G4double*> Z44N56(56,pZ44N56); 654 static const G4double pZ44N57[4]={3.E-12, 50 656 static const G4double pZ44N57[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 655 static const std::pair<G4int, const G4double 657 static const std::pair<G4int, const G4double*> Z44N57(57,pZ44N57); 656 static const G4double pZ44N58[4]={3.E-12, 50 658 static const G4double pZ44N58[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 657 static const std::pair<G4int, const G4double 659 static const std::pair<G4int, const G4double*> Z44N58(58,pZ44N58); 658 static const G4double pZ44N60[4]={3.E-12, 50 660 static const G4double pZ44N60[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 659 static const std::pair<G4int, const G4double 661 static const std::pair<G4int, const G4double*> Z44N60(60,pZ44N60); 660 static const std::pair<G4int, const G4double 662 static const std::pair<G4int, const G4double*> Z44[N44]={Z44N52, Z44N54, Z44N55, Z44N56, 661 663 Z44N57, Z44N58, Z44N60}; 662 //==> Rh(Z=45) 664 //==> Rh(Z=45) 663 static const G4int N45=1; 665 static const G4int N45=1; 664 static const G4double pZ45N58[4]={3.E-12, 50 666 static const G4double pZ45N58[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 665 static const std::pair<G4int, const G4double 667 static const std::pair<G4int, const G4double*> Z45N58(58,pZ45N58); 666 static const std::pair<G4int, const G4double 668 static const std::pair<G4int, const G4double*> Z45[N45]={Z45N58}; 667 //==> Pd(Z=46) 669 //==> Pd(Z=46) 668 static const G4int N46=6; 670 static const G4int N46=6; 669 static const G4double pZ46N56[4]={3.E-12, 50 671 static const G4double pZ46N56[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 670 static const std::pair<G4int, const G4double 672 static const std::pair<G4int, const G4double*> Z46N56(56,pZ46N56); 671 static const G4double pZ46N58[4]={3.E-12, 50 673 static const G4double pZ46N58[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 672 static const std::pair<G4int, const G4double 674 static const std::pair<G4int, const G4double*> Z46N58(58,pZ46N58); 673 static const G4double pZ46N59[4]={3.E-12, 50 675 static const G4double pZ46N59[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 674 static const std::pair<G4int, const G4double 676 static const std::pair<G4int, const G4double*> Z46N59(59,pZ46N59); 675 static const G4double pZ46N60[4]={3.E-12, 50 677 static const G4double pZ46N60[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 676 static const std::pair<G4int, const G4double 678 static const std::pair<G4int, const G4double*> Z46N60(60,pZ46N60); 677 static const G4double pZ46N62[4]={3.E-12, 50 679 static const G4double pZ46N62[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 678 static const std::pair<G4int, const G4double 680 static const std::pair<G4int, const G4double*> Z46N62(62,pZ46N62); 679 static const G4double pZ46N64[4]={3.E-12, 50 681 static const G4double pZ46N64[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 680 static const std::pair<G4int, const G4double 682 static const std::pair<G4int, const G4double*> Z46N64(64,pZ46N64); 681 static const std::pair<G4int, const G4double 683 static const std::pair<G4int, const G4double*> Z46[N46]={Z46N56, Z46N58, Z46N59, 682 684 Z46N60, Z46N62, Z46N64}; 683 //==> Ag(Z=47) 685 //==> Ag(Z=47) 684 static const G4int N47=2; 686 static const G4int N47=2; 685 static const G4double pZ47N60[4]={3.E-12, 50 687 static const G4double pZ47N60[4]={3.E-12, 500., .01, 2.7E-5}; 686 static const std::pair<G4int, const G4double 688 static const std::pair<G4int, const G4double*> Z47N60(60,pZ47N60); 687 static const G4double pZ47N62[4]={3.E-12, 48 689 static const G4double pZ47N62[4]={3.E-12, 480., .01, 2.5E-4}; 688 static const std::pair<G4int, const G4double 690 static const std::pair<G4int, const G4double*> Z47N62(62,pZ47N62); 689 static const std::pair<G4int, const G4double 691 static const std::pair<G4int, const G4double*> Z47[N47]={Z47N60, Z47N62}; 690 //==> Cd(Z=48) 692 //==> Cd(Z=48) 691 static const G4int N48=8; 693 static const G4int N48=8; 692 static const G4double pZ48N58[4]={3.E-12, 50 694 static const G4double pZ48N58[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 693 static const std::pair<G4int, const G4double 695 static const std::pair<G4int, const G4double*> Z48N58(58,pZ48N58); 694 static const G4double pZ48N60[4]={3.E-12, 50 696 static const G4double pZ48N60[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 695 static const std::pair<G4int, const G4double 697 static const std::pair<G4int, const G4double*> Z48N60(60,pZ48N60); 696 static const G4double pZ48N62[4]={3.E-12, 50 698 static const G4double pZ48N62[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 697 static const std::pair<G4int, const G4double 699 static const std::pair<G4int, const G4double*> Z48N62(62,pZ48N62); 698 static const G4double pZ48N63[4]={3.E-12, 50 700 static const G4double pZ48N63[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 699 static const std::pair<G4int, const G4double 701 static const std::pair<G4int, const G4double*> Z48N63(63,pZ48N63); 700 static const G4double pZ48N64[4]={3.E-12, 50 702 static const G4double pZ48N64[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 701 static const std::pair<G4int, const G4double 703 static const std::pair<G4int, const G4double*> Z48N64(64,pZ48N64); 702 static const G4double pZ48N65[4]={3.E-12, 50 704 static const G4double pZ48N65[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 703 static const std::pair<G4int, const G4double 705 static const std::pair<G4int, const G4double*> Z48N65(65,pZ48N65); 704 static const G4double pZ48N66[4]={3.E-12, 50 706 static const G4double pZ48N66[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 705 static const std::pair<G4int, const G4double 707 static const std::pair<G4int, const G4double*> Z48N66(66,pZ48N66); 706 static const G4double pZ48N68[4]={3.E-12, 50 708 static const G4double pZ48N68[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 707 static const std::pair<G4int, const G4double 709 static const std::pair<G4int, const G4double*> Z48N68(68,pZ48N68); 708 static const std::pair<G4int, const G4double 710 static const std::pair<G4int, const G4double*> Z48[N48]={Z48N58, Z48N60, Z48N62, Z48N63, 709 711 Z48N64, Z48N65, Z48N66, Z48N68}; 710 //==> In(Z=49) 712 //==> In(Z=49) 711 static const G4int N49=2; 713 static const G4int N49=2; 712 static const G4double pZ49N64[4]={3.E-12, 50 714 static const G4double pZ49N64[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 713 static const std::pair<G4int, const G4double 715 static const std::pair<G4int, const G4double*> Z49N64(64,pZ49N64); 714 static const G4double pZ49N66[4]={3.E-12, 50 716 static const G4double pZ49N66[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 715 static const std::pair<G4int, const G4double 717 static const std::pair<G4int, const G4double*> Z49N66(66,pZ49N66); 716 static const std::pair<G4int, const G4double 718 static const std::pair<G4int, const G4double*> Z49[N49]={Z49N64, Z49N66}; 717 //==> Sn(Z=50) 719 //==> Sn(Z=50) 718 static const G4int N50=10; 720 static const G4int N50=10; 719 static const G4double pZ50N62[4]={3.E-12, 50 721 static const G4double pZ50N62[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 720 static const std::pair<G4int, const G4double 722 static const std::pair<G4int, const G4double*> Z50N62(62,pZ50N62); 721 static const G4double pZ50N64[4]={3.E-12, 50 723 static const G4double pZ50N64[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 722 static const std::pair<G4int, const G4double 724 static const std::pair<G4int, const G4double*> Z50N64(64,pZ50N64); 723 static const G4double pZ50N65[4]={3.E-12, 50 725 static const G4double pZ50N65[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 724 static const std::pair<G4int, const G4double 726 static const std::pair<G4int, const G4double*> Z50N65(65,pZ50N65); 725 static const G4double pZ50N66[4]={3.E-12, 50 727 static const G4double pZ50N66[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 726 static const std::pair<G4int, const G4double 728 static const std::pair<G4int, const G4double*> Z50N66(66,pZ50N66); 727 static const G4double pZ50N67[4]={3.E-12, 50 729 static const G4double pZ50N67[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 728 static const std::pair<G4int, const G4double 730 static const std::pair<G4int, const G4double*> Z50N67(67,pZ50N67); 729 static const G4double pZ50N68[4]={3.E-12, 50 731 static const G4double pZ50N68[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 730 static const std::pair<G4int, const G4double 732 static const std::pair<G4int, const G4double*> Z50N68(68,pZ50N68); 731 static const G4double pZ50N69[4]={3.E-12, 50 733 static const G4double pZ50N69[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 732 static const std::pair<G4int, const G4double 734 static const std::pair<G4int, const G4double*> Z50N69(69,pZ50N69); 733 static const G4double pZ50N70[4]={3.E-12, 50 735 static const G4double pZ50N70[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 734 static const std::pair<G4int, const G4double 736 static const std::pair<G4int, const G4double*> Z50N70(70,pZ50N70); 735 static const G4double pZ50N72[4]={3.E-12, 50 737 static const G4double pZ50N72[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 736 static const std::pair<G4int, const G4double 738 static const std::pair<G4int, const G4double*> Z50N72(72,pZ50N72); 737 static const G4double pZ50N74[4]={3.E-12, 50 739 static const G4double pZ50N74[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 738 static const std::pair<G4int, const G4double 740 static const std::pair<G4int, const G4double*> Z50N74(74,pZ50N74); 739 static const std::pair<G4int, const G4double 741 static const std::pair<G4int, const G4double*> Z50[N50]={Z50N62, Z50N64, Z50N65, Z50N66, 740 742 Z50N67, Z50N68, Z50N69, Z50N70, 741 743 Z50N72, Z50N74}; 742 //==> Sb(Z=51) 744 //==> Sb(Z=51) 743 static const G4int N51=2; 745 static const G4int N51=2; 744 static const G4double pZ51N70[4]={3.E-12, 50 746 static const G4double pZ51N70[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 745 static const std::pair<G4int, const G4double 747 static const std::pair<G4int, const G4double*> Z51N70(70,pZ51N70); 746 static const G4double pZ51N72[4]={3.E-12, 50 748 static const G4double pZ51N72[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 747 static const std::pair<G4int, const G4double 749 static const std::pair<G4int, const G4double*> Z51N72(72,pZ51N72); 748 static const std::pair<G4int, const G4double 750 static const std::pair<G4int, const G4double*> Z51[N51]={Z51N70, Z51N72}; 749 //==> Te(Z=52) 751 //==> Te(Z=52) 750 static const G4int N52=8; 752 static const G4int N52=8; 751 static const G4double pZ52N68[4]={3.E-12, 50 753 static const G4double pZ52N68[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 752 static const std::pair<G4int, const G4double 754 static const std::pair<G4int, const G4double*> Z52N68(68,pZ52N68); 753 static const G4double pZ52N70[4]={3.E-12, 50 755 static const G4double pZ52N70[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 754 static const std::pair<G4int, const G4double 756 static const std::pair<G4int, const G4double*> Z52N70(70,pZ52N70); 755 static const G4double pZ52N71[4]={3.E-12, 50 757 static const G4double pZ52N71[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 756 static const std::pair<G4int, const G4double 758 static const std::pair<G4int, const G4double*> Z52N71(71,pZ52N71); 757 static const G4double pZ52N72[4]={3.E-12, 50 759 static const G4double pZ52N72[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 758 static const std::pair<G4int, const G4double 760 static const std::pair<G4int, const G4double*> Z52N72(72,pZ52N72); 759 static const G4double pZ52N73[4]={3.E-12, 50 761 static const G4double pZ52N73[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 760 static const std::pair<G4int, const G4double 762 static const std::pair<G4int, const G4double*> Z52N73(73,pZ52N73); 761 static const G4double pZ52N74[4]={3.E-12, 50 763 static const G4double pZ52N74[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 762 static const std::pair<G4int, const G4double 764 static const std::pair<G4int, const G4double*> Z52N74(74,pZ52N74); 763 static const G4double pZ52N76[4]={3.E-12, 50 765 static const G4double pZ52N76[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 764 static const std::pair<G4int, const G4double 766 static const std::pair<G4int, const G4double*> Z52N76(76,pZ52N76); 765 static const G4double pZ52N78[4]={3.E-12, 50 767 static const G4double pZ52N78[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 766 static const std::pair<G4int, const G4double 768 static const std::pair<G4int, const G4double*> Z52N78(78,pZ52N78); 767 static const std::pair<G4int, const G4double 769 static const std::pair<G4int, const G4double*> Z52[N52]={Z52N68, Z52N70, Z52N71, Z52N72, 768 770 Z52N73, Z52N74, Z52N76, Z52N78}; 769 //==> I (Z=53) 771 //==> I (Z=53) 770 static const G4int N53=1; 772 static const G4int N53=1; 771 static const G4double pZ53N74[4]={3.E-12, 50 773 static const G4double pZ53N74[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 772 static const std::pair<G4int, const G4double 774 static const std::pair<G4int, const G4double*> Z53N74(74,pZ53N74); 773 static const std::pair<G4int, const G4double 775 static const std::pair<G4int, const G4double*> Z53[N53]={Z53N74}; 774 //==> Xe(Z=54) 776 //==> Xe(Z=54) 775 static const G4int N54=9; 777 static const G4int N54=9; 776 static const G4double pZ54N70[4]={3.E-12, 50 778 static const G4double pZ54N70[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 777 static const std::pair<G4int, const G4double 779 static const std::pair<G4int, const G4double*> Z54N70(70,pZ54N70); 778 static const G4double pZ54N72[4]={3.E-12, 50 780 static const G4double pZ54N72[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 779 static const std::pair<G4int, const G4double 781 static const std::pair<G4int, const G4double*> Z54N72(72,pZ54N72); 780 static const G4double pZ54N74[4]={3.E-12, 50 782 static const G4double pZ54N74[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 781 static const std::pair<G4int, const G4double 783 static const std::pair<G4int, const G4double*> Z54N74(74,pZ54N74); 782 static const G4double pZ54N75[4]={3.E-12, 50 784 static const G4double pZ54N75[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 783 static const std::pair<G4int, const G4double 785 static const std::pair<G4int, const G4double*> Z54N75(75,pZ54N75); 784 static const G4double pZ54N76[4]={3.E-12, 50 786 static const G4double pZ54N76[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 785 static const std::pair<G4int, const G4double 787 static const std::pair<G4int, const G4double*> Z54N76(76,pZ54N76); 786 static const G4double pZ54N77[4]={3.E-12, 50 788 static const G4double pZ54N77[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 787 static const std::pair<G4int, const G4double 789 static const std::pair<G4int, const G4double*> Z54N77(77,pZ54N77); 788 static const G4double pZ54N78[4]={3.E-12, 50 790 static const G4double pZ54N78[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 789 static const std::pair<G4int, const G4double 791 static const std::pair<G4int, const G4double*> Z54N78(78,pZ54N78); 790 static const G4double pZ54N80[4]={3.E-12, 50 792 static const G4double pZ54N80[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 791 static const std::pair<G4int, const G4double 793 static const std::pair<G4int, const G4double*> Z54N80(80,pZ54N80); 792 static const G4double pZ54N82[4]={3.E-12, 50 794 static const G4double pZ54N82[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 793 static const std::pair<G4int, const G4double 795 static const std::pair<G4int, const G4double*> Z54N82(82,pZ54N82); 794 static const std::pair<G4int, const G4double 796 static const std::pair<G4int, const G4double*> Z54[N54]={Z54N70, Z54N72, Z54N74, 795 797 Z54N75, Z54N76, Z54N77, 796 798 Z54N78, Z54N80, Z54N82}; 797 //==> Cs(Z=55) 799 //==> Cs(Z=55) 798 static const G4int N55=1; 800 static const G4int N55=1; 799 static const G4double pZ55N78[4]={3.E-12, 50 801 static const G4double pZ55N78[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 800 static const std::pair<G4int, const G4double 802 static const std::pair<G4int, const G4double*> Z55N78(78,pZ55N78); 801 static const std::pair<G4int, const G4double 803 static const std::pair<G4int, const G4double*> Z55[N55]={Z55N78}; 802 //==> Ba(Z=56) 804 //==> Ba(Z=56) 803 static const G4int N56=7; 805 static const G4int N56=7; 804 static const G4double pZ56N74[4]={3.E-12, 50 806 static const G4double pZ56N74[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 805 static const std::pair<G4int, const G4double 807 static const std::pair<G4int, const G4double*> Z56N74(74,pZ56N74); 806 static const G4double pZ56N76[4]={3.E-12, 50 808 static const G4double pZ56N76[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 807 static const std::pair<G4int, const G4double 809 static const std::pair<G4int, const G4double*> Z56N76(76,pZ56N76); 808 static const G4double pZ56N78[4]={3.E-12, 50 810 static const G4double pZ56N78[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 809 static const std::pair<G4int, const G4double 811 static const std::pair<G4int, const G4double*> Z56N78(78,pZ56N78); 810 static const G4double pZ56N79[4]={3.E-12, 50 812 static const G4double pZ56N79[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 811 static const std::pair<G4int, const G4double 813 static const std::pair<G4int, const G4double*> Z56N79(79,pZ56N79); 812 static const G4double pZ56N80[4]={3.E-12, 50 814 static const G4double pZ56N80[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 813 static const std::pair<G4int, const G4double 815 static const std::pair<G4int, const G4double*> Z56N80(80,pZ56N80); 814 static const G4double pZ56N81[4]={3.E-12, 50 816 static const G4double pZ56N81[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 815 static const std::pair<G4int, const G4double 817 static const std::pair<G4int, const G4double*> Z56N81(81,pZ56N81); 816 static const G4double pZ56N82[4]={3.E-12, 50 818 static const G4double pZ56N82[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 817 static const std::pair<G4int, const G4double 819 static const std::pair<G4int, const G4double*> Z56N82(82,pZ56N82); 818 static const std::pair<G4int, const G4double 820 static const std::pair<G4int, const G4double*> Z56[N56]={Z56N74, Z56N76, Z56N78, Z56N79, 819 821 Z56N80, Z56N81, Z56N82}; 820 //==> La(Z=57) 822 //==> La(Z=57) 821 static const G4int N57=2; 823 static const G4int N57=2; 822 static const G4double pZ57N81[4]={3.E-12, 50 824 static const G4double pZ57N81[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 823 static const std::pair<G4int, const G4double 825 static const std::pair<G4int, const G4double*> Z57N81(81,pZ57N81); 824 static const G4double pZ57N82[4]={3.E-12, 50 826 static const G4double pZ57N82[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 825 static const std::pair<G4int, const G4double 827 static const std::pair<G4int, const G4double*> Z57N82(82,pZ57N82); 826 static const std::pair<G4int, const G4double 828 static const std::pair<G4int, const G4double*> Z57[N57]={Z57N81, Z57N82}; 827 //==> Ce(Z=58) 829 //==> Ce(Z=58) 828 static const G4int N58=4; 830 static const G4int N58=4; 829 static const G4double pZ58N78[4]={3.E-12, 50 831 static const G4double pZ58N78[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 830 static const std::pair<G4int, const G4double 832 static const std::pair<G4int, const G4double*> Z58N78(78,pZ58N78); 831 static const G4double pZ58N80[4]={3.E-12, 50 833 static const G4double pZ58N80[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 832 static const std::pair<G4int, const G4double 834 static const std::pair<G4int, const G4double*> Z58N80(80,pZ58N80); 833 static const G4double pZ58N82[4]={3.E-12, 50 835 static const G4double pZ58N82[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 834 static const std::pair<G4int, const G4double 836 static const std::pair<G4int, const G4double*> Z58N82(82,pZ58N82); 835 static const G4double pZ58N84[4]={3.E-12, 50 837 static const G4double pZ58N84[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 836 static const std::pair<G4int, const G4double 838 static const std::pair<G4int, const G4double*> Z58N84(84,pZ58N84); 837 static const std::pair<G4int, const G4double 839 static const std::pair<G4int, const G4double*> Z58[N58]={Z58N78, Z58N80, Z58N82, Z58N84}; 838 //==> Pr(Z=59) 840 //==> Pr(Z=59) 839 static const G4int N59=1; 841 static const G4int N59=1; 840 static const G4double pZ59N82[4]={3.E-12, 50 842 static const G4double pZ59N82[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 841 static const std::pair<G4int, const G4double 843 static const std::pair<G4int, const G4double*> Z59N82(82,pZ59N82); 842 static const std::pair<G4int, const G4double 844 static const std::pair<G4int, const G4double*> Z59[N59]={Z59N82}; 843 //==> Nd(Z=60) 845 //==> Nd(Z=60) 844 static const G4int N60=7; 846 static const G4int N60=7; 845 static const G4double pZ60N82[4]={3.E-12, 50 847 static const G4double pZ60N82[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 846 static const std::pair<G4int, const G4double 848 static const std::pair<G4int, const G4double*> Z60N82(82,pZ60N82); 847 static const G4double pZ60N83[4]={3.E-12, 50 849 static const G4double pZ60N83[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 848 static const std::pair<G4int, const G4double 850 static const std::pair<G4int, const G4double*> Z60N83(83,pZ60N83); 849 static const G4double pZ60N84[4]={3.E-12, 50 851 static const G4double pZ60N84[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 850 static const std::pair<G4int, const G4double 852 static const std::pair<G4int, const G4double*> Z60N84(84,pZ60N84); 851 static const G4double pZ60N85[4]={3.E-12, 50 853 static const G4double pZ60N85[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 852 static const std::pair<G4int, const G4double 854 static const std::pair<G4int, const G4double*> Z60N85(85,pZ60N85); 853 static const G4double pZ60N86[4]={3.E-12, 50 855 static const G4double pZ60N86[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 854 static const std::pair<G4int, const G4double 856 static const std::pair<G4int, const G4double*> Z60N86(86,pZ60N86); 855 static const G4double pZ60N88[4]={3.E-12, 50 857 static const G4double pZ60N88[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 856 static const std::pair<G4int, const G4double 858 static const std::pair<G4int, const G4double*> Z60N88(88,pZ60N88); 857 static const G4double pZ60N90[4]={3.E-12, 50 859 static const G4double pZ60N90[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 858 static const std::pair<G4int, const G4double 860 static const std::pair<G4int, const G4double*> Z60N90(90,pZ60N90); 859 static const std::pair<G4int, const G4double 861 static const std::pair<G4int, const G4double*> Z60[N60]={Z60N82, Z60N83, Z60N84, Z60N85, 860 862 Z60N86, Z60N88, Z60N90}; 861 //==> Mo(Z=61) 863 //==> Mo(Z=61) 862 static const G4int N61=1; 864 static const G4int N61=1; 863 static const G4double pZ61N0[4]={3.E-12, 500 865 static const G4double pZ61N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 864 static const std::pair<G4int, const G4double 866 static const std::pair<G4int, const G4double*> Z61N0(0,pZ61N0); 865 static const std::pair<G4int, const G4double 867 static const std::pair<G4int, const G4double*> Z61[N61]={Z61N0}; 866 //==> Sm(Z=62) 868 //==> Sm(Z=62) 867 static const G4int N62=7; 869 static const G4int N62=7; 868 static const G4double pZ62N82[4]={3.E-12, 50 870 static const G4double pZ62N82[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 869 static const std::pair<G4int, const G4double 871 static const std::pair<G4int, const G4double*> Z62N82(82,pZ62N82); 870 static const G4double pZ62N85[4]={3.E-12, 50 872 static const G4double pZ62N85[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 871 static const std::pair<G4int, const G4double 873 static const std::pair<G4int, const G4double*> Z62N85(85,pZ62N85); 872 static const G4double pZ62N86[4]={3.E-12, 50 874 static const G4double pZ62N86[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 873 static const std::pair<G4int, const G4double 875 static const std::pair<G4int, const G4double*> Z62N86(86,pZ62N86); 874 static const G4double pZ62N87[4]={3.E-12, 50 876 static const G4double pZ62N87[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 875 static const std::pair<G4int, const G4double 877 static const std::pair<G4int, const G4double*> Z62N87(87,pZ62N87); 876 static const G4double pZ62N88[4]={3.E-12, 50 878 static const G4double pZ62N88[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 877 static const std::pair<G4int, const G4double 879 static const std::pair<G4int, const G4double*> Z62N88(88,pZ62N88); 878 static const G4double pZ62N90[4]={3.E-12, 50 880 static const G4double pZ62N90[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 879 static const std::pair<G4int, const G4double 881 static const std::pair<G4int, const G4double*> Z62N90(90,pZ62N90); 880 static const G4double pZ62N92[4]={3.E-12, 50 882 static const G4double pZ62N92[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 881 static const std::pair<G4int, const G4double 883 static const std::pair<G4int, const G4double*> Z62N92(92,pZ62N92); 882 static const std::pair<G4int, const G4double 884 static const std::pair<G4int, const G4double*> Z62[N62]={Z62N82, Z62N85, Z62N86, Z62N87, 883 885 Z62N88, Z62N90, Z62N92}; 884 //==> Eu(Z=63) 886 //==> Eu(Z=63) 885 static const G4int N63=2; 887 static const G4int N63=2; 886 static const G4double pZ63N88[4]={3.E-12, 50 888 static const G4double pZ63N88[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 887 static const std::pair<G4int, const G4double 889 static const std::pair<G4int, const G4double*> Z63N88(88,pZ63N88); 888 static const G4double pZ63N90[4]={3.E-12, 50 890 static const G4double pZ63N90[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 889 static const std::pair<G4int, const G4double 891 static const std::pair<G4int, const G4double*> Z63N90(90,pZ63N90); 890 static const std::pair<G4int, const G4double 892 static const std::pair<G4int, const G4double*> Z63[N63]={Z63N88, Z63N90}; 891 //==> Gd(Z=64) 893 //==> Gd(Z=64) 892 static const G4int N64=7; 894 static const G4int N64=7; 893 static const G4double pZ64N88[4]={3.E-12, 50 895 static const G4double pZ64N88[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 894 static const std::pair<G4int, const G4double 896 static const std::pair<G4int, const G4double*> Z64N88(88,pZ64N88); 895 static const G4double pZ64N90[4]={3.E-12, 50 897 static const G4double pZ64N90[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 896 static const std::pair<G4int, const G4double 898 static const std::pair<G4int, const G4double*> Z64N90(90,pZ64N90); 897 static const G4double pZ64N91[4]={3.E-12, 50 899 static const G4double pZ64N91[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 898 static const std::pair<G4int, const G4double 900 static const std::pair<G4int, const G4double*> Z64N91(91,pZ64N91); 899 static const G4double pZ64N92[4]={3.E-12, 50 901 static const G4double pZ64N92[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 900 static const std::pair<G4int, const G4double 902 static const std::pair<G4int, const G4double*> Z64N92(92,pZ64N92); 901 static const G4double pZ64N93[4]={3.E-12, 50 903 static const G4double pZ64N93[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 902 static const std::pair<G4int, const G4double 904 static const std::pair<G4int, const G4double*> Z64N93(93,pZ64N93); 903 static const G4double pZ64N94[4]={3.E-12, 50 905 static const G4double pZ64N94[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 904 static const std::pair<G4int, const G4double 906 static const std::pair<G4int, const G4double*> Z64N94(94,pZ64N94); 905 static const G4double pZ64N96[4]={3.E-12, 50 907 static const G4double pZ64N96[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 906 static const std::pair<G4int, const G4double 908 static const std::pair<G4int, const G4double*> Z64N96(96,pZ64N96); 907 static const std::pair<G4int, const G4double 909 static const std::pair<G4int, const G4double*> Z64[N64]={Z64N88, Z64N90, Z64N91, Z64N92, 908 910 Z64N93, Z64N94, Z64N96}; 909 //==> Tb(Z=65) 911 //==> Tb(Z=65) 910 static const G4int N65=1; 912 static const G4int N65=1; 911 static const G4double pZ65N94[4]={3.E-12, 50 913 static const G4double pZ65N94[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 912 static const std::pair<G4int, const G4double 914 static const std::pair<G4int, const G4double*> Z65N94(82,pZ65N94); 913 static const std::pair<G4int, const G4double 915 static const std::pair<G4int, const G4double*> Z65[N65]={Z65N94}; 914 //==> Dy(Z=66) 916 //==> Dy(Z=66) 915 static const G4int N66=7; 917 static const G4int N66=7; 916 static const G4double pZ66N90[4]={3.E-12, 50 918 static const G4double pZ66N90[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 917 static const std::pair<G4int, const G4double 919 static const std::pair<G4int, const G4double*> Z66N90(90,pZ66N90); 918 static const G4double pZ66N92[4]={3.E-12, 50 920 static const G4double pZ66N92[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 919 static const std::pair<G4int, const G4double 921 static const std::pair<G4int, const G4double*> Z66N92(92,pZ66N92); 920 static const G4double pZ66N94[4]={3.E-12, 50 922 static const G4double pZ66N94[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 921 static const std::pair<G4int, const G4double 923 static const std::pair<G4int, const G4double*> Z66N94(94,pZ66N94); 922 static const G4double pZ66N95[4]={3.E-12, 50 924 static const G4double pZ66N95[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 923 static const std::pair<G4int, const G4double 925 static const std::pair<G4int, const G4double*> Z66N95(95,pZ66N95); 924 static const G4double pZ66N96[4]={3.E-12, 50 926 static const G4double pZ66N96[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 925 static const std::pair<G4int, const G4double 927 static const std::pair<G4int, const G4double*> Z66N96(96,pZ66N96); 926 static const G4double pZ66N97[4]={3.E-12, 50 928 static const G4double pZ66N97[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 927 static const std::pair<G4int, const G4double 929 static const std::pair<G4int, const G4double*> Z66N97(97,pZ66N97); 928 static const G4double pZ66N98[4]={3.E-12, 50 930 static const G4double pZ66N98[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 929 static const std::pair<G4int, const G4double 931 static const std::pair<G4int, const G4double*> Z66N98(98,pZ66N98); 930 static const std::pair<G4int, const G4double 932 static const std::pair<G4int, const G4double*> Z66[N66]={Z66N90, Z66N92, Z66N94, Z66N95, 931 933 Z66N96, Z66N97, Z66N98}; 932 //==> Ho(Z=67) 934 //==> Ho(Z=67) 933 static const G4int N67=1; 935 static const G4int N67=1; 934 static const G4double pZ67N98[4]={3.E-12, 50 936 static const G4double pZ67N98[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 935 static const std::pair<G4int, const G4double 937 static const std::pair<G4int, const G4double*> Z67N98(98,pZ67N98); 936 static const std::pair<G4int, const G4double 938 static const std::pair<G4int, const G4double*> Z67[N67]={Z67N98}; 937 //==> Er(Z=68) 939 //==> Er(Z=68) 938 static const G4int N68=6; 940 static const G4int N68=6; 939 static const G4double pZ68N94[4]={3.E-12, 50 941 static const G4double pZ68N94[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 940 static const std::pair<G4int, const G4double 942 static const std::pair<G4int, const G4double*> Z68N94(94,pZ68N94); 941 static const G4double pZ68N96[4]={3.E-12, 50 943 static const G4double pZ68N96[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 942 static const std::pair<G4int, const G4double 944 static const std::pair<G4int, const G4double*> Z68N96(96,pZ68N96); 943 static const G4double pZ68N98[4]={3.E-12, 50 945 static const G4double pZ68N98[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 944 static const std::pair<G4int, const G4double 946 static const std::pair<G4int, const G4double*> Z68N98(98,pZ68N98); 945 static const G4double pZ68N99[4]={3.E-12, 50 947 static const G4double pZ68N99[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 946 static const std::pair<G4int, const G4double 948 static const std::pair<G4int, const G4double*> Z68N99(99,pZ68N99); 947 static const G4double pZ68N100[4]={3.E-12, 5 949 static const G4double pZ68N100[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 948 static const std::pair<G4int, const G4double 950 static const std::pair<G4int, const G4double*> Z68N100(100,pZ68N100); 949 static const G4double pZ68N102[4]={3.E-12, 5 951 static const G4double pZ68N102[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 950 static const std::pair<G4int, const G4double 952 static const std::pair<G4int, const G4double*> Z68N102(102,pZ68N102); 951 static const std::pair<G4int, const G4double 953 static const std::pair<G4int, const G4double*> Z68[N68]={Z68N94, Z68N96, Z68N98, 952 954 Z68N99, Z68N100, Z68N102}; 953 //==> Tm(Z=69) 955 //==> Tm(Z=69) 954 static const G4int N69=1; 956 static const G4int N69=1; 955 static const G4double pZ69N100[4]={3.E-12, 5 957 static const G4double pZ69N100[4]={3.E-12, 500., .01, 2.5E-4}; // *** No DATA *** 956 static const std::pair<G4int, const G4double 958 static const std::pair<G4int, const G4double*> Z69N100(100,pZ69N100); 957 static const std::pair<G4int, const G4double 959 static const std::pair<G4int, const G4double*> Z69[N69]={Z69N100}; 958 //==> Yb(Z=70) 960 //==> Yb(Z=70) 959 static const G4int N70=7; 961 static const G4int N70=7; 960 static const G4double pZ70N98[4]={3.E-12, 50 962 static const G4double pZ70N98[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 961 static const std::pair<G4int, const G4double 963 static const std::pair<G4int, const G4double*> Z70N98(98,pZ70N98); 962 static const G4double pZ70N100[4]={3.E-12, 5 964 static const G4double pZ70N100[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 963 static const std::pair<G4int, const G4double 965 static const std::pair<G4int, const G4double*> Z70N100(100,pZ70N100); 964 static const G4double pZ70N101[4]={3.E-12, 5 966 static const G4double pZ70N101[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 965 static const std::pair<G4int, const G4double 967 static const std::pair<G4int, const G4double*> Z70N101(101,pZ70N101); 966 static const G4double pZ70N102[4]={3.E-12, 5 968 static const G4double pZ70N102[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 967 static const std::pair<G4int, const G4double 969 static const std::pair<G4int, const G4double*> Z70N102(102,pZ70N102); 968 static const G4double pZ70N103[4]={3.E-12, 5 970 static const G4double pZ70N103[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 969 static const std::pair<G4int, const G4double 971 static const std::pair<G4int, const G4double*> Z70N103(103,pZ70N103); 970 static const G4double pZ70N104[4]={3.E-12, 5 972 static const G4double pZ70N104[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 971 static const std::pair<G4int, const G4double 973 static const std::pair<G4int, const G4double*> Z70N104(104,pZ70N104); 972 static const G4double pZ70N106[4]={3.E-12, 5 974 static const G4double pZ70N106[4]={3.E-12, 500., .01, 2.5E-4}; // *** No DATA *** 973 static const std::pair<G4int, const G4double 975 static const std::pair<G4int, const G4double*> Z70N106(106,pZ70N106); 974 static const std::pair<G4int, const G4double 976 static const std::pair<G4int, const G4double*> Z70[N70]={Z70N98, Z70N100, Z70N101, 975 977 Z70N102, Z70N103, Z70N104, 976 978 Z70N106}; 977 //==> Lu(Z=71) 979 //==> Lu(Z=71) 978 static const G4int N71=2; 980 static const G4int N71=2; 979 static const G4double pZ71N104[4]={3.E-12, 5 981 static const G4double pZ71N104[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 980 static const std::pair<G4int, const G4double 982 static const std::pair<G4int, const G4double*> Z71N104(104,pZ71N104); 981 static const G4double pZ71N105[4]={3.E-12, 5 983 static const G4double pZ71N105[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 982 static const std::pair<G4int, const G4double 984 static const std::pair<G4int, const G4double*> Z71N105(105,pZ71N105); 983 static const std::pair<G4int, const G4double 985 static const std::pair<G4int, const G4double*> Z71[N71]={Z71N104, Z71N105}; 984 //==> Hf(Z=72) 986 //==> Hf(Z=72) 985 static const G4int N72=6; 987 static const G4int N72=6; 986 static const G4double pZ72N102[4]={3.E-12, 5 988 static const G4double pZ72N102[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 987 static const std::pair<G4int, const G4double 989 static const std::pair<G4int, const G4double*> Z72N102(102,pZ72N102); 988 static const G4double pZ72N104[4]={3.E-12, 5 990 static const G4double pZ72N104[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 989 static const std::pair<G4int, const G4double 991 static const std::pair<G4int, const G4double*> Z72N104(104,pZ72N104); 990 static const G4double pZ72N105[4]={3.E-12, 5 992 static const G4double pZ72N105[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 991 static const std::pair<G4int, const G4double 993 static const std::pair<G4int, const G4double*> Z72N105(105,pZ72N105); 992 static const G4double pZ72N106[4]={3.E-12, 5 994 static const G4double pZ72N106[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 993 static const std::pair<G4int, const G4double 995 static const std::pair<G4int, const G4double*> Z72N106(106,pZ72N106); 994 static const G4double pZ72N107[4]={3.E-12, 5 996 static const G4double pZ72N107[4]={3.E-12, 500., .01, 2.5E-5}; // *** NotImplemented *** 995 static const std::pair<G4int, const G4double 997 static const std::pair<G4int, const G4double*> Z72N107(107,pZ72N107); 996 static const G4double pZ72N108[4]={3.E-12, 5 998 static const G4double pZ72N108[4]={3.E-12, 500., .01, 2.5E-4}; // *** NotImplemented *** 997 static const std::pair<G4int, const G4double 999 static const std::pair<G4int, const G4double*> Z72N108(108,pZ72N108); 998 static const std::pair<G4int, const G4double 1000 static const std::pair<G4int, const G4double*> Z72[N72]={Z72N102, Z72N104, Z72N105, 999 1001 Z72N106, Z72N107, Z72N108}; 1000 //==> Ta(Z=73) 1002 //==> Ta(Z=73) 1001 static const G4int N73=1; 1003 static const G4int N73=1; 1002 static const G4double pZ73N108[4]={4.E-12, 1004 static const G4double pZ73N108[4]={4.E-12, 1100., .027, 1.E-3}; 1003 static const std::pair<G4int, const G4doubl 1005 static const std::pair<G4int, const G4double*> Z73N108(108,pZ73N108); 1004 static const std::pair<G4int, const G4doubl 1006 static const std::pair<G4int, const G4double*> Z73[N73]={Z73N108}; 1005 //==> W (Z=74) 1007 //==> W (Z=74) 1006 static const G4int N74=5; 1008 static const G4int N74=5; 1007 static const G4double pZ74N106[4]={7.E-12, 1009 static const G4double pZ74N106[4]={7.E-12, 1000., .03, 2.E-4}; // *** No DATA *** 1008 static const std::pair<G4int, const G4doubl 1010 static const std::pair<G4int, const G4double*> Z74N106(106,pZ74N106); 1009 static const G4double pZ74N108[4]={7.E-12, 1011 static const G4double pZ74N108[4]={7.E-12, 1300., .03, 1.5E-4}; 1010 static const std::pair<G4int, const G4doubl 1012 static const std::pair<G4int, const G4double*> Z74N108(108,pZ74N108); 1011 static const G4double pZ74N109[4]={2.E-12, 1013 static const G4double pZ74N109[4]={2.E-12, 1700., .023, 2.E-4}; 1012 static const std::pair<G4int, const G4doubl 1014 static const std::pair<G4int, const G4double*> Z74N109(109,pZ74N109); 1013 static const G4double pZ74N110[4]={7.E-12, 1015 static const G4double pZ74N110[4]={7.E-12, 1100., .03, 1.5E-4}; 1014 static const std::pair<G4int, const G4doubl 1016 static const std::pair<G4int, const G4double*> Z74N110(110,pZ74N110); 1015 static const G4double pZ74N112[4]={7.E-12, 1017 static const G4double pZ74N112[4]={7.E-12, 1100., .03, 1.5E-4}; 1016 static const std::pair<G4int, const G4doubl 1018 static const std::pair<G4int, const G4double*> Z74N112(112,pZ74N112); 1017 static const std::pair<G4int, const G4doubl 1019 static const std::pair<G4int, const G4double*> Z74[N74]={Z74N106, Z74N108, Z74N109, 1018 1020 Z74N110, Z74N112}; 1019 //==> Re(Z=75) 1021 //==> Re(Z=75) 1020 static const G4int N75=2; 1022 static const G4int N75=2; 1021 static const G4double pZ75N110[4]={5.E-12, 1023 static const G4double pZ75N110[4]={5.E-12, 1000., .025, 3.E-4}; 1022 static const std::pair<G4int, const G4doubl 1024 static const std::pair<G4int, const G4double*> Z75N110(110,pZ75N110); 1023 static const G4double pZ75N112[4]={5.E-12, 1025 static const G4double pZ75N112[4]={5.E-12, 1000., .025, 3.E-4}; 1024 static const std::pair<G4int, const G4doubl 1026 static const std::pair<G4int, const G4double*> Z75N112(112,pZ75N112); 1025 static const std::pair<G4int, const G4doubl 1027 static const std::pair<G4int, const G4double*> Z75[N75]={Z75N110, Z75N112}; 1026 //==> Os(Z=76) 1028 //==> Os(Z=76) 1027 static const G4int N76=7; 1029 static const G4int N76=7; 1028 static const G4double pZ76N108[4]={3.E-12, 1030 static const G4double pZ76N108[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1029 static const std::pair<G4int, const G4doubl 1031 static const std::pair<G4int, const G4double*> Z76N108(108,pZ76N108); 1030 static const G4double pZ76N110[4]={3.E-12, 1032 static const G4double pZ76N110[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1031 static const std::pair<G4int, const G4doubl 1033 static const std::pair<G4int, const G4double*> Z76N110(110,pZ76N110); 1032 static const G4double pZ76N111[4]={3.E-12, 1034 static const G4double pZ76N111[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1033 static const std::pair<G4int, const G4doubl 1035 static const std::pair<G4int, const G4double*> Z76N111(111,pZ76N111); 1034 static const G4double pZ76N112[4]={3.E-12, 1036 static const G4double pZ76N112[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1035 static const std::pair<G4int, const G4doubl 1037 static const std::pair<G4int, const G4double*> Z76N112(112,pZ76N112); 1036 static const G4double pZ76N113[4]={3.E-12, 1038 static const G4double pZ76N113[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1037 static const std::pair<G4int, const G4doubl 1039 static const std::pair<G4int, const G4double*> Z76N113(113,pZ76N113); 1038 static const G4double pZ76N114[4]={3.E-12, 1040 static const G4double pZ76N114[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1039 static const std::pair<G4int, const G4doubl 1041 static const std::pair<G4int, const G4double*> Z76N114(114,pZ76N114); 1040 static const G4double pZ76N116[4]={3.E-12, 1042 static const G4double pZ76N116[4]={3.E-12, 500., .01, 2.5E-4}; // *** No DATA *** 1041 static const std::pair<G4int, const G4doubl 1043 static const std::pair<G4int, const G4double*> Z76N116(116,pZ76N116); 1042 static const std::pair<G4int, const G4doubl 1044 static const std::pair<G4int, const G4double*> Z76[N76]={Z76N108, Z76N110, Z76N111, 1043 1045 Z76N112, Z76N113, Z76N114, 1044 1046 Z76N116}; 1045 //==> Ir(Z=77) 1047 //==> Ir(Z=77) 1046 static const G4int N77=2; 1048 static const G4int N77=2; 1047 static const G4double pZ77N114[4]={4.E-12, 1049 static const G4double pZ77N114[4]={4.E-12, 1700., .028, 2.E-4}; 1048 static const std::pair<G4int, const G4doubl 1050 static const std::pair<G4int, const G4double*> Z77N114(114,pZ77N114); 1049 static const G4double pZ77N116[4]={5.E-12, 1051 static const G4double pZ77N116[4]={5.E-12, 1500., .028, 2.E-4}; 1050 static const std::pair<G4int, const G4doubl 1052 static const std::pair<G4int, const G4double*> Z77N116(116,pZ77N116); 1051 static const std::pair<G4int, const G4doubl 1053 static const std::pair<G4int, const G4double*> Z77[N77]={Z77N114, Z77N116}; 1052 //==> Pt(Z=78) 1054 //==> Pt(Z=78) 1053 static const G4int N78=6; 1055 static const G4int N78=6; 1054 static const G4double pZ78N112[4]={3.E-12, 1056 static const G4double pZ78N112[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1055 static const std::pair<G4int, const G4doubl 1057 static const std::pair<G4int, const G4double*> Z78N112(112,pZ78N112); 1056 static const G4double pZ78N114[4]={3.E-12, 1058 static const G4double pZ78N114[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1057 static const std::pair<G4int, const G4doubl 1059 static const std::pair<G4int, const G4double*> Z78N114(114,pZ78N114); 1058 static const G4double pZ78N116[4]={3.E-12, 1060 static const G4double pZ78N116[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1059 static const std::pair<G4int, const G4doubl 1061 static const std::pair<G4int, const G4double*> Z78N116(116,pZ78N116); 1060 static const G4double pZ78N117[4]={3.E-12, 1062 static const G4double pZ78N117[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1061 static const std::pair<G4int, const G4doubl 1063 static const std::pair<G4int, const G4double*> Z78N117(117,pZ78N117); 1062 static const G4double pZ78N118[4]={3.E-12, 1064 static const G4double pZ78N118[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1063 static const std::pair<G4int, const G4doubl 1065 static const std::pair<G4int, const G4double*> Z78N118(118,pZ78N118); 1064 static const G4double pZ78N120[4]={3.E-12, 1066 static const G4double pZ78N120[4]={3.E-12, 500., .01, 2.5E-4}; // *** No DATA *** 1065 static const std::pair<G4int, const G4doubl 1067 static const std::pair<G4int, const G4double*> Z78N120(120,pZ78N120); 1066 static const std::pair<G4int, const G4doubl 1068 static const std::pair<G4int, const G4double*> Z78[N78]={Z78N112, Z78N114, Z78N116, 1067 1069 Z78N117, Z78N118, Z78N120}; 1068 //==> Au(Z=79) 1070 //==> Au(Z=79) 1069 static const G4int N79=1; 1071 static const G4int N79=1; 1070 static const G4double pZ79N118[4]={.2E-9, 1 1072 static const G4double pZ79N118[4]={.2E-9, 1600., .043, 5.E-4}; 1071 static const std::pair<G4int, const G4doubl 1073 static const std::pair<G4int, const G4double*> Z79N118(118,pZ79N118); 1072 static const std::pair<G4int, const G4doubl 1074 static const std::pair<G4int, const G4double*> Z79[N79]={Z79N118}; 1073 //==> Hg(Z=80) 1075 //==> Hg(Z=80) 1074 static const G4int N80=7; 1076 static const G4int N80=7; 1075 static const G4double pZ80N116[4]={6.E-8, 2 1077 static const G4double pZ80N116[4]={6.E-8, 2500., .085, 2.E-3}; 1076 static const std::pair<G4int, const G4doubl 1078 static const std::pair<G4int, const G4double*> Z80N116(116,pZ80N116); 1077 static const G4double pZ80N118[4]={6.E-8, 2 1079 static const G4double pZ80N118[4]={6.E-8, 2500., .083, 1.7E-3}; 1078 static const std::pair<G4int, const G4doubl 1080 static const std::pair<G4int, const G4double*> Z80N118(118,pZ80N118); 1079 static const G4double pZ80N119[4]={6.E-8, 2 1081 static const G4double pZ80N119[4]={6.E-8, 2600., .073, 2.5E-3}; 1080 static const std::pair<G4int, const G4doubl 1082 static const std::pair<G4int, const G4double*> Z80N119(119,pZ80N119); 1081 static const G4double pZ80N120[4]={6.E-8, 2 1083 static const G4double pZ80N120[4]={6.E-8, 2500., .084, 1.7E-3}; 1082 static const std::pair<G4int, const G4doubl 1084 static const std::pair<G4int, const G4double*> Z80N120(120,pZ80N120); 1083 static const G4double pZ80N121[4]={1.5E-7, 1085 static const G4double pZ80N121[4]={1.5E-7, 2600., .078, 4.E-3}; 1084 static const std::pair<G4int, const G4doubl 1086 static const std::pair<G4int, const G4double*> Z80N121(121,pZ80N121); 1085 static const G4double pZ80N122[4]={6.E-8, 2 1087 static const G4double pZ80N122[4]={6.E-8, 2500., .083, 1.6E-3}; 1086 static const std::pair<G4int, const G4doubl 1088 static const std::pair<G4int, const G4double*> Z80N122(122,pZ80N122); 1087 static const G4double pZ80N124[4]={6.E-8, 2 1089 static const G4double pZ80N124[4]={6.E-8, 2500., .083, 1.5E-3}; 1088 static const std::pair<G4int, const G4doubl 1090 static const std::pair<G4int, const G4double*> Z80N124(124,pZ80N124); 1089 static const std::pair<G4int, const G4doubl 1091 static const std::pair<G4int, const G4double*> Z80[N80]={Z80N116, Z80N118, Z80N119, 1090 1092 Z80N120, Z80N121, Z80N122, 1091 1093 Z80N124}; 1092 //==> Tl(Z=81) 1094 //==> Tl(Z=81) 1093 static const G4int N81=2; 1095 static const G4int N81=2; 1094 static const G4double pZ81N122[4]={3.E-12, 1096 static const G4double pZ81N122[4]={3.E-12, 500., .01, 2.5E-5}; // *** No DATA *** 1095 static const std::pair<G4int, const G4doubl 1097 static const std::pair<G4int, const G4double*> Z81N122(122,pZ81N122); 1096 static const G4double pZ81N124[4]={3.E-12, 1098 static const G4double pZ81N124[4]={3.E-12, 500., .01, 2.5E-4}; // *** No DATA *** 1097 static const std::pair<G4int, const G4doubl 1099 static const std::pair<G4int, const G4double*> Z81N124(124,pZ81N124); 1098 static const std::pair<G4int, const G4doubl 1100 static const std::pair<G4int, const G4double*> Z81[N81]={Z81N122, Z81N124}; 1099 //==> Pb(Z=82) 1101 //==> Pb(Z=82) 1100 static const G4int N82=4; 1102 static const G4int N82=4; 1101 static const G4double pZ82N122[4]={.2E-9, 4 1103 static const G4double pZ82N122[4]={.2E-9, 40., .002, 6.E-4}; 1102 static const std::pair<G4int, const G4doubl 1104 static const std::pair<G4int, const G4double*> Z82N122(122,pZ82N122); 1103 static const G4double pZ82N124[4]={6.E-9, 1 1105 static const G4double pZ82N124[4]={6.E-9, 1700., .076, 7.E-4}; 1104 static const std::pair<G4int, const G4doubl 1106 static const std::pair<G4int, const G4double*> Z82N124(124,pZ82N124); 1105 static const G4double pZ82N125[4]={.2E-9, 7 1107 static const G4double pZ82N125[4]={.2E-9, 770., .057, 4.5E-4}; 1106 static const std::pair<G4int, const G4doubl 1108 static const std::pair<G4int, const G4double*> Z82N125(125,pZ82N125); 1107 static const G4double pZ82N126[4]={4.E-9, 0 1109 static const G4double pZ82N126[4]={4.E-9, 0., .051, 2.E-4}; 1108 static const std::pair<G4int, const G4doubl 1110 static const std::pair<G4int, const G4double*> Z82N126(126,pZ82N126); 1109 static const std::pair<G4int, const G4doubl 1111 static const std::pair<G4int, const G4double*> Z82[N82]={Z82N122, Z82N124, Z82N125, 1110 1112 Z82N126}; 1111 //==> Bi(Z=83) 1113 //==> Bi(Z=83) 1112 static const G4int N83=1; 1114 static const G4int N83=1; 1113 static const G4double pZ83N126[4]={1.5E-9, 1115 static const G4double pZ83N126[4]={1.5E-9, 150., .052, 5.E-5}; 1114 static const std::pair<G4int, const G4doubl 1116 static const std::pair<G4int, const G4double*> Z83N126(126,pZ83N126); 1115 static const std::pair<G4int, const G4doubl 1117 static const std::pair<G4int, const G4double*> Z83[N83]={Z83N126}; 1116 //==> Po(Z=84) 1118 //==> Po(Z=84) 1117 static const G4int N84=1; 1119 static const G4int N84=1; 1118 static const G4double pZ84N0[4]={3.E-12, 50 1120 static const G4double pZ84N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1119 static const std::pair<G4int, const G4doubl 1121 static const std::pair<G4int, const G4double*> Z84N0(0,pZ84N0); 1120 static const std::pair<G4int, const G4doubl 1122 static const std::pair<G4int, const G4double*> Z84[N84]={Z84N0}; 1121 //==> At(Z=85) 1123 //==> At(Z=85) 1122 static const G4int N85=1; 1124 static const G4int N85=1; 1123 static const G4double pZ85N0[4]={3.E-12, 50 1125 static const G4double pZ85N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1124 static const std::pair<G4int, const G4doubl 1126 static const std::pair<G4int, const G4double*> Z85N0(0,pZ85N0); 1125 static const std::pair<G4int, const G4doubl 1127 static const std::pair<G4int, const G4double*> Z85[N85]={Z85N0}; 1126 //==> Rn(Z=86) 1128 //==> Rn(Z=86) 1127 static const G4int N86=1; 1129 static const G4int N86=1; 1128 static const G4double pZ86N0[4]={3.E-12, 50 1130 static const G4double pZ86N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1129 static const std::pair<G4int, const G4doubl 1131 static const std::pair<G4int, const G4double*> Z86N0(0,pZ86N0); 1130 static const std::pair<G4int, const G4doubl 1132 static const std::pair<G4int, const G4double*> Z86[N86]={Z86N0}; 1131 //==> Fr(Z=87) 1133 //==> Fr(Z=87) 1132 static const G4int N87=1; 1134 static const G4int N87=1; 1133 static const G4double pZ87N0[4]={3.E-12, 50 1135 static const G4double pZ87N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1134 static const std::pair<G4int, const G4doubl 1136 static const std::pair<G4int, const G4double*> Z87N0(0,pZ87N0); 1135 static const std::pair<G4int, const G4doubl 1137 static const std::pair<G4int, const G4double*> Z87[N87]={Z87N0}; 1136 //==> Ra(Z=88) 1138 //==> Ra(Z=88) 1137 static const G4int N88=1; 1139 static const G4int N88=1; 1138 static const G4double pZ88N138[4]={3.E-9, 2 1140 static const G4double pZ88N138[4]={3.E-9, 2200., .057, 1.2E-3}; 1139 static const std::pair<G4int, const G4doubl 1141 static const std::pair<G4int, const G4double*> Z88N138(138,pZ88N138); 1140 static const std::pair<G4int, const G4doubl 1142 static const std::pair<G4int, const G4double*> Z88[N88]={Z88N138}; 1141 //==> Ac(Z=89) 1143 //==> Ac(Z=89) 1142 static const G4int N89=1; 1144 static const G4int N89=1; 1143 static const G4double pZ89N0[4]={3.E-12, 50 1145 static const G4double pZ89N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1144 static const std::pair<G4int, const G4doubl 1146 static const std::pair<G4int, const G4double*> Z89N0(0,pZ89N0); 1145 static const std::pair<G4int, const G4doubl 1147 static const std::pair<G4int, const G4double*> Z89[N89]={Z89N0}; 1146 //==> Th(Z=90) 1148 //==> Th(Z=90) 1147 static const G4int N90=1; 1149 static const G4int N90=1; 1148 static const G4double pZ90N142[4]={1.E-11, 1150 static const G4double pZ90N142[4]={1.E-11, 1200., .028, 3.E-4}; 1149 static const std::pair<G4int, const G4doubl 1151 static const std::pair<G4int, const G4double*> Z90N142(142,pZ90N142); 1150 static const std::pair<G4int, const G4doubl 1152 static const std::pair<G4int, const G4double*> Z90[N90]={Z90N142}; 1151 //==> Pa(Z=91) 1153 //==> Pa(Z=91) 1152 static const G4int N91=1; 1154 static const G4int N91=1; 1153 static const G4double pZ91N0[4]={3.E-12, 50 1155 static const G4double pZ91N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1154 static const std::pair<G4int, const G4doubl 1156 static const std::pair<G4int, const G4double*> Z91N0(0,pZ91N0); 1155 static const std::pair<G4int, const G4doubl 1157 static const std::pair<G4int, const G4double*> Z91[N91]={Z91N0}; 1156 //==> U (Z=92) 1158 //==> U (Z=92) 1157 static const G4int N92=2; 1159 static const G4int N92=2; 1158 static const G4double pZ92N143[4]={2.E-11, 1160 static const G4double pZ92N143[4]={2.E-11, 2700., .026, 6.E-4}; 1159 static const std::pair<G4int, const G4doubl 1161 static const std::pair<G4int, const G4double*> Z92N143(143,pZ92N143); 1160 static const G4double pZ92N146[4]={1.E-11, 1162 static const G4double pZ92N146[4]={1.E-11, 1700., .029, 2.5E-4}; 1161 static const std::pair<G4int, const G4doubl 1163 static const std::pair<G4int, const G4double*> Z92N146(146,pZ92N146); 1162 static const std::pair<G4int, const G4doubl 1164 static const std::pair<G4int, const G4double*> Z92[N92]={Z92N143, Z92N146}; 1163 //==> Np(Z=93) 1165 //==> Np(Z=93) 1164 static const G4int N93=1; 1166 static const G4int N93=1; 1165 static const G4double pZ93N144[4]={4.E-8, 3 1167 static const G4double pZ93N144[4]={4.E-8, 3700., .066, 3.5E-3}; 1166 static const std::pair<G4int, const G4doubl 1168 static const std::pair<G4int, const G4double*> Z93N144(144,pZ93N144); 1167 static const std::pair<G4int, const G4doubl 1169 static const std::pair<G4int, const G4double*> Z93[N93]={Z93N144}; 1168 //==> Pu(Z=94) 1170 //==> Pu(Z=94) 1169 static const G4int N94=3; 1171 static const G4int N94=3; 1170 static const G4double pZ94N145[4]={8.E-11, 1172 static const G4double pZ94N145[4]={8.E-11, 2900., .029, 1.3E-3}; // *** Artificial *** 1171 static const std::pair<G4int, const G4doubl 1173 static const std::pair<G4int, const G4double*> Z94N145(145,pZ94N145); 1172 static const G4double pZ94N148[4]={9.E-12, 1174 static const G4double pZ94N148[4]={9.E-12, 1400., .025, 3.E-4}; // *** Artificial *** 1173 static const std::pair<G4int, const G4doubl 1175 static const std::pair<G4int, const G4double*> Z94N148(148,pZ94N148); 1174 static const G4double pZ94N150[4]={4.E-12, 1176 static const G4double pZ94N150[4]={4.E-12, 1500., .023, 1.2E-4}; 1175 static const std::pair<G4int, const G4doubl 1177 static const std::pair<G4int, const G4double*> Z94N150(150,pZ94N150); 1176 static const std::pair<G4int, const G4doubl 1178 static const std::pair<G4int, const G4double*> Z94[N94]={Z94N145, Z94N148, Z94N150}; 1177 //==> Am(Z=95) 1179 //==> Am(Z=95) 1178 static const G4int N95=1; 1180 static const G4int N95=1; 1179 static const G4double pZ95N0[4]={3.E-12, 50 1181 static const G4double pZ95N0[4]={3.E-12, 500., .01, 2.5E-4}; // *** NoStableIsotopes *** 1180 static const std::pair<G4int, const G4doubl 1182 static const std::pair<G4int, const G4double*> Z95N0(0,pZ95N0); 1181 static const std::pair<G4int, const G4doubl 1183 static const std::pair<G4int, const G4double*> Z95[N95]={Z95N0}; 1182 //==> Cm(Z=96) 1184 //==> Cm(Z=96) 1183 static const G4int N96=1; 1185 static const G4int N96=1; 1184 static const G4double pZ96N151[4]={1.5E-8, 1186 static const G4double pZ96N151[4]={1.5E-8, 3700., .055, 2.E-3}; 1185 static const std::pair<G4int, const G4doubl 1187 static const std::pair<G4int, const G4double*> Z96N151(151,pZ96N151); 1186 static const std::pair<G4int, const G4doubl 1188 static const std::pair<G4int, const G4double*> Z96[N96]={Z96N151}; 1187 1189 1188 static const G4int NZ=97; // #of Elements c 1190 static const G4int NZ=97; // #of Elements covered by CHIPS 1189 static const std::pair<G4int, const G4doubl 1191 static const std::pair<G4int, const G4double*>* Pars[NZ]={Z0,Z1,Z2,Z3,Z4,Z5,Z6,Z7,Z8,Z9, 1190 Z10,Z11,Z12,Z13,Z14,Z15,Z16,Z17,Z18,Z19,Z 1192 Z10,Z11,Z12,Z13,Z14,Z15,Z16,Z17,Z18,Z19,Z20,Z21,Z22,Z23,Z24,Z25,Z26,Z27,Z28,Z29,Z30, 1191 Z31,Z32,Z33,Z34,Z35,Z36,Z37,Z38,Z39,Z40,Z 1193 Z31,Z32,Z33,Z34,Z35,Z36,Z37,Z38,Z39,Z40,Z41,Z42,Z43,Z44,Z45,Z46,Z47,Z48,Z49,Z50,Z51, 1192 Z52,Z53,Z54,Z55,Z56,Z57,Z58,Z59,Z60,Z61,Z 1194 Z52,Z53,Z54,Z55,Z56,Z57,Z58,Z59,Z60,Z61,Z62,Z63,Z64,Z65,Z66,Z67,Z68,Z69,Z70,Z71,Z72, 1193 Z73,Z74,Z75,Z76,Z77,Z78,Z79,Z80,Z81,Z82,Z 1195 Z73,Z74,Z75,Z76,Z77,Z78,Z79,Z80,Z81,Z82,Z83,Z84,Z85,Z86,Z87,Z88,Z89,Z90,Z91,Z92,Z93, 1194 Z94,Z95,Z96}; 1196 Z94,Z95,Z96}; 1195 static const G4int NIso[NZ]={N0,N1,N2,N3,N4 1197 static const G4int NIso[NZ]={N0,N1,N2,N3,N4,N5,N6,N7,N8,N9,N10,N11,N12,N13,N14,N15,N16, 1196 N17,N18,N19,N20,N21,N22,N23,N24,N25,N26,N 1198 N17,N18,N19,N20,N21,N22,N23,N24,N25,N26,N27,N28,N29,N30,N31,N32,N33,N34,N35,N36,N37, 1197 N38,N39,N40,N41,N42,N43,N44,N45,N46,N47,N 1199 N38,N39,N40,N41,N42,N43,N44,N45,N46,N47,N48,N49,N50,N51,N52,N53,N54,N55,N56,N57,N58, 1198 N59,N60,N61,N62,N63,N64,N65,N66,N67,N68,N 1200 N59,N60,N61,N62,N63,N64,N65,N66,N67,N68,N69,N70,N71,N72,N73,N74,N75,N76,N77,N78,N79, 1199 N80,N81,N82,N83,N84,N85,N86,N87,N88,N89,N 1201 N80,N81,N82,N83,N84,N85,N86,N87,N88,N89,N90,N91,N92,N93,N94,N95,N96}; 1200 //G4int curN=Pars[1][0].first; 1202 //G4int curN=Pars[1][0].first; 1201 //G4double par=Pars[1][0].second[1]; 1203 //G4double par=Pars[1][0].second[1]; 1202 //G4cout<<"-Warning-G4ChipsNeutronInelastic 1204 //G4cout<<"-Warning-G4ChipsNeutronInelasticXS::CSLin: N="<<curN<<", P="<<par<<G4endl; 1203 G4double sigma=0.; 1205 G4double sigma=0.; 1204 G4double lP=G4Log(P); << 1206 G4double lP=std::log(P); 1205 if( (tZ==1 && !tN) || (!tZ && tN==1)){if(P> 1207 if( (tZ==1 && !tN) || (!tZ && tN==1)){if(P>.35) sigma=CrossSectionFormula(tZ,tN,P,lP);} 1206 else if(tZ<97 && tN<152) // 1208 else if(tZ<97 && tN<152) // General solution (*** Z/A limits ***) 1207 { 1209 { 1208 HEthresh=1.E-4; // Default guess 1210 HEthresh=1.E-4; // Default guess 1209 G4double pex=0.; 1211 G4double pex=0.; 1210 G4double pos=0.; 1212 G4double pos=0.; 1211 G4double wid=1.; 1213 G4double wid=1.; 1212 G4int nn=NIso[tZ]; 1214 G4int nn=NIso[tZ]; 1213 G4bool nfound=true; 1215 G4bool nfound=true; 1214 if(nn) for (G4int in=0; in<nn; in++) 1216 if(nn) for (G4int in=0; in<nn; in++) 1215 { 1217 { 1216 std::pair<G4int, const G4double*> curIs 1218 std::pair<G4int, const G4double*> curIs=Pars[tZ][in]; 1217 if(curIs.first == tN) 1219 if(curIs.first == tN) 1218 { 1220 { 1219 const G4double* curT=curIs.second; 1221 const G4double* curT=curIs.second; 1220 HEthresh= curT[0]; 1222 HEthresh= curT[0]; 1221 pex = curT[1]; 1223 pex = curT[1]; 1222 pos = curT[2]; 1224 pos = curT[2]; 1223 wid = curT[3]; 1225 wid = curT[3]; 1224 nfound = false; 1226 nfound = false; 1225 break; 1227 break; 1226 } 1228 } 1227 } 1229 } 1228 if(nfound) G4cout<<"-Warning-G4ChipsNeutr 1230 if(nfound) G4cout<<"-Warning-G4ChipsNeutronInelasticXS::CSLin: Z="<<tZ<<", N=" 1229 <<tN<<" isotope is not i 1231 <<tN<<" isotope is not implemented in CHIPS"<<G4endl; 1230 sigma=CrossSectionFormula(tZ,tN,P,lP); 1232 sigma=CrossSectionFormula(tZ,tN,P,lP); 1231 if(pex>0.) 1233 if(pex>0.) 1232 { 1234 { 1233 G4double dp=P-pos; 1235 G4double dp=P-pos; 1234 sigma+=pex*G4Exp(-dp*dp/wid); << 1236 sigma+=pex*std::exp(-dp*dp/wid); 1235 } 1237 } 1236 } 1238 } 1237 else 1239 else 1238 { 1240 { 1239 G4cerr<<"-Warning-G4ChipsNeutronNuclearCr 1241 G4cerr<<"-Warning-G4ChipsNeutronNuclearCroSect::CSLin:*Bad A* Z="<<tZ<<", N="<<tN<<G4endl; 1240 sigma=0.; 1242 sigma=0.; 1241 } 1243 } 1242 if(sigma<0.) return 0.; 1244 if(sigma<0.) return 0.; 1243 return sigma; 1245 return sigma; 1244 } 1246 } 1245 1247 1246 // Calculation formula for proton-nuclear ine 1248 // Calculation formula for proton-nuclear inelastic cross-section (mb) log(P in GeV/c) 1247 G4double G4ChipsNeutronInelasticXS::CrossSect 1249 G4double G4ChipsNeutronInelasticXS::CrossSectionLog(G4int tZ, G4int tN, G4double lP) 1248 { 1250 { 1249 G4double P=G4Exp(lP); << 1251 G4double P=std::exp(lP); 1250 return CrossSectionFormula(tZ, tN, P, lP); 1252 return CrossSectionFormula(tZ, tN, P, lP); 1251 } 1253 } 1252 // Calculation formula for proton-nuclear ine 1254 // Calculation formula for proton-nuclear inelastic cross-section (mb) log(P in GeV/c) 1253 G4double G4ChipsNeutronInelasticXS::CrossSect 1255 G4double G4ChipsNeutronInelasticXS::CrossSectionFormula(G4int tZ, G4int tN, 1254 1256 G4double P, G4double lP) 1255 { 1257 { 1256 G4double sigma=0.; 1258 G4double sigma=0.; 1257 if(tZ==1 && !tN) // 1259 if(tZ==1 && !tN) // np interaction from G4QuasiElasticRatios 1258 { 1260 { 1259 1261 1260 G4double El(0.), To(0.); // 1262 G4double El(0.), To(0.); // Uzhi 1261 if(P<0.1) // 1263 if(P<0.1) // Copied from G4QuasiElasticRatios Uzhi / start 1262 { 1264 { 1263 G4double p2=P*P; 1265 G4double p2=P*P; 1264 El=1./(0.00012+p2*(0.051+0.1*p2)); 1266 El=1./(0.00012+p2*(0.051+0.1*p2)); 1265 To=El; 1267 To=El; 1266 } 1268 } 1267 else if(P>1000.) 1269 else if(P>1000.) 1268 { 1270 { 1269 G4double lp=G4Log(P)-3.5; << 1271 G4double lp=std::log(P)-3.5; 1270 G4double lp2=lp*lp; 1272 G4double lp2=lp*lp; 1271 El=0.0557*lp2+6.72; 1273 El=0.0557*lp2+6.72; 1272 To=0.3 *lp2+38.2; 1274 To=0.3 *lp2+38.2; 1273 } 1275 } 1274 else 1276 else 1275 { 1277 { 1276 G4double p2=P*P; 1278 G4double p2=P*P; 1277 G4double LE=1./(0.00012+p2*(0.051+0.1*p 1279 G4double LE=1./(0.00012+p2*(0.051+0.1*p2)); 1278 G4double lp=G4Log(P)-3.5; << 1280 G4double lp=std::log(P)-3.5; 1279 G4double lp2=lp*lp; 1281 G4double lp2=lp*lp; 1280 G4double rp2=1./p2; 1282 G4double rp2=1./p2; 1281 El=LE+(0.0557*lp2+6.72+30./P)/(1.+0.49* 1283 El=LE+(0.0557*lp2+6.72+30./P)/(1.+0.49*rp2/P); 1282 To=LE+(0.3 *lp2+38.2)/(1.+0.54*rp2*rp 1284 To=LE+(0.3 *lp2+38.2)/(1.+0.54*rp2*rp2); 1283 } // Co 1285 } // Copied from G4QuasiElasticRatios Uzhi / end 1284 1286 1285 /* 1287 /* // Uzhi 4.03.2013 1286 G4double p2=P*P; 1288 G4double p2=P*P; 1287 G4double lp=lP-3.5; 1289 G4double lp=lP-3.5; 1288 G4double lp2=lp*lp; 1290 G4double lp2=lp*lp; 1289 G4double rp2=1./p2; 1291 G4double rp2=1./p2; 1290 G4double El=(.0557*lp2+6.72+32.6/P)/(1.+r 1292 G4double El=(.0557*lp2+6.72+32.6/P)/(1.+rp2/P); 1291 G4double To=(.3*lp2+38.2+52.7*rp2)/(1.+2. 1293 G4double To=(.3*lp2+38.2+52.7*rp2)/(1.+2.72*rp2*rp2); 1292 */ 1294 */ // Uzhi 4.03.2013 1293 sigma=To-El; 1295 sigma=To-El; 1294 } 1296 } 1295 else if(tZ<97 && tN<152) // 1297 else if(tZ<97 && tN<152) // General solution 1296 { 1298 { 1297 //G4double lP=G4Log(P); // Alr << 1299 //G4double lP=std::log(P); // Already calculated 1298 G4double d=lP-4.2; // 1300 G4double d=lP-4.2; // 1299 G4double p2=P*P; // 1301 G4double p2=P*P; // 1300 G4double p4=p2*p2; // 1302 G4double p4=p2*p2; // 1301 G4double a=tN+tZ; // 1303 G4double a=tN+tZ; // A of the target 1302 G4double al=G4Log(a); // << 1304 G4double al=std::log(a); // 1303 G4double sa=std::sqrt(a); // 1305 G4double sa=std::sqrt(a); // 1304 G4double a2=a*a; // 1306 G4double a2=a*a; // 1305 G4double sa2=sa*a2; // 1307 G4double sa2=sa*a2; // 1306 G4double a3=a2*a; // 1308 G4double a3=a2*a; // 1307 G4double a4=a2*a2; // 1309 G4double a4=a2*a2; // 1308 //G4double a5=a4*a; 1310 //G4double a5=a4*a; 1309 G4double a6=a4*a2; // 1311 G4double a6=a4*a2; // 1310 G4double a7=a6*a; // 1312 G4double a7=a6*a; // 1311 G4double a8=a4*a4; // 1313 G4double a8=a4*a4; // 1312 //G4double a12=a8*a4; 1314 //G4double a12=a8*a4; 1313 //G4double a16=a8*a8; 1315 //G4double a16=a8*a8; 1314 G4double c=(170.+3600./sa2)/(1.+65./sa2); 1316 G4double c=(170.+3600./sa2)/(1.+65./sa2); 1315 G4double dl=al-3.; 1317 G4double dl=al-3.; 1316 G4double dl2=dl*dl; 1318 G4double dl2=dl*dl; 1317 G4double r=.21+.62*dl2/(1.+.5*dl2); 1319 G4double r=.21+.62*dl2/(1.+.5*dl2); 1318 G4double gg=42.*(G4Exp(al*0.8)+4.E-8*a4)/ << 1320 G4double gg=42.*(std::exp(al*0.8)+4.E-8*a4)/(1.+28./a)/(1.+5.E-5*a2); 1319 G4double e=5.*((a6+.021*a8)/(1.+.0013*a7) 1321 G4double e=5.*((a6+.021*a8)/(1.+.0013*a7)+.001*a3)/(1.+.0007*a2); 1320 G4double ss=5./(1.+144./a8); 1322 G4double ss=5./(1.+144./a8); 1321 G4double h=HEthresh; // Individual 1323 G4double h=HEthresh; // Individual 1322 1324 1323 //G4double h=(.01/a4+2.5e-6/a)*(1.+7.e-8* 1325 //G4double h=(.01/a4+2.5e-6/a)*(1.+7.e-8*a4)/(1.+6.e7/a12/a2); 1324 //sigma=(c+d*d)/(1.+r/p4)+(gg+e*G4Exp(-ss << 1326 //sigma=(c+d*d)/(1.+r/p4)+(gg+e*std::exp(-ss*P))/(1.+h/p4/p4); 1325 sigma=(c+d*d)/(1+r/p4)+(gg+e*G4Exp(-ss*P) << 1327 sigma=(c+d*d)/(1+r/p4)+(gg+e*std::exp(-ss*P))/(1+h/p4/p4); 1326 } 1328 } 1327 else 1329 else 1328 { 1330 { 1329 G4cerr<<"-Warning-G4ChipsNeutronNuclearCr 1331 G4cerr<<"-Warning-G4ChipsNeutronNuclearCroSect::CSForm:*Bad A* Z="<<tZ<<", N="<<tN<<G4endl; 1330 sigma=0.; 1332 sigma=0.; 1331 } 1333 } 1332 if(sigma<0.) return 0.; 1334 if(sigma<0.) return 0.; 1333 return sigma; 1335 return sigma; 1334 } 1336 } 1335 1337 1336 G4double G4ChipsNeutronInelasticXS::EquLinear 1338 G4double G4ChipsNeutronInelasticXS::EquLinearFit(G4double X, G4int N, G4double X0, G4double DX, G4double* Y) 1337 { 1339 { 1338 if(DX<=0. || N<2) 1340 if(DX<=0. || N<2) 1339 { 1341 { 1340 G4cerr<<"***G4ChipsNeutronInelasticXS:: 1342 G4cerr<<"***G4ChipsNeutronInelasticXS::EquLinearFit: DX="<<DX<<", N="<<N<<G4endl; 1341 return Y[0]; 1343 return Y[0]; 1342 } 1344 } 1343 1345 1344 G4int N2=N-2; 1346 G4int N2=N-2; 1345 G4double d=(X-X0)/DX; 1347 G4double d=(X-X0)/DX; 1346 G4int jj=static_cast<int>(d); << 1348 G4int j=static_cast<int>(d); 1347 if (jj<0) jj=0; << 1349 if (j<0) j=0; 1348 else if(jj>N2) jj=N2; << 1350 else if(j>N2) j=N2; 1349 d-=jj; // excess << 1351 d-=j; // excess 1350 G4double yi=Y[jj]; << 1352 G4double yi=Y[j]; 1351 G4double sigma=yi+(Y[jj+1]-yi)*d; << 1353 G4double sigma=yi+(Y[j+1]-yi)*d; 1352 1354 1353 return sigma; 1355 return sigma; 1354 } 1356 } 1355 1357