69   G4double gmo2 = (gamma - 1.)*(gamma - 1.);
 
   71   G4double pref = gamma2*re2/(gmo2*(gamma + 1.0));
 
   80   if (flag==0) polarized=
false;
 
   84   phi0+= ((1. - 2.*gamma)/gamma2)*(1./e + 1./(1.-e));
 
   85   phi0+= 1./(e*e) + 1./((1. - e)*(1. - e));
 
   90     if (flag<=1) usephi=0.;
 
   94     G4double xx = (gamma - f*e*gmo*(3. + gamma))/(4.*f*e*gamma2);
 
   95     G4double yy = (-1. + f*e*gmo2 + 2.*gamma)/(4.*f*e*gamma2);
 
   96     G4double zz = (-(e*gmo*(3. + gamma)) + e2*gmo*(3. + gamma) + 
 
   97            gamma*(-1. + 2.*gamma))/(4.*f*e*gamma2);
 
   99     phi0 += xx*pol0.
x()*pol1.
x() + yy*pol0.
y()*pol1.
y() + zz*pol0.
z()*pol1.
z();
 
  104       G4double xz = -((-1. + 2.*e)*gmo)/(2.*sqrttwo*gamma2*
 
  105                        std::sqrt(-((f*e)/gpo)));
 
  108       G4double zx = -((-1. + 2.*e)*gmo)/(2.*sqrttwo*gamma2*
 
  109                        std::sqrt(-((f*e)/gpo)));
 
  111       phi0+=yx*pol0.
y()*pol1.
x() + xy*pol0.
x()*pol1.
y();
 
  112       phi0+=zx*pol0.
z()*pol1.
x() + xz*pol0.
x()*pol1.
z();
 
  113       phi0+=zy*pol0.
z()*pol1.
y() + yz*pol0.
y()*pol1.
z();
 
  127       G4double xxP1K1 = (std::sqrt(gpo/(1. + e2*gmo + gamma - 2.*e*gamma))*
 
  128              (gamma - e*gpo))/(4.*e2*gamma);
 
  130       G4double xzP1K1 = (-1. + 2.*e*gamma)/(2.*sqrttwo*f*gamma*
 
  131                       std::sqrt(e*e2*(1. + e + gamma - e*gamma)));
 
  133       G4double yyP1K1 = (-gamma2 + e*(-1. + gamma*(2. + gamma)))/(4.*f*e2*gamma2);
 
  135       G4double zxP1K1 = (1. + 2.*e2*gmo - 2.*e*gamma)/(2.*sqrttwo*f*e*gamma*
 
  136                             std::sqrt(e*(1. + e + gamma - e*gamma)));
 
  138       G4double zzP1K1 = (-gamma + e*(1. - 2.*e*gmo + gamma))/(4.*f*e2*gamma*
 
  139                                 std::sqrt(1. - (2.*e)/(f*gpo)));
 
  140       phi2[0] += xxP1K1*pol0.
x() + xyP1K1*pol0.
y() + xzP1K1*pol0.
z();
 
  141       phi2[1] += yxP1K1*pol0.
x() + yyP1K1*pol0.
y() + yzP1K1*pol0.
z();
 
  142       phi2[2] += zxP1K1*pol0.
x() + zyP1K1*pol0.
y() + zzP1K1*pol0.
z();
 
  146       G4double xxP1K2 = ((1. + e*(-3. + gamma))*std::sqrt(gpo/(1. + e2*gmo + gamma - 
 
  147                                  2.*e*gamma)))/(4.*f*e*gamma);
 
  149       G4double xzP1K2 = (-2. + 2.*e + gamma)/(2.*sqrttwo*f2*gamma*
 
  150                         std::sqrt(e*(1. + e + gamma - e*gamma)));
 
  152       G4double yyP1K2 = (1. - 2.*gamma + e*(-1. + gamma*(2. + gamma)))/(4.*f2*e*gamma2);
 
  154       G4double zxP1K2 = (2.*e*(1. + e*gmo - 2.*gamma) + gamma)/(2.*sqrttwo*f2*gamma*
 
  155                                  std::sqrt(e*(1. + e + gamma - e*gamma)));
 
  157       G4double zzP1K2 = (1. - 2.*gamma + e*(-1. - 2.*e*gmo + 3.*gamma))/
 
  158     (4.*f2*e*gamma*std::sqrt(1. - (2.*e)/(f*gpo)));
 
  159       phi2[0] += xxP1K2*pol1.
x() + xyP1K2*pol1.
y() + xzP1K2*pol1.
z();
 
  160       phi2[1] += yxP1K2*pol1.
x() + yyP1K2*pol1.
y() + yzP1K2*pol1.
z();
 
  161       phi2[2] += zxP1K2*pol1.
x() + zyP1K2*pol1.
y() + zzP1K2*pol1.
z();
 
  171       G4double xxP2K1 = (-1. + e + e*gamma)/(4.*f2*gamma*
 
  172                         std::sqrt((e*(2. + e*gmo))/gpo));
 
  174       G4double xzP2K1 = -((1. + 2.*f*gamma)*std::sqrt(f/(-2. + e - e*gamma)))/
 
  175     (2.*sqrttwo*f2*e*gamma);
 
  177       G4double yyP2K1 = (1. - 2.*gamma + e*(-1. + gamma*(2. + gamma)))/(4.*f2*e*gamma2);
 
  179       G4double zxP2K1 = (1. + 2.*e*(-2. + e + gamma - e*gamma))/(2.*sqrttwo*f*e*
 
  180                                   std::sqrt(-(f*(2. + e*gmo)))*gamma);
 
  182       G4double zzP2K1 = (std::sqrt((e*gpo)/(2. + e*gmo))*
 
  183              (-3. + e*(5. + 2.*e*gmo - 3.*gamma) + 2.*gamma))/(4.*f2*e*gamma);
 
  185       phi3[0] += xxP2K1*pol0.
x() + xyP2K1*pol0.
y() + xzP2K1*pol0.
z();
 
  186       phi3[1] += yxP2K1*pol0.
x() + yyP2K1*pol0.
y() + yzP2K1*pol0.
z();
 
  187       phi3[2] += zxP2K1*pol0.
x() + zyP2K1*pol0.
y() + zzP2K1*pol0.
z();
 
  192       G4double xxP2K2 = (-2. - e*(-3. + gamma) + gamma)/
 
  193     (4.*f*e*gamma* std::sqrt((e*(2. + e*gmo))/gpo));
 
  195       G4double xzP2K2 = ((-2.*e + gamma)*std::sqrt(f/(-2. + e - e*gamma)))/
 
  196     (2.*sqrttwo*f*e2*gamma);
 
  198       G4double yyP2K2 = (-gamma2 + e*(-1. + gamma*(2. + gamma)))/(4.*f*e2*gamma2);
 
  200       G4double zxP2K2 = (gamma + 2.*e*(-1. + e - e*gamma))/
 
  201     (2.*sqrttwo*e2* std::sqrt(-(f*(2. + e*gmo)))*gamma);
 
  203       G4double zzP2K2 = (std::sqrt((e*gpo)/(2. + e*gmo))*
 
  204              (-2. + e*(3. + 2.*e*gmo - gamma) + gamma))/(4.*f*e2*gamma);
 
  205       phi3[0] += xxP2K2*pol1.
x() + xyP2K2*pol1.
y() + xzP2K2*pol1.
z();
 
  206       phi3[1] += yxP2K2*pol1.
x() + yyP2K2*pol1.
y() + yzP2K2*pol1.
z();
 
  207       phi3[2] += zxP2K2*pol1.
x() + zyP2K2*pol1.
y() + zzP2K2*pol1.
z();
 
  223     xs+=phi2*pol2 + phi3*pol3;
 
  236   if (xmax != 1./2.) 
G4cout<<
" warning xmax expected to be 1/2 but is "<<xmax<< 
G4endl;
 
  241   G4double gmo2 = (gamma - 1.)*(gamma - 1.);
 
  242   G4double logMEM = std::log(1./x - 1.);
 
  246     sigma0 += (gmo2/gamma2)*(0.5 - x);
 
  247     sigma0 += ((1. - 2.*gamma)/gamma2)*logMEM;
 
  248     sigma0 += 1./x - 1./(1. - x);
 
  251     sigma2 += ((gamma2 + 2.*gamma - 3.)/gamma2)*(0.5 - x);
 
  252     sigma2 += (1./gamma - 2.)*logMEM;
 
  255     sigma3 += (2.*(1. - gamma)/gamma2)*(0.5 - x);
 
  256     sigma3 += (1. - 3.*gamma)/(2.*gamma2)*logMEM;
 
  258   xs+=pref*(sigma0 + sigma2*pol0.
z()*pol1.
z() + sigma3*(pol0.
x()*pol1.
x()+pol0.
y()*pol1.
y()));
 
  268   return 1./phi0 * phi2;
 
  274   return 1./phi0 * phi3;
 
G4double XSection(const G4StokesVector &pol2, const G4StokesVector &pol3) override
 
void Initialize(G4double x, G4double y, G4double phi, const G4StokesVector &p0, const G4StokesVector &p1, G4int flag=0) override
 
CLHEP::Hep3Vector G4ThreeVector
 
G4StokesVector GetPol2() override
 
static constexpr double twopi
 
G4PolarizedMollerCrossSection()
 
G4GLOB_DLL std::ostream G4cout
 
static constexpr double classic_electr_radius
 
void SetXmax(G4double xmax)
 
G4double TotalXSection(G4double xmin, G4double xmax, G4double y, const G4StokesVector &pol0, const G4StokesVector &pol1) override
 
G4StokesVector GetPol3() override
 
virtual ~G4PolarizedMollerCrossSection()