4 subroutine MRST2006evolve(x,Q,pdf)
6 ! implicit real*8 (a-h,o-z)
7 include 'parmsetup.inc'
8 character*16 name(nmxset)
11 integer i,f,nhess,nx,nq,np,nqc0,nqb0,nqc,nqb,n,m,io
12 double precision x,q,xmin,xmax,qsqmin,qsqmax,emc2,emb2,eps,dummy,qsq, &
13 xlog,qsqlog,res,ExtrapLHAPDF,InterpLHAPDF
14 double precision emc2minuseps,emb2minuseps
15 double precision xsave,q2save
16 double precision pdf(-6:6),alfas,Qalfa,Q2fit,eorder
17 double precision upv,dnv,glu,usea,str,dsea,sbar,chm,bot
18 integer iset,nflav,mem,nset,nmem(nmxset),ndef(nmxset),mmem,imem
19 common/NAME/name,nmem,ndef,mmem
20 parameter(nx=64,nq=48,np=9,nqc0=4,nqb0=14,nqc=nq-nqc0,nqb=nq-nqb0)
21 parameter(xmin=1d-6,xmax=1d0,qsqmin=1d0,qsqmax=1d9,eps=1d-6)
22 parameter(nhess=0,emc2=1.43d0**2,emb2=4.3d0**2) ! MRST 2006 NNLO
23 parameter(emc2minuseps=emc2-eps,emb2minuseps=emb2-eps)
24 double precision f1(nx,nq),f2(nx,nq),f3(nx,nq),f4(nx,nq),f5(nx,nq), &
25 f6(nx,nq),f7(nx,nq),f8(nx,nq),fc(nx,nqc),fb(nx,nqb),f9(nx,nq)
26 double precision qq(nq),xx(nx),cc1(0:nhess,nx,nq,4,4),cc2(0:nhess,nx,nq,4,4), &
27 cc3(0:nhess,nx,nq,4,4),cc4(0:nhess,nx,nq,4,4),cc6(0:nhess,nx,nq,4,4), &
28 cc8(0:nhess,nx,nq,4,4),cc9(0:nhess,nx,nq,4,4),ccc(0:nhess,nx,nqc,4,4), &
29 ccb(0:nhess,nx,nqb,4,4)
30 double precision xxl(nx),qql(nq),qqlc(nqc),qqlb(nqb)
31 data xx/1d-6,2d-6,4d-6,6d-6,8d-6,1d-5,2d-5,4d-5,6d-5,8d-5,1d-4,2d-4,4d-4,6d-4, &
32 8d-4,1d-3,2d-3,4d-3,6d-3,8d-3,1d-2,1.4d-2,2d-2,3d-2,4d-2,6d-2,8d-2, &
33 .1d0,.125d0,.15d0,.175d0,.2d0,.225d0,.25d0,.275d0,.3d0,.325d0,.35d0,.375d0, &
34 .4d0,.425d0,.45d0,.475d0,.5d0,.525d0,.55d0,.575d0,.6d0,.625d0,.65d0,.675d0, &
35 .7d0,.725d0,.75d0,.775d0,.8d0,.825d0,.85d0,.875d0,.9d0,.925d0,.95d0,.975d0,1d0/
36 data qq/1.d0,1.25d0,1.5d0,emc2minuseps,emc2,2.5d0,3.2d0,4d0,5d0,6.4d0,8d0,1d1,1.2d1, &
37 emb2minuseps,emb2,2.6d1,4d1,6.4d1,1d2,1.6d2,2.4d2,4d2,6.4d2,1d3,1.8d3,3.2d3,5.6d3, &
38 1d4,1.8d4,3.2d4,5.6d4,1d5,1.8d5,3.2d5,5.6d5,1d6,1.8d6,3.2d6,5.6d6,1d7,1.8d7,3.2d7, &
39 5.6d7,1d8,1.8d8,3.2d8,5.6d8,1d9/
46 if (qsq.gt.qq(nqc0).and.qsq.lt.qq(nqc0+1)) qsq = qq(nqc0)
47 if (qsq.gt.qq(nqb0).and.qsq.lt.qq(nqb0+1)) qsq = qq(nqb0)
53 call getnmem(iset,imem)
65 if (x.le.0.d0.or.x.gt.xmax.or.qsq.lt.qsqmin) then
66 print *,"Error in GetOnePDF: x,qsq = ",x,qsq
67 else if (x.lt.xmin.or.qsq.gt.qsqmax) then ! extrapolate
68 print *, "Warning in GetOnePDF, extrapolating: f = ",f,", x = ",x,", q = ",q
69 upv = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc1)
70 dnv = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc2)
71 glu = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc3)
72 usea = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc4)
73 str = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc6)
74 dsea = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc8)
75 sbar = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc9)
76 if (qsq.ge.emc2) then ! chm
77 chm = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nqc,xxl,qqlc,ccc)
79 if (qsq.ge.emb2) then ! bot
80 bot = ExtrapLHAPDF(imem,nhess,xlog,qsqlog,nx,nqb,xxl,qqlb,ccb)
83 upv = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc1)
84 dnv = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc2)
85 glu = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc3)
86 usea = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc4)
87 str = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc6)
88 dsea = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc8)
89 sbar = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nq,xxl,qql,cc9)
90 if (qsq.ge.emc2) then ! chm
91 chm = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nqc,xxl,qqlc,ccc)
93 if (qsq.ge.emb2) then ! bot
94 bot = InterpLHAPDF(imem,nhess,xlog,qsqlog,nx,nqb,xxl,qqlb,ccb)
117 !----------------------------------------------------------------------
119 entry MRST2006read(nset)
120 ! - dummy read in to get to End: (stream 1 is still open)
121 read(1,*)nmem(nset),ndef(nset)
133 !----------------------------------------------------------------------
135 entry MRST2006alfa(nflav,alfas,Qalfa)
136 ! print *,'MRST2006alfa',nflav,alfas,Qalfa
138 call alphamrs(nflav,alfas,Qalfa)
139 ! print *,'MRST2006alfa',nflav,alfas,Qalfa
142 !----------------------------------------------------------------------
144 entry MRST2006init(Eorder,Q2fit)
147 !----------------------------------------------------------------------
149 entry MRST2006pdf(mem)
151 call setnmem(iset,mem)
153 ! have to reopen stream 1
154 call getsetpath(setpath)
155 open(1,file=setpath(1:len_trim(setpath)))
158 do while (line(2:11).ne.'Evolution:')
164 read(1,*)nmem(iset),ndef(iset)
166 ! - dummy read up to the member requested
176 !- read in the data of the requested member
180 read(1,50) f1(n,m),f2(n,m),f3(n,m),f4(n,m),f5(n,m),f7(n,m),f6(n,m),f8(n,m),f9(n,m)
181 ! write(6,50) f1(n,m),f2(n,m),f3(n,m),f4(n,m),f5(n,m),f7(n,m),f6(n,m),f8(n,m),f9(n,m)
182 !-- Notation:1=upv 2=dnv 3=glu 4=usea 5=chm 6=str 7=bot 8=dsea 9=sbar
185 ! write(*,*)'PDF set ',i,' first element ',f1(1,1)
205 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f1,cc1)
206 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f2,cc2)
207 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f3,cc3)
208 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f4,cc4)
209 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f6,cc6)
210 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f8,cc8)
211 call InitialLHAPDF(i,nhess,nx,nq,nqc0,nqb0,xxl,qql,f9,cc9)
219 call InitialLHAPDF(i,nhess,nx,nqc,nqc0-nqc0,nqb0-nqc0,xxl,qqlc,fc,ccc)
227 call InitialLHAPDF(i,nhess,nx,nqb,nqc0-nqb0,nqb0-nqb0,xxl,qqlb,fb,ccb)
233 end subroutine MRST2006evolve
236 !----------------------------------------------------------------------
239 subroutine InitialLHAPDF(i,nhess,nx,my,myc0,myb0,xx,yy,ff,cc)
241 integer nhess,i,nx,my,myc0,myb0,j,k,l,m,n
242 double precision xx(nx),yy(my),ff(nx,my),ff1(nx,my),ff2(nx,my),ff12(nx,my), &
243 yy0(4),yy1(4),yy2(4),yy12(4),z(16),cl(16),cc(0:nhess,nx,my,4,4), &
244 iwt(16,16),dx,dy,polderiv,d1,d2,d1d2,xxd
245 data iwt/1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, &
246 0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0, &
247 -3,0,0,3,0,0,0,0,-2,0,0,-1,0,0,0,0, &
248 2,0,0,-2,0,0,0,0,1,0,0,1,0,0,0,0, &
249 0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0, &
250 0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0, &
251 0,0,0,0,-3,0,0,3,0,0,0,0,-2,0,0,-1, &
252 0,0,0,0,2,0,0,-2,0,0,0,0,1,0,0,1, &
253 -3,3,0,0,-2,-1,0,0,0,0,0,0,0,0,0,0, &
254 0,0,0,0,0,0,0,0,-3,3,0,0,-2,-1,0,0, &
255 9,-9,9,-9,6,3,-3,-6,6,-6,-3,3,4,2,1,2, &
256 -6,6,-6,6,-4,-2,2,4,-3,3,3,-3,-2,-1,-1,-2, &
257 2,-2,0,0,1,1,0,0,0,0,0,0,0,0,0,0, &
258 0,0,0,0,0,0,0,0,2,-2,0,0,1,1,0,0, &
259 -6,6,-6,6,-3,-3,3,3,-4,4,2,-2,-2,-2,-1,-1, &
260 4,-4,4,-4,2,2,-2,-2,2,-2,-2,2,1,1,1,1/
264 ff1(1,m)=(ff(2,m)-ff(1,m))/dx
266 ff1(nx,m)=(ff(nx,m)-ff(nx-1,m))/dx
268 ff1(n,m)=polderiv(xx(n-1),xx(n),xx(n+1),ff(n-1,m),ff(n,m),ff(n+1,m))
272 !-- Calculate the derivatives at qsq=emc2-eps,emc2,emb2-eps,emb2
273 !-- in a similar way as at the endpoints qsqmin and qsqmax.
276 if (m.eq.1.or.m.eq.myc0+1.or.m.eq.myb0+1) then
278 ff2(n,m)=(ff(n,m+1)-ff(n,m))/dy
279 else if (m.eq.my.or.m.eq.myc0.or.m.eq.myb0) then
281 ff2(n,m)=(ff(n,m)-ff(n,m-1))/dy
283 ff2(n,m)=polderiv(yy(m-1),yy(m),yy(m+1),ff(n,m-1),ff(n,m),ff(n,m+1))
290 ff12(1,m)=(ff2(2,m)-ff2(1,m))/dx
292 ff12(nx,m)=(ff2(nx,m)-ff2(nx-1,m))/dx
294 ff12(n,m)=polderiv(xx(n-1),xx(n),xx(n+1),ff2(n-1,m),ff2(n,m),ff2(n+1,m))
321 yy12(3)=ff12(n+1,m+1)
334 xxd=xxd+iwt(k,l)*z(k)
348 end subroutine InitialLHAPDF
351 !----------------------------------------------------------------------
354 double precision function InterpLHAPDF(i,nhess,x,y,nx,my,xx,yy,cc)
356 integer i,nx,my,nhess,locx,l,m,n
357 double precision xx(nx),yy(my),cc(0:nhess,nx,my,4,4),x,y,z,t,u
362 t=(x-xx(n))/(xx(n+1)-xx(n))
363 u=(y-yy(m))/(yy(m+1)-yy(m))
367 z = t*z + ((cc(i,n,m,l,4)*u + cc(i,n,m,l,3))*u + cc(i,n,m,l,2))*u + cc(i,n,m,l,1)
373 end function InterpLHAPDF
376 !----------------------------------------------------------------------
379 double precision function ExtrapLHAPDF(i,nhess,x,y,nx,my,xx,yy,cc)
381 integer i,nx,my,nhess,locx,n,m
382 double precision xx(nx),yy(my),cc(0:nhess,nx,my,4,4),x,y,z,f0,f1,z0,z1,InterpLHAPDF
384 n=locx(xx,nx,x) ! 0: below xmin, nx: above xmax
385 m=locx(yy,my,y) ! 0: below qsqmin, my: above qsqmax
387 !-- If extrapolation in small x only:
388 if (n.eq.0.and.m.gt.0.and.m.lt.my) then
389 f0 = InterpLHAPDF(i,nhess,xx(1),y,nx,my,xx,yy,cc)
390 f1 = InterpLHAPDF(i,nhess,xx(2),y,nx,my,xx,yy,cc)
391 if (f0.gt.0.d0.and.f1.gt.0.d0) then
392 z = exp(log(f0)+(log(f1)-log(f0))/(xx(2)-xx(1))*(x-xx(1)))
394 z = f0+(f1-f0)/(xx(2)-xx(1))*(x-xx(1))
396 !-- If extrapolation into large q only:
397 else if (n.gt.0.and.m.eq.my) then
398 f0 = InterpLHAPDF(i,nhess,x,yy(my),nx,my,xx,yy,cc)
399 f1 = InterpLHAPDF(i,nhess,x,yy(my-1),nx,my,xx,yy,cc)
400 if (f0.gt.0.d0.and.f1.gt.0.d0) then
401 z = exp(log(f0)+(log(f0)-log(f1))/(yy(my)-yy(my-1))*(y-yy(my)))
403 z = f0+(f0-f1)/(yy(my)-yy(my-1))*(y-yy(my))
405 !-- If extrapolation into large q AND small x:
406 else if (n.eq.0.and.m.eq.my) then
407 f0 = InterpLHAPDF(i,nhess,xx(1),yy(my),nx,my,xx,yy,cc)
408 f1 = InterpLHAPDF(i,nhess,xx(1),yy(my-1),nx,my,xx,yy,cc)
409 if (f0.gt.0.d0.and.f1.gt.0.d0) then
410 z0 = exp(log(f0)+(log(f0)-log(f1))/(yy(my)-yy(my-1))*(y-yy(my)))
412 z0 = f0+(f0-f1)/(yy(my)-yy(my-1))*(y-yy(my))
414 f0 = InterpLHAPDF(i,nhess,xx(2),yy(my),nx,my,xx,yy,cc)
415 f1 = InterpLHAPDF(i,nhess,xx(2),yy(my-1),nx,my,xx,yy,cc)
416 if (f0.gt.0.d0.and.f1.gt.0.d0) then
417 z1 = exp(log(f0)+(log(f0)-log(f1))/(yy(my)-yy(my-1))*(y-yy(my)))
419 z1 = f0+(f0-f1)/(yy(my)-yy(my-1))*(y-yy(my))
421 if (z0.gt.0.d0.and.z1.gt.0.d0) then
422 z = exp(log(z0)+(log(z1)-log(z0))/(xx(2)-xx(1))*(x-xx(1)))
424 z = z0+(z1-z0)/(xx(2)-xx(1))*(x-xx(1))
427 print *,"Error in ExtrapLHAPDF"
434 end function ExtrapLHAPDF
437 !----------------------------------------------------------------------