Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/processes/electromagnetic/lowenergy/src/G4RayleighAngularGenerator.cc

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

Diff markup

Differences between /processes/electromagnetic/lowenergy/src/G4RayleighAngularGenerator.cc (Version 11.3.0) and /processes/electromagnetic/lowenergy/src/G4RayleighAngularGenerator.cc (Version 10.7.p4)


  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 // -------------------------------------------     27 // -------------------------------------------------------------------
 28 //                                                 28 //
 29 // GEANT4 Class file                               29 // GEANT4 Class file
 30 //                                                 30 //
 31 // File name:     G4RayleighAngularGenerator       31 // File name:     G4RayleighAngularGenerator
 32 //                                                 32 //
 33 // Author:        V. Ivanchenko using design o     33 // Author:        V. Ivanchenko using design of existing 
 34 //                interface                        34 //                interface 
 35 //                                                 35 // 
 36 // Creation date: 31 May 2012                      36 // Creation date: 31 May 2012
 37 //                                                 37 //
 38 // Modifications:                                  38 // Modifications: 
 39 //                                                 39 //
 40 // Class Description: Class are tabulated data     40 // Class Description: Class are tabulated data according modified formula
 41 //                    modified fit formulas fr     41 //                    modified fit formulas from Dermott E. Cullen, 
 42 //                    Nucl. Instrum. Meth. Phy     42 //                    Nucl. Instrum. Meth. Phys. Res. B v.101, (4),499-510. 
 43 //                                                 43 //                    
 44 //                                                 44 //
 45 // Class for Rayleigh scattering generation        45 // Class for Rayleigh scattering generation
 46 //                                                 46 //
 47 // Class Description: End                          47 // Class Description: End 
                                                   >>  48 
 48 // -------------------------------------------     49 // -------------------------------------------------------------------
 49 //                                                 50 //
 50 //                                                 51 //    
 51                                                    52 
 52 #include "G4RayleighAngularGenerator.hh"           53 #include "G4RayleighAngularGenerator.hh"
 53 #include "G4PhysicalConstants.hh"                  54 #include "G4PhysicalConstants.hh"
 54 #include "G4SystemOfUnits.hh"                      55 #include "G4SystemOfUnits.hh"
 55 #include "Randomize.hh"                            56 #include "Randomize.hh"
 56 #include "G4Log.hh"                                57 #include "G4Log.hh"
 57 #include "G4Exp.hh"                                58 #include "G4Exp.hh"
 58                                                    59 
 59 using namespace std;                               60 using namespace std;
 60                                                    61 
 61 //....oooOO0OOooo........oooOO0OOooo........oo     62 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 62                                                    63 
 63 G4RayleighAngularGenerator::G4RayleighAngularG     64 G4RayleighAngularGenerator::G4RayleighAngularGenerator()
 64   : G4VEmAngularDistribution("CullenGenerator"     65   : G4VEmAngularDistribution("CullenGenerator")
 65 {                                                  66 {
 66   G4double x = cm/(h_Planck*c_light);              67   G4double x = cm/(h_Planck*c_light);
 67   fFactor = 0.5*x*x;                               68   fFactor = 0.5*x*x;
 68 }                                                  69 }
 69                                                    70 
 70 //....oooOO0OOooo........oooOO0OOooo........oo     71 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
 71                                                    72 
 72 G4RayleighAngularGenerator::~G4RayleighAngular     73 G4RayleighAngularGenerator::~G4RayleighAngularGenerator() 
 73 {}                                                 74 {}
 74                                                    75 
 75 //....oooOO0OOooo........oooOO0OOooo........oo     76 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo.... ....oooOO0OOooo....
 76                                                    77 
 77 G4ThreeVector&                                     78 G4ThreeVector& 
 78 G4RayleighAngularGenerator::SampleDirection(co     79 G4RayleighAngularGenerator::SampleDirection(const G4DynamicParticle* dp,
 79               G4double, G4int Z,                   80               G4double, G4int Z,
 80               const G4Material*)                   81               const G4Material*)
 81 {                                                  82 {
 82   G4double ekin = dp->GetKineticEnergy();          83   G4double ekin = dp->GetKineticEnergy();
 83   G4double xx = fFactor*ekin*ekin;                 84   G4double xx = fFactor*ekin*ekin;
 84                                                    85 
 85   G4double n0 = PP6[Z] - 1.0;                      86   G4double n0 = PP6[Z] - 1.0;
 86   G4double n1 = PP7[Z] - 1.0;                      87   G4double n1 = PP7[Z] - 1.0;
 87   G4double n2 = PP8[Z] - 1.0;                      88   G4double n2 = PP8[Z] - 1.0;
 88   G4double b0 = PP3[Z];                            89   G4double b0 = PP3[Z];
 89   G4double b1 = PP4[Z];                            90   G4double b1 = PP4[Z];
 90   G4double b2 = PP5[Z];                            91   G4double b2 = PP5[Z];
 91                                                    92 
 92   static const G4double numlim = 0.02;             93   static const G4double numlim = 0.02;
 93   G4double x  = 2.*xx*b0;                          94   G4double x  = 2.*xx*b0;
 94   G4double w0 = (x < numlim) ? n0*x*(1.0 - 0.5     95   G4double w0 = (x < numlim) ? n0*x*(1.0 - 0.5*(n0 - 1.0)*x*(1.0 - (n0 - 2.0)*x/3.))
 95     : 1.0 - G4Exp(-n0*G4Log(1.0 + x));             96     : 1.0 - G4Exp(-n0*G4Log(1.0 + x)); 
 96                                                    97 
 97   x  = 2.*xx*b1;                                   98   x  = 2.*xx*b1;
 98   G4double w1 = (x < numlim) ? n1*x*(1.0 - 0.5     99   G4double w1 = (x < numlim) ? n1*x*(1.0 - 0.5*(n1 - 1.0)*x*(1.0 - (n1 - 2.0)*x/3.))
 99     : 1.0 - G4Exp(-n1*G4Log(1.0 + x));            100     : 1.0 - G4Exp(-n1*G4Log(1.0 + x));
100                                                   101  
101   x  = 2.*xx*b2;                                  102   x  = 2.*xx*b2;
102   G4double w2 = (x < numlim) ? n2*x*(1.0 - 0.5    103   G4double w2 = (x < numlim) ? n2*x*(1.0 - 0.5*(n2 - 1.0)*x*(1.0 - (n2 - 2.0)*x/3.))
103     : 1.0 - G4Exp(-n2*G4Log(1.0 + x));            104     : 1.0 - G4Exp(-n2*G4Log(1.0 + x));
104                                                   105 
105   G4double x0= w0*PP0[Z]/(b0*n0);                 106   G4double x0= w0*PP0[Z]/(b0*n0);
106   G4double x1= w1*PP1[Z]/(b1*n1);                 107   G4double x1= w1*PP1[Z]/(b1*n1);
107   G4double x2= w2*PP2[Z]/(b2*n2);                 108   G4double x2= w2*PP2[Z]/(b2*n2);
108                                                   109 
109   G4double cost;                                  110   G4double cost;
110   do {                                            111   do {
                                                   >> 112 
111     G4double w = w0;                              113     G4double w = w0;
112     G4double n = n0;                              114     G4double n = n0;
113     G4double b = b0;                              115     G4double b = b0;
114                                                   116   
115     x = G4UniformRand()*(x0 + x1 + x2);           117     x = G4UniformRand()*(x0 + x1 + x2);
116     if(x > x0) {                                  118     if(x > x0) {
117       x -= x0;                                    119       x -= x0;
118       if(x <= x1 ) {                              120       if(x <= x1 ) {
119   w = w1;                                         121   w = w1;
120   n = n1;                                         122   n = n1;
121   b = b1;                                         123   b = b1;
122       } else {                                    124       } else { 
123   w = w2;                                         125   w = w2;
124   n = n2;                                         126   n = n2;
125   b = b2;                                         127   b = b2;
126       }                                           128       }
127     }                                             129     }
128     n = 1.0/n;                                    130     n = 1.0/n;
129                                                   131 
130     // sampling of angle                          132     // sampling of angle
131     G4double y = w*G4UniformRand();               133     G4double y = w*G4UniformRand();
132     if(y < numlim) { x = y*n*( 1. + 0.5*(n + 1 << 134     if(y < numlim) { x = y*n*( 1. + 0.5*(n + 1.)*y*(1. - (n + 2.)*y/3.)); }
                                                   >> 135     //else           { x = 1.0/std::pow(1 - y, n) - 1.0; }
133     else           { x = G4Exp(-n*G4Log(1. - y    136     else           { x = G4Exp(-n*G4Log(1. - y)) - 1.0; }
134     cost = 1.0 - x/(b*xx);                        137     cost = 1.0 - x/(b*xx);
                                                   >> 138     //G4cout << "cost = " << cost << " w= " << w << " n= " << n 
                                                   >> 139     //     << " b= " << b << " x= " << x << " xx= " << xx << G4endl;  
135   } while (2*G4UniformRand() > 1.0 + cost*cost    140   } while (2*G4UniformRand() > 1.0 + cost*cost || cost < -1.0);
136                                                   141 
137   G4double phi  = twopi*G4UniformRand();          142   G4double phi  = twopi*G4UniformRand();
138   G4double sint = sqrt((1. - cost)*(1.0 + cost    143   G4double sint = sqrt((1. - cost)*(1.0 + cost));
139   fLocalDirection.set(sint*cos(phi),sint*sin(p    144   fLocalDirection.set(sint*cos(phi),sint*sin(phi),cost);
140   fLocalDirection.rotateUz(dp->GetMomentumDire    145   fLocalDirection.rotateUz(dp->GetMomentumDirection());
141                                                   146 
142   return fLocalDirection;                         147   return fLocalDirection;
143 }                                                 148 }
144                                                   149 
145 //....oooOO0OOooo........oooOO0OOooo........oo    150 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo.... ....oooOO0OOooo....
                                                   >> 151 
146 const G4double                                    152 const G4double
147   G4RayleighAngularGenerator::PP0[101] = {0,   << 153 G4RayleighAngularGenerator::PP0[101] = { 0, 
148   -2.477067493e-06, 3.308728278e+00, 5.2145900 << 154 0, 2., 5.21459, 10.2817, 3.66207, 3.63903, 3.71155, 36.5165, 3.43548, 3.40045,     // 1-10 
149   3.407539119e+00, 3.387258718e+00, 3.23054486 << 155 2.87811, 3.35541, 3.21141, 2.95234, 3.02524, 126.146, 175.044, 162, 296.833, 300.994,     // 11-20 
150   3.731860000e+02, 4.201934230e+02, 4.61292033 << 156 373.186, 397.823, 430.071, 483.293, 2.14885, 335.553, 505.422, 644.739, 737.017, 707.575,     // 21-30 
151   4.773566612e+02, 5.084376201e+02, 5.41367729 << 157 3.8094, 505.957, 4.10347, 574.665, 15.5277, 10.0991, 4.95013, 16.3391, 6.20836, 3.52767,     // 31-40 
152   2.972874756e+00, 2.740289935e+00, 2.50748731 << 158 2.7763, 2.19565, 12.2802, 965.741, 1011.09, 2.85583, 3.65673, 225.777, 1.95284, 15.775,     // 41-50 
153   6.127527681e+01, 3.792700000e+00, 4.79811088 << 159 39.9006, 3.7927, 64.7339, 1323.91, 3.73723, 2404.54, 28.3408, 29.9869, 217.128, 71.7138,     // 51-60 
154   1.194981340e+02, 2.167522747e+02, 3.36459000 << 160 255.42, 134.495, 3364.59, 425.326, 449.405, 184.046, 3109.04, 193.133, 3608.48, 152.967,     // 61-70 
155   1.431016078e+02, 1.359161828e+02, 3.67045607 << 161 484.517, 422.591, 423.518, 393.404, 437.172, 432.356, 478.71, 455.097, 495.237, 417.8,     // 71-80 
156   3.340399767e+02, 3.011038509e+03, 3.48549794 << 162 3367.95, 3281.71, 3612.56, 3368.73, 3407.46, 40.2866, 641.24, 826.44, 3579.13, 4916.44,     // 81-90 
157   2.791527615e+00, 3.755804160e+03, 4.86370584 << 163 930.184, 887.945, 3490.96, 4058.6, 3068.1, 3898.32, 1398.34, 5285.18, 1, 872.368,     // 91-100 
158 };                                             << 164 };
159                                                << 165 
160 const G4double                                 << 166 const G4double
161   G4RayleighAngularGenerator::PP1[101] = {0,   << 167 G4RayleighAngularGenerator::PP1[101] = { 0, 
162   1.000002477e+00, 6.912717221e-01, 3.77240000 << 168 1., 2., 3.7724, 2.17924, 11.9967, 17.7772, 23.5265, 23.797, 39.9937, 46.7748,     // 1-10 
163   5.759246095e+01, 6.861274506e+01, 8.37613986 << 169 60, 68.6446, 81.7887, 98, 112, 128, 96.7939, 162, 61.5575, 96.4218,     // 11-20 
164   6.540840000e+01, 6.120116992e+01, 6.54048763 << 170 65.4084, 83.3079, 96.2889, 90.123, 312, 338, 181.943, 94.3868, 54.5084, 132.819,     // 21-30 
165   4.800000000e+02, 5.120000000e+02, 5.44000000 << 171 480, 512, 544, 578, 597.472, 647.993, 682.009, 722, 754.885, 799.974,     // 31-40 
166   8.399999990e+02, 8.819999639e+02, 9.23999352 << 172 840, 882, 924, 968, 1012, 1058, 1104, 1151.95, 1199.05, 1250,     // 41-50 
167   1.300000000e+03, 1.352000000e+03, 1.40024221 << 173 1300, 1352, 1404, 1458, 1512, 729.852, 1596.66, 1682, 1740, 1800,     // 51-60 
168   1.859999972e+03, 1.705247726e+03, 6.03151000 << 174 1605.79, 1787.51, 603.151, 2048, 2112, 1993.95, 334.907, 2312, 885.149, 2337.19,     // 61-70 
169   2.519999640e+03, 2.591999669e+03, 2.31793557 << 175 2036.48, 2169.41, 2241.49, 2344.6, 2812, 2888, 2964, 2918.04, 2882.97, 2938.74,     // 71-80 
170   3.279999955e+03, 3.362000000e+03, 3.44399642 << 176 2716.13, 511.66, 581.475, 594.305, 672.232, 3657.71, 3143.76, 3045.56, 3666.7, 1597.84,     // 81-90 
171   4.139900637e+03, 4.761958553e+02, 3.83862968 << 177 3428.87, 3681.22, 1143.31, 1647.17, 1444.9, 1894.33, 3309.12, 2338.59, 4900, 4856.61,     // 91-100 
172 };                                             << 178 };
173                                                << 179 
174 const G4double                                 << 180 const G4double
175   G4RayleighAngularGenerator::PP2[101] = {0,   << 181 G4RayleighAngularGenerator::PP2[101] = { 0, 
176   0.000000000e+00, 0.000000000e+00, 1.30091000 << 182 0, 0, 0.0130091, 3.53906, 9.34125, 14.5838, 21.7619, 3.68644, 37.5709, 49.8248,     // 1-10 
177   5.999999993e+01, 7.199999622e+01, 8.20080565 << 183 58.1219, 72, 83.9999, 95.0477, 109.975, 1.85351, 17.1623, 0, 2.60927, 2.58422,     // 11-20 
178   2.405300000e+00, 2.605407111e+00, 2.30308987 << 184 2.4053, 2.86948, 2.63999, 2.58417, 310.851, 2.44683, 41.6348, 44.8739, 49.4746, 59.6053,     // 21-30 
179   3.643338776e+00, 3.562379948e+00, 3.63227021 << 185 477.191, 6.04261, 540.897, 3.33531, 612, 637.908, 682.041, 705.661, 759.906, 796.498,     // 31-40 
180   8.380271263e+02, 8.792597462e+02, 9.22493160 << 186 838.224, 879.804, 912.72, 2.25892, 1.90993, 1055.14, 1101.34, 926.275, 1200, 1234.23,     // 41-50 
181   1.239724724e+03, 1.348210000e+03, 1.40395967 << 187 1261.1, 1348.21, 1340.27, 134.085, 1509.26, 1.60851, 1624, 1652.01, 1523.87, 1728.29,     // 51-60 
182   1.741501894e+03, 1.922000000e+03, 1.25916000 << 188 1859.79, 1922, 1.25916, 1622.67, 1663.6, 2178, 1045.05, 2118.87, 267.371, 2409.84,     // 61-70 
183   2.377898752e+03, 2.456084148e+03, 2.64401881 << 189 2520, 2592, 2664, 2738, 2375.83, 2455.64, 2486.29, 2710.86, 2862.79, 3043.46,     // 71-80 
184   2.946960068e+03, 3.509614912e+02, 3.09645378 << 190 476.925, 2930.63, 2694.96, 3092.96, 3145.31, 3698, 3784, 3872, 675.166, 1585.71,     // 81-90 
185   4.138307836e+03, 4.231999985e+03, 4.32399973 << 191 3921.95, 3894.83, 4014.73, 3130.23, 4512, 3423.35, 4701.53, 1980.23, 4900, 4271.02,     // 91-100 
186 };                                             << 192 };
187                                                << 193 
188 const G4double                                 << 194 const G4double
189   G4RayleighAngularGenerator::PP3[101] = {0,   << 195 G4RayleighAngularGenerator::PP3[101] = { 0, 
190   1.325913011e-16, 4.871957764e-16, 1.95042000 << 196 1.53728e-16, 2.95909e-16, 1.95042e-15, 6.24521e-16, 4.69459e-17, 3.1394e-17, 2.38808e-17, 3.59428e-16, 1.2947e-17, 1.01182e-17,     // 1-10 
191   8.030444002e-18, 6.678303405e-18, 5.35823468 << 197 6.99543e-18, 6.5138e-18, 5.24063e-18, 4.12831e-18, 4.22067e-18, 2.12802e-16, 3.27035e-16, 2.27705e-16, 1.86943e-15, 8.10577e-16,     // 11-20 
192   1.805410000e-15, 1.568852030e-15, 1.46426465 << 198 1.80541e-15, 9.32266e-16, 5.93459e-16, 4.93049e-16, 5.03211e-19, 2.38223e-16, 4.5181e-16, 5.34468e-16, 5.16504e-16, 3.0641e-16,     // 21-30 
193   2.121922892e-16, 2.064234936e-16, 1.99647988 << 199 1.24646e-18, 2.13805e-16, 1.21448e-18, 2.02122e-16, 5.91556e-18, 3.4609e-18, 1.39331e-18, 5.47242e-18, 1.71017e-18, 7.92438e-19,     // 31-40 
194   4.605105770e-19, 3.816125471e-19, 3.01753747 << 200 4.72225e-19, 2.74825e-19, 4.02137e-18, 1.6662e-16, 1.68841e-16, 4.73202e-19, 7.28319e-19, 3.64382e-15, 1.53323e-19, 4.15409e-18,     // 41-50 
195   9.418934098e-18, 6.540360000e-19, 6.72335260 << 201 7.91645e-18, 6.54036e-19, 1.04123e-17, 9.116e-17, 5.97268e-19, 1.23272e-15, 5.83259e-18, 5.42458e-18, 2.20137e-17, 1.19654e-17,     // 51-60 
196   1.285032193e-17, 1.897941915e-17, 8.38225000 << 202 2.3481e-17, 1.53337e-17, 8.38225e-16, 3.40248e-17, 3.50901e-17, 1.95115e-17, 2.91803e-16, 1.98684e-17, 3.59425e-16, 1.54e-17,     // 61-70 
197   1.351358940e-17, 1.262062535e-17, 2.23834297 << 203 3.04174e-17, 2.71295e-17, 2.6803e-17, 2.36469e-17, 2.56818e-17, 2.50364e-17, 2.6818e-17, 2.56229e-17, 2.7419e-17, 2.27442e-17,     // 71-80 
198   1.842791671e-17, 1.006061314e-16, 1.84533117 << 204 1.38078e-15, 1.49595e-15, 1.20023e-16, 1.74446e-15, 1.82836e-15, 5.80108e-18, 3.02324e-17, 3.71029e-17, 1.01058e-16, 4.87707e-16,     // 81-90 
199   1.861376691e-19, 8.994366946e-17, 2.16885552 << 205 4.18953e-17, 4.03182e-17, 1.11553e-16, 9.51125e-16, 2.57569e-15, 1.14294e-15, 2.98597e-15, 5.88714e-16, 1.46196e-20, 1.53226e-15,     // 91-100 
200 };                                             << 206 };
201                                                << 207 
202 const G4double                                 << 208 const G4double
203   G4RayleighAngularGenerator::PP4[101] = {0,   << 209 G4RayleighAngularGenerator::PP4[101] = { 0, 
204   1.105926652e-15, 2.260014406e-16, 1.56836000 << 210 1.10561e-15, 3.50254e-16, 1.56836e-16, 7.86286e-15, 2.2706e-16, 7.28454e-16, 4.54123e-16, 8.03792e-17, 4.91833e-16, 1.45891e-16,     // 1-10 
205   2.381852183e-15, 3.734413372e-15, 8.39186756 << 211 1.71829e-16, 3.90707e-15, 2.76487e-15, 4.345e-16, 6.80131e-16, 4.04186e-16, 8.95703e-17, 3.32136e-16, 1.3847e-17, 4.16869e-17,     // 11-20 
206   1.379630000e-17, 9.139141296e-18, 1.87240878 << 212 1.37963e-17, 1.96187e-17, 2.93852e-17, 2.46581e-17, 4.49944e-16, 3.80311e-16, 1.62925e-15, 7.52449e-16, 9.45445e-16, 5.47652e-16,     // 21-30 
207   5.210034592e-16, 7.614492538e-16, 8.94817886 << 213 6.89379e-16, 1.37078e-15, 1.22209e-15, 1.13856e-15, 9.06914e-16, 8.77868e-16, 9.70871e-16, 1.8532e-16, 1.69254e-16, 1.14059e-15,     // 31-40 
208   6.465293663e-16, 3.854995461e-16, 4.89499585 << 214 7.90712e-16, 5.36611e-16, 8.27932e-16, 2.4329e-16, 5.82899e-16, 1.97595e-16, 1.96263e-16, 1.73961e-16, 1.62174e-16, 5.31143e-16,     // 41-50 
209   3.105865310e-16, 4.197600000e-16, 1.32632143 << 215 5.29731e-16, 4.1976e-16, 4.91842e-16, 4.67937e-16, 4.32264e-16, 6.91046e-17, 1.62962e-16, 9.87241e-16, 1.04526e-15, 1.05819e-15,     // 51-60 
210   7.097022036e-16, 1.115122840e-16, 4.61021000 << 216 1.10579e-16, 1.49116e-16, 4.61021e-17, 1.5143e-16, 1.53667e-16, 1.67844e-15, 2.7494e-17, 2.31253e-16, 2.27211e-15, 1.33401e-15,     // 61-70 
211   2.003109343e-16, 1.934498511e-16, 1.31900805 << 217 9.02548e-16, 1.77743e-15, 1.76608e-15, 9.45054e-16, 1.06805e-16, 1.06085e-16, 1.01688e-16, 1.0226e-16, 7.7793e-16, 8.0166e-16,     // 71-80 
212   1.158662950e-15, 1.374180788e-15, 8.56667776 << 218 9.18595e-17, 2.73428e-17, 3.01222e-17, 3.09814e-17, 3.39028e-17, 1.49653e-15, 1.19511e-15, 1.40408e-15, 2.37226e-15, 8.35973e-17,     // 81-90 
213   1.305399034e-16, 2.169990868e-17, 8.37279953 << 219 1.4089e-15, 1.2819e-15, 4.96925e-17, 6.04886e-17, 7.39507e-17, 6.6832e-17, 1.09433e-16, 9.61804e-17, 1.38525e-16, 2.49104e-16,     // 91-100 
214 };                                             << 220 };
215                                                << 221 
216 const G4double                                 << 222 const G4double
217   G4RayleighAngularGenerator::PP5[101] ={0,    << 223 G4RayleighAngularGenerator::PP5[101] = { 0, 
218  6.894128600e-17, 2.232031723e-17, 2.477820000 << 224 6.89413e-17, 2.11456e-17, 2.47782e-17, 7.01557e-17, 1.01544e-15, 1.76177e-16, 1.28191e-16, 1.80511e-17, 1.96803e-16, 3.16753e-16,     // 1-10 
219  5.490626359e-17, 6.721220587e-17, 2.797861959 << 225 1.21362e-15, 6.6366e-17, 8.42625e-17, 1.01935e-16, 1.34162e-16, 1.87076e-18, 2.76259e-17, 1.2217e-16, 1.66059e-18, 1.76249e-18,     // 11-20 
220  1.137340000e-18, 1.172666277e-18, 9.208052526 << 226 1.13734e-18, 1.58963e-18, 1.33987e-18, 1.18496e-18, 2.44536e-16, 6.69957e-19, 2.5667e-17, 2.62482e-17, 2.55816e-17, 2.6574e-17,     // 21-30 
221  1.000486545e-18, 8.890635605e-19, 8.866911360 << 227 2.26522e-16, 2.17703e-18, 2.07434e-16, 8.8717e-19, 1.75583e-16, 1.81312e-16, 1.83716e-16, 2.58371e-15, 1.74416e-15, 1.7473e-16,     // 31-40 
222  1.673069643e-16, 1.638573610e-16, 1.618391268 << 228 1.76817e-16, 1.74757e-16, 1.6739e-16, 2.68691e-19, 1.8138e-19, 1.60726e-16, 1.59441e-16, 1.36927e-16, 2.70127e-16, 1.63371e-16,     // 41-50 
223  1.080904532e-16, 1.490120000e-16, 2.463071192 << 229 1.29776e-16, 1.49012e-16, 1.17301e-16, 1.67919e-17, 1.47596e-16, 1.14246e-19, 1.10392e-15, 1.58755e-16, 1.11706e-16, 1.80135e-16,     // 51-60 
224  1.358154769e-16, 8.509795172e-16, 4.722000000 << 230 1.00213e-15, 9.44133e-16, 4.722e-20, 1.18997e-15, 1.16311e-15, 2.31716e-16, 1.86238e-15, 1.53632e-15, 2.45853e-17, 2.08069e-16,     // 61-70 
225  1.325219469e-15, 1.361391001e-15, 1.166226381 << 231 1.08659e-16, 1.29019e-16, 1.24987e-16, 1.07865e-16, 1.03501e-15, 1.05211e-15, 9.38473e-16, 8.66912e-16, 9.3778e-17, 9.91467e-17,     // 71-80 
226  9.927188930e-17, 1.933919795e-17, 8.642866554 << 232 2.58481e-17, 9.72329e-17, 9.77921e-16, 1.02928e-16, 1.01767e-16, 1.81276e-16, 1.07026e-16, 1.11273e-16, 3.25695e-17, 1.77629e-15,     // 81-90 
227  4.609653396e-16, 1.503608663e-15, 9.130139990 << 233 1.18382e-16, 1.111e-16, 1.56996e-15, 8.45221e-17, 3.6783e-16, 1.20652e-16, 3.91104e-16, 3.52282e-15, 4.29979e-16, 1.28308e-16,     // 91-100 
228 };                                             << 234 };
229                                                << 235 
230 const G4double                                 << 236 const G4double
231   G4RayleighAngularGenerator::PP6[101] = {0,   << 237 G4RayleighAngularGenerator::PP6[101] = { 0, 
232   5.245179284e+00, 3.941069622e+00, 7.59547000 << 238 6.57834, 3.91446, 7.59547, 10.707, 3.97317, 4.00593, 3.93206, 8.10644, 3.97743, 4.04641,     // 1-10 
233   4.165369684e+00, 4.154784462e+00, 4.24310617 << 239 4.30202, 4.19399, 4.27399, 4.4169, 4.04829, 2.21745, 11.3523, 1.84976, 1.61905, 3.68297,     // 11-20 
234   1.570400000e+00, 1.595930653e+00, 1.59229579 << 240 1.5704, 2.58852, 3.59827, 3.61633, 9.07174, 1.76738, 1.97272, 1.91032, 1.9838, 2.64286,     // 21-30 
235   1.788357076e+00, 1.779735777e+00, 1.78269447 << 241 4.16296, 1.80149, 3.94257, 1.72731, 2.27523, 2.57383, 3.33453, 2.2361, 2.94376, 3.91332,     // 31-40 
236   4.992480078e+00, 5.353762609e+00, 5.98387288 << 242 5.01832, 6.8016, 2.19508, 1.65926, 1.63781, 4.23097, 3.4399, 2.55583, 7.96814, 2.06573,     // 41-50 
237   1.895332668e+00, 3.235160000e+00, 3.11741287 << 243 1.84175, 3.23516, 1.79129, 2.90259, 3.18266, 1.51305, 1.88361, 1.91925, 1.68033, 1.72078,     // 51-60 
238   1.735584396e+00, 1.700970330e+00, 1.49394000 << 244 1.66246, 1.66676, 1.49394, 1.58924, 1.57558, 1.63307, 1.84447, 1.60296, 1.56719, 1.62166,     // 61-70 
239   1.646594633e+00, 1.646361209e+00, 1.59689950 << 245 1.5753, 1.57329, 1.558, 1.57567, 1.55612, 1.54607, 1.53251, 1.51928, 1.50265, 1.52445,     // 71-80 
240   1.539905529e+00, 2.445886590e+00, 1.52166658 << 246 1.4929, 1.51098, 2.52959, 1.42334, 1.41292, 2.0125, 1.45015, 1.43067, 2.6026, 1.39261,     // 81-90 
241   2.720221569e+00, 2.423181552e+00, 1.43380003 << 247 1.38559, 1.37575, 2.53155, 2.51924, 1.32386, 2.31791, 2.47722, 1.33584, 9.60979, 6.84949,     // 91-100 
242 };                                             << 248 };
243                                                << 249 
244 const G4double                                 << 250 const G4double
245   G4RayleighAngularGenerator::PP7[101] ={0,    << 251 G4RayleighAngularGenerator::PP7[101] = { 0, 
246  3.999571467e+00, 3.991128282e+00, 3.855930000 << 252 3.99983, 6.63093, 3.85593, 1.69342, 14.7911, 7.03995, 8.89527, 13.1929, 4.93354, 5.59461,     // 1-10 
247  1.860829199e+00, 1.805395915e+00, 5.601066041 << 253 3.98033, 1.74578, 2.67629, 14.184, 8.88775, 13.1809, 4.51627, 13.7677, 9.53727, 4.04257,     // 11-20 
248  7.887250000e+00, 1.010638153e+01, 5.125426065 << 254 7.88725, 5.78566, 4.08148, 4.18194, 7.96292, 8.38322, 3.31429, 13.106, 13.0857, 13.1053,     // 21-30 
249  4.487670198e+00, 3.377601937e+00, 3.060634263 << 255 3.54708, 2.08567, 2.38131, 2.58162, 3.199, 3.20493, 3.19799, 1.88697, 1.80323, 3.15596,     // 31-40 
250  4.924387077e+00, 7.722486735e+00, 6.373463850 << 256 4.10675, 5.68928, 3.93024, 11.2607, 4.86595, 12.1708, 12.2867, 9.29496, 1.61249, 5.0998,     // 41-50 
251  8.586125523e+00, 6.676730000e+00, 1.759586815 << 257 5.25068, 6.67673, 5.82498, 6.12968, 6.94532, 1.71622, 1.63028, 3.34945, 2.84671, 2.66325,     // 51-60 
252  3.616573408e+00, 2.616627730e+00, 1.724970000 << 258 2.73395, 1.93715, 1.72497, 2.74504, 2.71531, 1.52039, 1.58191, 1.61444, 2.67701, 1.51369,     // 61-70 
253  1.632630475e+00, 1.635873458e+00, 1.825704957 << 259 2.60766, 1.46608, 1.49792, 2.49166, 2.84906, 2.80604, 2.92788, 2.76411, 2.59305, 2.5855,     // 71-80 
254  1.775440582e+00, 1.577663847e+00, 2.371177051 << 260 2.80503, 1.4866, 1.46649, 1.45595, 1.44374, 1.54865, 2.45661, 2.43268, 1.35352, 1.35911,     // 81-90 
255  1.455793655e+00, 1.441149845e+00, 2.479382371 << 261 2.26339, 2.26838, 1.35877, 1.37826, 1.3499, 1.36574, 1.33654, 1.33001, 1.37648, 4.28173,     // 91-100 
256 };                                             << 262 };
257                                                << 263 
258 const G4double                                 << 264 const G4double
259   G4RayleighAngularGenerator::PP8[101] = {0,   << 265 G4RayleighAngularGenerator::PP8[101] = { 0, 
260   3.999988492e+00, 3.007894874e+00, 5.94686000 << 266 4, 4, 5.94686, 4.10265, 7.87177, 12.0509, 12.0472, 3.90597, 5.34338, 6.33072,     // 1-10 
261   1.115856859e+01, 7.827803195e+00, 2.64112611 << 267 2.76777, 7.90099, 5.58323, 4.26372, 3.3005, 5.69179, 2.3698, 3.68167, 5.2807, 4.61212,     // 11-20 
262   5.878090000e+00, 5.532784283e+00, 5.96333790 << 268 5.87809, 4.46207, 4.59278, 4.67584, 1.75212, 7.00575, 2.05428, 2.00415, 2.02048, 1.98413,     // 21-30 
263   4.551995537e+00, 4.677756013e+00, 4.52827956 << 269 1.71725, 3.18743, 1.74231, 4.40997, 2.01626, 1.8622, 1.7544, 1.60332, 2.23338, 1.70932,     // 31-40 
264   1.727732750e+00, 1.724150271e+00, 1.70951822 << 270 1.67223, 1.64655, 1.76198, 6.33416, 7.92665, 1.67835, 1.67408, 1.55895, 9.3642, 1.68776,     // 41-50 
265   2.409664359e+00, 1.654010000e+00, 1.13468614 << 271 2.02167, 1.65401, 2.20616, 1.76498, 1.63064, 7.13771, 3.17033, 1.65236, 2.66943, 1.62703,     // 51-60 
266   2.057911711e+00, 2.980049185e+00, 1.08600000 << 272 2.72469, 2.73686, 10.86, 2.76759, 2.69728, 1.62436, 2.76662, 1.48514, 1.57342, 1.61518,     // 61-70 
267   1.536232590e+00, 1.520253937e+00, 2.70110718 << 273 3.18455, 2.73467, 2.72521, 2.786, 2.35611, 2.31574, 2.5787, 2.46877, 2.89052, 2.6478,     // 71-80 
268   2.454130254e+00, 1.522182263e+00, 2.58554126 << 274 1.50419, 2.73998, 2.79809, 2.66207, 2.73089, 1.34835, 2.59656, 2.7006, 1.41867, 4.26255,     // 81-90 
269   4.518186694e+00, 1.690796964e+00, 2.45897436 << 275 2.47985, 2.47126, 1.72573, 3.44856, 1.36451, 2.8715, 2.35731, 1.28196, 4.1224, 1.32633,     // 91-100 
270 };                                                276 };
                                                   >> 277  
271 //....oooOO0OOooo........oooOO0OOooo........oo    278 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo.... ....oooOO0OOooo....
272                                                   279