function wtn(q2_set) include ? real p1,p2,p3,p4,p5,p6,p7,p8,p9,p10,p11,p12 real nsigl,nsigt,nsiglt,nsigtt,tmp real nsig219,nsig,wtn real pi,mtar_gev real my_limit integer q2_set parameter (pi=3.14159) parameter (mtar_gev=0.93827231) if (abs(q2_set-055).lt.1) then p1= 0.29088E+03 p2= -0.60000E+03 p3= -0.10677E+02 p4= 0.19000E+02 p5= 0.51834E+02 p6= 0.20556E+03 p7= -0.94798E+02 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.70274E+02 p12= 0.00000E+00 elseif (abs(q2_set-060).lt.1) then p1= 0.57593E+03 p2= -0.60000E+03 p3= -0.18255E+02 p4= 0.19000E+02 p5= 0.15023E+02 p6= 0.16474E+03 p7= 0.91255E+02 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.71086E+02 p12= 0.00000E+00 elseif (abs(q2_set-065).lt.1) then p1= 0.23880E+04 p2= -0.60000E+03 p3= -0.42496E+02 p4= 0.19000E+02 p5= -0.14984E+03 p6= 0.13367E+03 p7= 0.10945E+04 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.67886E+02 p12= 0.00000E+00 elseif (abs(q2_set-075).lt.1) then p1= -0.85510E+02 p2= -0.60000E+03 p3= 0.86994E+01 p4= 0.19000E+02 p5= -0.91077E+02 p6= -0.50971E+03 p7= 0.17270E+04 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.80523E+02 p12= 0.00000E+00 elseif (abs(q2_set-100).lt.1) then p1= 0.48039E+03 p2= -0.60000E+03 p3= -0.14619E+02 p4= 0.19000E+02 p5= -0.80872E+02 p6= -0.22015E+03 p7= 0.16566E+04 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.96493E+02 p12= 0.00000E+00 elseif (abs(q2_set-160).lt.1) then p1= 0.37283E+03 p2= -0.60000E+03 p3= -0.16320E+02 p4= 0.19000E+02 p5= -0.35092E+03 p6= -0.72114E+03 p7= 0.10622E+05 p8= -0.50000E+02 p9= 0.00000E+00 p10=-0.20000E+02 p11=-0.55054E+02 p12= 0.00000E+00 else write(*,*)'wtn: q2 error ',q2_set endif *** * Cornel's parameterization c nsigl=(p1+p2*Q2i)*exp((p3+p4*Q2i)*ti) c nsigt=(p5+p6*Q2i)*exp((p7+p8*Q2i)*ti) c c tmp=ti/(ti+0.02)**2 c nsiglt=p9*exp(p10*ti)*sin(thetacmi) c nsigtt=(p11/Q2i+p12/Q2i**2)*tmp*sin(thetacmi)**2 c * New parameterization suggested by Henk, 11.04.27 c nsigl=(p1+p2*Q2i)*exp((p3+p4*log(Q2i))*ti) c nsigt=(p5/Q2i+p6/Q2i**2)*exp((p7+p8*log(Q2i))*ti) c nsiglt=p9*exp(p10*ti)*sin(thetacmi) c c tmp=ti/(ti+0.02)**2 c nsigtt=(p11/Q2i+p12/Q2i**2)*tmp*sin(thetacmi)**2 c * Revised parameterization after IT17, 12.04.01 tmp=ti/(ti+0.139570**2)**2 nsigl=(p1+p2*log(Q2i))*exp((p3+p4*log(Q2i))*ti) nsigt=p5+p6*tmp*(sin(thetacmi)**2)+(p7/Q2i**3+p8)*ti nsiglt=p9*exp(p10*ti)*sin(thetacmi) nsigtt=(p11/Q2i+p12/Q2i**2)*tmp*sin(thetacmi)**2 nsig219=(nsigt+epsiloni*nsigl+epsiloni*cos(2.*phicmi)*nsigtt 1 +sqrt(2.0*epsiloni*(1.+epsiloni))*cos(phicmi)*nsiglt)/1.d0 wfactor=1.D0/(Wcmi**2-mtar_gev**2)**2 nsig=nsig219*wfactor nsig=nsig/2./pi/1.d+06 !dsig/dtdphicm in microbarns/MeV**2/rad wtn=Weight*nsig/dsigdt my_limit=0.20 if ((wtn.lt.my_limit).and.(wtn.gt.0.0)) then continue else wtn=0. endif return end