spline modules added, grayl removed

This commit is contained in:
Lorenzo Figini 2015-06-12 12:08:45 +00:00
parent 139f42fee2
commit 5f8f6c454d
5 changed files with 4929 additions and 4738 deletions

View File

@ -3,11 +3,10 @@ EXE=gray
# Objects list # Objects list
MAINOBJ=gray.o MAINOBJ=gray.o
OTHOBJ=conical.o const_and_precisions.o dispersion.o eierf.o \ OTHOBJ=conical.o const_and_precisions.o dierckx.o dispersion.o eierf.o \
graydata_flags.o graydata_par.o graydata_anequil.o grayl.o \ graydata_anequil.o graydata_flags.o graydata_par.o green_func_p.o \
green_func_p.o interp_eqprof.o magsurf_data.o math.o minpack.o \ interp_eqprof.o magsurf_data.o math.o minpack.o numint.o quadpack.o \
numint.o quadpack.o reflections.o utils.o reflections.o simplespline.o utils.o
# Alternative search paths # Alternative search paths
vpath %.f90 src vpath %.f90 src
@ -26,23 +25,25 @@ $(EXE): $(MAINOBJ) $(OTHOBJ)
$(FC) $(FFLAGS) -o $@ $^ $(FC) $(FFLAGS) -o $@ $^
# Dependencies on modules # Dependencies on modules
gray.o: const_and_precisions.o conical.o dispersion.o green_func_p.o \ gray.o: const_and_precisions.o conical.o dierckx.o dispersion.o \
graydata_flags.o graydata_par.o graydata_anequil.o interp_eqprof.o \ graydata_anequil.o graydata_flags.o graydata_par.o green_func_p.o \
magsurf_data.o math.o minpack.o numint.o quadpack.o reflections.o \ interp_eqprof.o magsurf_data.o math.o minpack.o numint.o quadpack.o \
utils.o reflections.o simplespline.o utils.o
grayl.o: const_and_precisions.o
green_func_p.o: const_and_precisions.o numint.o
numint.o: const_and_precisions.o
reflections.o: const_and_precisions.o utils.o
conical.o: const_and_precisions.o conical.o: const_and_precisions.o
dierckx.o: const_and_precisions.o
dispersion.o: const_and_precisions.o eierf.o math.o quadpack.o dispersion.o: const_and_precisions.o eierf.o math.o quadpack.o
math.o: const_and_precisions.o graydata_anequil.o: const_and_precisions.o
minpack.o: const_and_precisions.o
graydata_flags.o: const_and_precisions.o graydata_flags.o: const_and_precisions.o
graydata_par.o: const_and_precisions.o graydata_par.o: const_and_precisions.o
graydata_anequil.o: const_and_precisions.o green_func_p.o: const_and_precisions.o numint.o
magsurf_data.o: const_and_precisions.o
interp_eqprof.o: const_and_precisions.o interp_eqprof.o: const_and_precisions.o
magsurf_data.o: const_and_precisions.o
math.o: const_and_precisions.o
minpack.o: const_and_precisions.o
numint.o: const_and_precisions.o
quadpack.o: const_and_precisions.o
reflections.o: const_and_precisions.o utils.o
simplespline.o: const_and_precisions.o
utils.o: const_and_precisions.o utils.o: const_and_precisions.o
# General object compilation command # General object compilation command

4609
src/dierckx.f90 Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1055,6 +1055,7 @@ c
subroutine read_beams subroutine read_beams
use graydata_flags, only : filenmbm, ibeam use graydata_flags, only : filenmbm, ibeam
use utils, only : locate use utils, only : locate
use simplespline, only : difcs,spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
parameter(nstrmx=50) parameter(nstrmx=50)
@ -1167,6 +1168,7 @@ c
subroutine equidata subroutine equidata
use const_and_precisions, only : pi use const_and_precisions, only : pi
use utils, only : vmaxmini use utils, only : vmaxmini
use dierckx, only : curfit,splev,regrid,bispev,coeff_parder
use graydata_flags, only : ipsinorm,sspl,ixp,icocos,neqdsk use graydata_flags, only : ipsinorm,sspl,ixp,icocos,neqdsk
use graydata_par, only : sgnbphi,sgniphi,factb use graydata_par, only : sgnbphi,sgniphi,factb
use interp_eqprof, only : nsrt,nszt,nsft,rlim,zlim,nlim,nr,nz, use interp_eqprof, only : nsrt,nszt,nsft,rlim,zlim,nlim,nr,nz,
@ -1858,6 +1860,8 @@ c
use graydata_par, only : psdbnd,factb,factt,factn use graydata_par, only : psdbnd,factb,factt,factn
use interp_eqprof, only : nsfd,npp,psnpp,aa,bb,cc, use interp_eqprof, only : nsfd,npp,psnpp,aa,bb,cc,
. psrad,derad,terad,zfc,tfn,cfn,ct,cz,alloc_profvec . psrad,derad,terad,zfc,tfn,cfn,ct,cz,alloc_profvec
use simplespline, only : difcsn
use dierckx, only : curfit,splev,splder
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
integer, dimension(:), allocatable :: iwrkf integer, dimension(:), allocatable :: iwrkf
@ -1968,6 +1972,7 @@ c
c c
subroutine rhotor(nnr) subroutine rhotor(nnr)
use interp_eqprof, only : nr,psinr,qpsi,crhot,cq use interp_eqprof, only : nr,psinr,qpsi,crhot,cq
use simplespline, only : difcsn
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
real*8, dimension(:), allocatable :: rhotnr real*8, dimension(:), allocatable :: rhotnr
@ -2006,6 +2011,7 @@ c
function fq_eq(psi) function fq_eq(psi)
use interp_eqprof, only : psinr,nr,cq use interp_eqprof, only : psinr,nr,cq
use simplespline, only :spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
@ -2019,6 +2025,7 @@ c
function frhotor_eq(psi) function frhotor_eq(psi)
use interp_eqprof, only : psinr,nr,crhot use interp_eqprof, only : psinr,nr,crhot
use simplespline, only :spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
c c
@ -2042,6 +2049,7 @@ c if(irt.eq.nr) irt=nr-1
function frhotor_av(psi) function frhotor_av(psi)
use magsurf_data, only : rpstab, crhotq, npsi use magsurf_data, only : rpstab, crhotq, npsi
use simplespline, only :spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
@ -2056,6 +2064,7 @@ c if(ip.eq.npsi) ip=npsi-1
end end
subroutine rhopol subroutine rhopol
use dierckx, only : curfit,splev
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
parameter(nnr=101,nrest=nnr+4) parameter(nnr=101,nrest=nnr+4)
parameter(lwrkp=nnr*4+nrest*16) parameter(lwrkp=nnr*4+nrest*16)
@ -2094,6 +2103,7 @@ c end do
end end
function frhopol(rhot) function frhopol(rhot)
use dierckx, only : splev
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
parameter(nnr=101,nrest=nnr+4) parameter(nnr=101,nrest=nnr+4)
dimension trp(nrest),crp(nrest),rrs(1),ffspl(1) dimension trp(nrest),crp(nrest),rrs(1),ffspl(1)
@ -2305,8 +2315,8 @@ c
use magsurf_data, only : npoints use magsurf_data, only : npoints
use interp_eqprof, only : psia,psiant,psinop,nsr=>nsrt,nsz=>nszt, use interp_eqprof, only : psia,psiant,psinop,nsr=>nsrt,nsz=>nszt,
. cc=>cceq,tr,tz,rup,zup,rlw,zlw,nr . cc=>cceq,tr,tz,rup,zup,rlw,zlw,nr
use const_and_precisions, only : pi use const_and_precisions, only : pi
use dierckx, only : profil,sproota
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
parameter(mest=4,kspl=3) parameter(mest=4,kspl=3)
dimension zeroc(mest) dimension zeroc(mest)
@ -2370,6 +2380,8 @@ c
use const_and_precisions, only : zero,one,pi,ccj=>mu0inv use const_and_precisions, only : zero,one,pi,ccj=>mu0inv
use magsurf_data use magsurf_data
use interp_eqprof, only : btrcen,btaxis,rmaxis,zmaxis,phitedge use interp_eqprof, only : btrcen,btaxis,rmaxis,zmaxis,phitedge
use simplespline, only : difcs
use dierckx, only : regrid,coeff_parder
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
real*8 lam real*8 lam
@ -2721,6 +2733,7 @@ c spline interpolation of H(lambda,rhop) and dH/dlambda
function fdadrhot(rpsi) function fdadrhot(rpsi)
use magsurf_data, only : rpstab,cdadrhot,npsi use magsurf_data, only : rpstab,cdadrhot,npsi
use simplespline, only :spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
@ -2735,6 +2748,7 @@ c if(ip.eq.npsi) ip=npsi-1
function fdvdrhot(rpsi) function fdvdrhot(rpsi)
use magsurf_data, only : rpstab,cdvdrhot,npsi use magsurf_data, only : rpstab,cdvdrhot,npsi
use simplespline, only :spli
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
@ -2749,6 +2763,8 @@ c if(ip.eq.npsi) ip=npsi-1
use graydata_anequil, only : q0,qa,alq,b0,rr0m,zr0m,rpam use graydata_anequil, only : q0,qa,alq,b0,rr0m,zr0m,rpam
use magsurf_data use magsurf_data
use interp_eqprof, only : btrcen use interp_eqprof, only : btrcen
use simplespline, only : difcs
use dierckx, only : regrid,coeff_parder
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
real*8 lam real*8 lam
@ -3127,6 +3143,7 @@ c spline interpolation of H(lambda,rhop) and dH/dlambda
subroutine rhopol_an subroutine rhopol_an
use dierckx, only : curfit,splev
use graydata_par, only : sgniphi use graydata_par, only : sgniphi
use graydata_anequil, only : q0,qa,alq,b0,rr0m,rpam use graydata_anequil, only : q0,qa,alq,b0,rr0m,rpam
use interp_eqprof, only : psia use interp_eqprof, only : psia
@ -3199,6 +3216,7 @@ c spline interpolation of rhotor versus rhopol
function frhotor_an(rhop) function frhotor_an(rhop)
use dierckx, only : splev
implicit real*8(a-h,o-z) implicit real*8(a-h,o-z)
parameter(nnr=101,nrest=nnr+4) parameter(nnr=101,nrest=nnr+4)
dimension trot(nrest),crot(nrest),rrs(1),ffspl(1) dimension trot(nrest),crot(nrest),rrs(1),ffspl(1)
@ -4153,6 +4171,7 @@ c
subroutine equinum_psi(rpsim,zpsim) subroutine equinum_psi(rpsim,zpsim)
use interp_eqprof, only : rmnm,rmxm,zmnm,zmxm,psiant,psinop, use interp_eqprof, only : rmnm,rmxm,zmnm,zmxm,psiant,psinop,
. tr,tz,ccspl=>cceq,nsrt,nszt . tr,tz,ccspl=>cceq,nsrt,nszt
use dierckx, only : fpbisp
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
parameter(lwrk=8,liwrk=2) parameter(lwrk=8,liwrk=2)
@ -4263,6 +4282,7 @@ c here lengths are measured in meters
end end
subroutine sub_derpsi(rpsim,zpsim,nur,nuz,derpsi,cc,lw) subroutine sub_derpsi(rpsim,zpsim,nur,nuz,derpsi,cc,lw)
use dierckx, only : fpbisp
use interp_eqprof, only : nr,nz,psia,tr,tz,nsrt,nszt use interp_eqprof, only : nr,nz,psia,tr,tz,nsrt,nszt
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
@ -4288,6 +4308,7 @@ c here lengths are measured in meters
end end
subroutine equinum_fpol(iderfpol) subroutine equinum_fpol(iderfpol)
use dierckx, only : splev,splder
use interp_eqprof, only : nr,psia,tfp,nsft,cfp,fpolas use interp_eqprof, only : nr,psia,tfp,nsft,cfp,fpolas
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
@ -4369,7 +4390,7 @@ c
subroutine psi_raxis(h,r1,r2) subroutine psi_raxis(h,r1,r2)
use interp_eqprof, only : psiant,psinop,zmaxis,nsr=>nsrt, use interp_eqprof, only : psiant,psinop,zmaxis,nsr=>nsrt,
. nsz=>nszt,cc=>cceq,tr,tz,nr . nsz=>nszt,cc=>cceq,tr,tz,nr
use dierckx, only : profil,sproota
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
parameter(mest=4,kspl=3) parameter(mest=4,kspl=3)
dimension zeroc(mest) dimension zeroc(mest)
@ -4421,6 +4442,7 @@ c
use graydata_anequil, only : dens0,aln1,aln2 use graydata_anequil, only : dens0,aln1,aln2
use interp_eqprof, only : psnpp,aad=>aa,bbd=>bb,ccd=>cc,tfn,nsfd, use interp_eqprof, only : psnpp,aad=>aa,bbd=>bb,ccd=>cc,tfn,nsfd,
. cfn,npp . cfn,npp
use dierckx, only : splev,splder
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
dimension xxs(1),ffs(1) dimension xxs(1),ffs(1)
@ -4478,6 +4500,7 @@ c
use graydata_anequil, only : te0,dte0,alt1,alt2 use graydata_anequil, only : te0,dte0,alt1,alt2
use interp_eqprof, only : psrad,ct,npp use interp_eqprof, only : psrad,ct,npp
use utils, only : locate use utils, only : locate
use simplespline, only :spli
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
c c
@ -4503,6 +4526,7 @@ c
use graydata_anequil, only : zeffan use graydata_anequil, only : zeffan
use interp_eqprof, only : psrad,cz,npp use interp_eqprof, only : psrad,cz,npp
use utils, only : locate use utils, only : locate
use simplespline, only :spli
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
c c
@ -5191,6 +5215,7 @@ c
c c
subroutine valpsispl(rpsi,voli,dervoli,areai,rrii,rbavi, subroutine valpsispl(rpsi,voli,dervoli,areai,rrii,rbavi,
. bmxi,bmni,fci,intp) . bmxi,bmni,fci,intp)
use simplespline, only :spli,splid
use magsurf_data, only : rpstab,cvol,crri,crbav,cbmx,cbmn, use magsurf_data, only : rpstab,cvol,crri,crbav,cbmx,cbmn,
. carea,cfc,npsi . carea,cfc,npsi
@ -5222,6 +5247,7 @@ c
c c
subroutine ratioj(rpsi,ratjai,ratjbi,ratjpli) subroutine ratioj(rpsi,ratjai,ratjbi,ratjpli)
use magsurf_data, only : rpstab,cratja,cratjb,cratjpl,npsi use magsurf_data, only : rpstab,cratja,cratjb,cratjpl,npsi
use simplespline, only :spli
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
@ -5909,13 +5935,12 @@ c
subroutine vlambda(alam,psi,fv,dfv) subroutine vlambda(alam,psi,fv,dfv)
use magsurf_data, only : ch,ch01,tjp,tlm,njpt,nlmt,npsi use magsurf_data, only : ch,ch01,tjp,tlm,njpt,nlmt,npsi
use dierckx, only : fpbisp
implicit real*8 (a-h,o-z) implicit real*8 (a-h,o-z)
parameter (nlam=41) parameter (nlam=41)
parameter(ksp=3,nlest=nlam+ksp+1) parameter(ksp=3,nlest=nlam+ksp+1)
external fpbisp
dimension xxs(1),yys(1),ffs(1) dimension xxs(1),yys(1),ffs(1)
integer, dimension(:), allocatable :: iwrk integer, dimension(:), allocatable :: iwrk
real*8, dimension(:), allocatable :: wrk real*8, dimension(:), allocatable :: wrk

File diff suppressed because it is too large Load Diff

273
src/simplespline.f90 Normal file
View File

@ -0,0 +1,273 @@
module simplespline
use const_and_precisions, only : wp_
implicit none
contains
function spli(cspli,n,k,dx)
implicit none
integer, intent(in) :: n, k
real(wp_), intent(in) :: cspli(n,4), dx
real(wp_) :: spli
spli=cspli(k,1)+dx*(cspli(k,2)+dx*(cspli(k,3)+dx*cspli(k,4)))
end function spli
function splid(cspli,n,k,dx)
implicit none
integer, intent(in) :: n, k
real(wp_), intent(in) :: cspli(n,4), dx
real(wp_) :: splid
splid=cspli(k,2)+dx*(2.0_wp_*cspli(k,3)+3.0_wp_*dx*cspli(k,4))
end function splid
subroutine difcs(x,y,n,iopt,c,ier)
implicit none
integer, intent(in) :: n, iopt
real(wp_), intent(in) :: x(n), y(n)
real(wp_), intent(inout) :: c(n*4)
integer :: ier
integer :: jmp,iol,ioh,i,ii,j,j1,j2,j3
real(wp_) :: xb,xc,ya,yb,h,a,r,dya,dyb,dy2
jmp =1
if (n <= 1) return
!
! initialization
!
xc =x(1)
yb =y(1)
h =0.0_wp_
a =0.0_wp_
r =0.0_wp_
dyb =0.0_wp_
!
! iol=0 - given derivative at first point
! ioh=0 - given derivative at last point
!
iol =iopt-1
ioh =iopt-2
if (ioh == 1) then
iol =0
ioh =0
end if
dy2 =c(2)
!
! form the system of linear equations
! and eliminate subsequentially
!
j =1
do i=1,n
j2 =n+i
j3 =j2+n
a =h*(2.0_wp_-a)
dya =dyb+h*r
if (i>=n) then
!
! set derivative dy2 at last point
!
dyb =dy2
h =0.0_wp_
if (ioh/=0) then
dyb =dya
goto 13
end if
else
j =j+jmp
xb =xc
xc =x(j)
h =xc-xb
!
! ii=0 - increasing abscissae
! ii=1 - decreasing abscissae
!
ii =0
if (h==0) return
if (h<0) ii =1
ya =yb
yb =y(j)
dyb =(yb-ya)/h
if (i<=1) then
j1 =ii
if (iol/=0) goto 13
dya =c(1)
end if
end if
if (j1-ii /= 0) return
a =1.0_wp_/(h+h+a)
13 continue
r =a*(dyb-dya)
c(j3)=r
a =h*a
c(j2)=a
c(i) =dyb
end do
!
! back substitution of the system of linear equations
! and computation of the other coefficients
!
a =1.0_wp_
j1 =j3+n+ii-ii*n
i =n
do iol=1,n
xb =x(j)
h =xc-xb
xc =xb
a =a+h
yb =r
r =c(j3)-r*c(j2)
ya =r+r
c(j3)=ya+r
c(j2)=c(i)-h*(ya+yb)
c(j1)=(yb-r)/a
c(i) =y(j)
a =0.0_wp_
j =j-jmp
i =i-1
j2 =j2-1
j3 =j3-1
j1 =j3+n+ii
end do
ier =0
end subroutine difcs
subroutine difcsn(xx,yy,nmx,n,iopt,cc,ier)
!
! same as difcs but with dimension(xx,yy) = nmx > n
!
implicit none
integer, intent(in) :: nmx, n, iopt
real(wp_), intent(in) :: xx(nmx), yy(nmx)
real(wp_), intent(inout) :: cc(nmx,4)
integer :: ier
integer :: jmp,iol,ioh,i,ii,j,j1,j2,j3
real(wp_) :: x(n),y(n),c(n*4),xb,xc,ya,yb,h,a,r,dya,dyb,dy2
!
do i=1,n
x(i)=xx(i)
y(i)=yy(i)
end do
ii=0
do j=1,4
do i=1,n
ii=ii+1
c(ii)=cc(i,j)
end do
end do
!
jmp =1
if (n>1) then
!
! initialization
!
xc =x(1)
yb =y(1)
h =0.0_wp_
a =0.0_wp_
r =0.0_wp_
dyb =0.0_wp_
!
! iol=0 - given derivative at first point
! ioh=0 - given derivative at last point
!
iol =iopt-1
ioh =iopt-2
if (ioh==1) then
iol =0
ioh =0
end if
dy2 =c(2)
!
! form the system of linear equations
! and eliminate subsequentially
!
j =1
do i=1,n
j2 =n+i
j3 =j2+n
a =h*(2.0_wp_-a)
dya =dyb+h*r
if (i>=n) then
!
! set derivative dy2 at last point
!
dyb =dy2
h =0.0_wp_
if (ioh/=0) then
dyb =dya
goto 13
end if
else
j =j+jmp
xb =xc
xc =x(j)
h =xc-xb
!
! ii=0 - increasing abscissae
! ii=1 - decreasing abscissae
!
ii =0
if (h==0) goto 16
if (h<0) ii =1
ya =yb
yb =y(j)
dyb =(yb-ya)/h
if (i<=1) then
j1 =ii
if (iol/=0) goto 13
dya =c(1)
end if
end if
if (j1/=ii) goto 16
a =1.0_wp_/(h+h+a)
13 continue
r =a*(dyb-dya)
c(j3)=r
a =h*a
c(j2)=a
c(i) =dyb
end do
!
! back substitution of the system of linear equations
! and computation of the other coefficients
!
a =1.0_wp_
j1 =j3+n+ii-ii*n
i =n
do iol=1,n
xb =x(j)
h =xc-xb
xc =xb
a =a+h
yb =r
r =c(j3)-r*c(j2)
ya =r+r
c(j3)=ya+r
c(j2)=c(i)-h*(ya+yb)
c(j1)=(yb-r)/a
c(i) =y(j)
a =0.0_wp_
j =j-jmp
i =i-1
j2 =j2-1
j3 =j3-1
j1 =j3+n+ii
end do
ier =0
end if
!
16 continue
ii=0
do j=1,4
do i=1,nmx
if(i<=n) then
ii=ii+1
cc(i,j)=c(ii)
else
cc(i,j)=0.0_wp_
end if
end do
end do
!
end subroutine difcsn
end module simplespline